mirror of
https://github.com/torvalds/linux.git
synced 2025-11-02 17:49:03 +02:00
drm/gma500: Inline psbfb_create() into psbfb_probe()
Inline psbfb_create() into its only caller psbfb_probe(). Streamline the color-depth selection. Also clean up the naming around struct drm_fb_helper_funcs. v2: * rename psbfb_probe() (Patrik) Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de> Acked-by: Patrik Jakobsson <patrik.r.jakobsson@gmail.com> Link: https://patchwork.freedesktop.org/patch/msgid/20230313151610.14367-6-tzimmermann@suse.de
This commit is contained in:
parent
a89c957a95
commit
d19ccb4ca5
1 changed files with 29 additions and 42 deletions
|
|
@ -137,31 +137,49 @@ static const struct fb_ops psb_fbdev_fb_ops = {
|
||||||
* struct drm_fb_helper_funcs
|
* struct drm_fb_helper_funcs
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int psbfb_create(struct drm_fb_helper *fb_helper,
|
static int psb_fbdev_fb_probe(struct drm_fb_helper *fb_helper,
|
||||||
struct drm_fb_helper_surface_size *sizes)
|
struct drm_fb_helper_surface_size *sizes)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = fb_helper->dev;
|
struct drm_device *dev = fb_helper->dev;
|
||||||
struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
|
struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
|
||||||
struct pci_dev *pdev = to_pci_dev(dev->dev);
|
struct pci_dev *pdev = to_pci_dev(dev->dev);
|
||||||
struct fb_info *info;
|
struct fb_info *info;
|
||||||
struct drm_framebuffer *fb;
|
struct drm_framebuffer *fb;
|
||||||
struct drm_mode_fb_cmd2 mode_cmd;
|
struct drm_mode_fb_cmd2 mode_cmd = { };
|
||||||
int size;
|
int size;
|
||||||
int ret;
|
int ret;
|
||||||
struct psb_gem_object *backing;
|
struct psb_gem_object *backing;
|
||||||
struct drm_gem_object *obj;
|
struct drm_gem_object *obj;
|
||||||
u32 bpp, depth;
|
u32 bpp, depth;
|
||||||
|
|
||||||
mode_cmd.width = sizes->surface_width;
|
/* No 24-bit packed mode */
|
||||||
mode_cmd.height = sizes->surface_height;
|
if (sizes->surface_bpp == 24) {
|
||||||
|
sizes->surface_bpp = 32;
|
||||||
|
sizes->surface_depth = 24;
|
||||||
|
}
|
||||||
bpp = sizes->surface_bpp;
|
bpp = sizes->surface_bpp;
|
||||||
depth = sizes->surface_depth;
|
depth = sizes->surface_depth;
|
||||||
|
|
||||||
/* No 24bit packed */
|
/*
|
||||||
if (bpp == 24)
|
* If the mode does not fit in 32 bit then switch to 16 bit to get
|
||||||
bpp = 32;
|
* a console on full resolution. The X mode setting server will
|
||||||
|
* allocate its own 32-bit GEM framebuffer.
|
||||||
|
*/
|
||||||
|
size = ALIGN(sizes->surface_width * DIV_ROUND_UP(bpp, 8), 64) *
|
||||||
|
sizes->surface_height;
|
||||||
|
size = ALIGN(size, PAGE_SIZE);
|
||||||
|
|
||||||
|
if (size > dev_priv->vram_stolen_size) {
|
||||||
|
sizes->surface_bpp = 16;
|
||||||
|
sizes->surface_depth = 16;
|
||||||
|
}
|
||||||
|
bpp = sizes->surface_bpp;
|
||||||
|
depth = sizes->surface_depth;
|
||||||
|
|
||||||
|
mode_cmd.width = sizes->surface_width;
|
||||||
|
mode_cmd.height = sizes->surface_height;
|
||||||
mode_cmd.pitches[0] = ALIGN(mode_cmd.width * DIV_ROUND_UP(bpp, 8), 64);
|
mode_cmd.pitches[0] = ALIGN(mode_cmd.width * DIV_ROUND_UP(bpp, 8), 64);
|
||||||
|
mode_cmd.pixel_format = drm_mode_legacy_fb_format(bpp, depth);
|
||||||
|
|
||||||
size = mode_cmd.pitches[0] * mode_cmd.height;
|
size = mode_cmd.pitches[0] * mode_cmd.height;
|
||||||
size = ALIGN(size, PAGE_SIZE);
|
size = ALIGN(size, PAGE_SIZE);
|
||||||
|
|
@ -180,8 +198,6 @@ static int psbfb_create(struct drm_fb_helper *fb_helper,
|
||||||
goto err_drm_gem_object_put;
|
goto err_drm_gem_object_put;
|
||||||
}
|
}
|
||||||
|
|
||||||
mode_cmd.pixel_format = drm_mode_legacy_fb_format(bpp, depth);
|
|
||||||
|
|
||||||
fb = psb_framebuffer_create(dev, &mode_cmd, obj);
|
fb = psb_framebuffer_create(dev, &mode_cmd, obj);
|
||||||
if (IS_ERR(fb)) {
|
if (IS_ERR(fb)) {
|
||||||
ret = PTR_ERR(fb);
|
ret = PTR_ERR(fb);
|
||||||
|
|
@ -217,37 +233,8 @@ static int psbfb_create(struct drm_fb_helper *fb_helper,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int psbfb_probe(struct drm_fb_helper *fb_helper,
|
static const struct drm_fb_helper_funcs psb_fbdev_fb_helper_funcs = {
|
||||||
struct drm_fb_helper_surface_size *sizes)
|
.fb_probe = psb_fbdev_fb_probe,
|
||||||
{
|
|
||||||
struct drm_device *dev = fb_helper->dev;
|
|
||||||
struct drm_psb_private *dev_priv = to_drm_psb_private(dev);
|
|
||||||
unsigned int fb_size;
|
|
||||||
int bytespp;
|
|
||||||
|
|
||||||
bytespp = sizes->surface_bpp / 8;
|
|
||||||
if (bytespp == 3) /* no 24bit packed */
|
|
||||||
bytespp = 4;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If the mode will not fit in 32bit then switch to 16bit to get
|
|
||||||
* a console on full resolution. The X mode setting server will
|
|
||||||
* allocate its own 32bit GEM framebuffer
|
|
||||||
*/
|
|
||||||
fb_size = ALIGN(sizes->surface_width * bytespp, 64) *
|
|
||||||
sizes->surface_height;
|
|
||||||
fb_size = ALIGN(fb_size, PAGE_SIZE);
|
|
||||||
|
|
||||||
if (fb_size > dev_priv->vram_stolen_size) {
|
|
||||||
sizes->surface_bpp = 16;
|
|
||||||
sizes->surface_depth = 16;
|
|
||||||
}
|
|
||||||
|
|
||||||
return psbfb_create(fb_helper, sizes);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct drm_fb_helper_funcs psb_fb_helper_funcs = {
|
|
||||||
.fb_probe = psbfb_probe,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static int psb_fbdev_destroy(struct drm_device *dev,
|
static int psb_fbdev_destroy(struct drm_device *dev,
|
||||||
|
|
@ -280,7 +267,7 @@ int psb_fbdev_init(struct drm_device *dev)
|
||||||
|
|
||||||
dev_priv->fb_helper = fb_helper;
|
dev_priv->fb_helper = fb_helper;
|
||||||
|
|
||||||
drm_fb_helper_prepare(dev, fb_helper, 32, &psb_fb_helper_funcs);
|
drm_fb_helper_prepare(dev, fb_helper, 32, &psb_fbdev_fb_helper_funcs);
|
||||||
|
|
||||||
ret = drm_fb_helper_init(dev, fb_helper);
|
ret = drm_fb_helper_init(dev, fb_helper);
|
||||||
if (ret)
|
if (ret)
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue