185397f6bSThomas Zimmermann // SPDX-License-Identifier: GPL-2.0-only
285397f6bSThomas Zimmermann 
385397f6bSThomas Zimmermann #include <linux/pci.h>
485397f6bSThomas Zimmermann 
585397f6bSThomas Zimmermann #include <drm/drm_drv.h>
685397f6bSThomas Zimmermann 
785397f6bSThomas Zimmermann #include "mgag200_drv.h"
885397f6bSThomas Zimmermann 
985397f6bSThomas Zimmermann /*
1085397f6bSThomas Zimmermann  * DRM device
1185397f6bSThomas Zimmermann  */
1285397f6bSThomas Zimmermann 
1385397f6bSThomas Zimmermann struct mga_device *mgag200_g200wb_device_create(struct pci_dev *pdev, const struct drm_driver *drv,
1485397f6bSThomas Zimmermann 						enum mga_type type, unsigned long flags)
1585397f6bSThomas Zimmermann {
1685397f6bSThomas Zimmermann 	struct mga_device *mdev;
1785397f6bSThomas Zimmermann 	struct drm_device *dev;
1885397f6bSThomas Zimmermann 	int ret;
1985397f6bSThomas Zimmermann 
2085397f6bSThomas Zimmermann 	mdev = devm_drm_dev_alloc(&pdev->dev, drv, struct mga_device, base);
2185397f6bSThomas Zimmermann 	if (IS_ERR(mdev))
2285397f6bSThomas Zimmermann 		return mdev;
2385397f6bSThomas Zimmermann 	dev = &mdev->base;
2485397f6bSThomas Zimmermann 
2585397f6bSThomas Zimmermann 	pci_set_drvdata(pdev, dev);
2685397f6bSThomas Zimmermann 
27*ce19021fSThomas Zimmermann 	ret = mgag200_init_pci_options(pdev, 0x41049120, 0x0000b000);
28*ce19021fSThomas Zimmermann 	if (ret)
29*ce19021fSThomas Zimmermann 		return ERR_PTR(ret);
30*ce19021fSThomas Zimmermann 
3185397f6bSThomas Zimmermann 	mdev->flags = flags;
3285397f6bSThomas Zimmermann 	mdev->type = type;
3385397f6bSThomas Zimmermann 
3485397f6bSThomas Zimmermann 	ret = mgag200_regs_init(mdev);
3585397f6bSThomas Zimmermann 	if (ret)
3685397f6bSThomas Zimmermann 		return ERR_PTR(ret);
3785397f6bSThomas Zimmermann 
3885397f6bSThomas Zimmermann 	ret = mgag200_mm_init(mdev);
3985397f6bSThomas Zimmermann 	if (ret)
4085397f6bSThomas Zimmermann 		return ERR_PTR(ret);
4185397f6bSThomas Zimmermann 
4285397f6bSThomas Zimmermann 	ret = mgag200_modeset_init(mdev);
4385397f6bSThomas Zimmermann 	if (ret)
4485397f6bSThomas Zimmermann 		return ERR_PTR(ret);
4585397f6bSThomas Zimmermann 
4685397f6bSThomas Zimmermann 	return mdev;
4785397f6bSThomas Zimmermann }
48