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