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; 18*d45e32c9SThomas Zimmermann resource_size_t vram_available; 1985397f6bSThomas Zimmermann int ret; 2085397f6bSThomas Zimmermann 2185397f6bSThomas Zimmermann mdev = devm_drm_dev_alloc(&pdev->dev, drv, struct mga_device, base); 2285397f6bSThomas Zimmermann if (IS_ERR(mdev)) 2385397f6bSThomas Zimmermann return mdev; 2485397f6bSThomas Zimmermann dev = &mdev->base; 2585397f6bSThomas Zimmermann 2685397f6bSThomas Zimmermann pci_set_drvdata(pdev, dev); 2785397f6bSThomas Zimmermann 28ce19021fSThomas Zimmermann ret = mgag200_init_pci_options(pdev, 0x41049120, 0x0000b000); 29ce19021fSThomas Zimmermann if (ret) 30ce19021fSThomas Zimmermann return ERR_PTR(ret); 31ce19021fSThomas Zimmermann 3285397f6bSThomas Zimmermann mdev->flags = flags; 3385397f6bSThomas Zimmermann mdev->type = type; 3485397f6bSThomas Zimmermann 3585397f6bSThomas Zimmermann ret = mgag200_regs_init(mdev); 3685397f6bSThomas Zimmermann if (ret) 3785397f6bSThomas Zimmermann return ERR_PTR(ret); 3885397f6bSThomas Zimmermann 3985397f6bSThomas Zimmermann ret = mgag200_mm_init(mdev); 4085397f6bSThomas Zimmermann if (ret) 4185397f6bSThomas Zimmermann return ERR_PTR(ret); 4285397f6bSThomas Zimmermann 43*d45e32c9SThomas Zimmermann vram_available = mgag200_device_probe_vram(mdev); 44*d45e32c9SThomas Zimmermann 45*d45e32c9SThomas Zimmermann ret = mgag200_modeset_init(mdev, vram_available); 4685397f6bSThomas Zimmermann if (ret) 4785397f6bSThomas Zimmermann return ERR_PTR(ret); 4885397f6bSThomas Zimmermann 4985397f6bSThomas Zimmermann return mdev; 5085397f6bSThomas Zimmermann } 51