Commit 5c465601 authored by Jani Nikula's avatar Jani Nikula Committed by Robert Foss

drm/bochs: switch to struct drm_edid

Prefer struct drm_edid based functions over struct edid.
Signed-off-by: default avatarJani Nikula <jani.nikula@intel.com>
Reviewed-by: default avatarRobert Foss <rfoss@kernel.org>
Signed-off-by: default avatarRobert Foss <rfoss@kernel.org>
Link: https://patchwork.freedesktop.org/patch/msgid/24536f4a1a12af7b43ba86e9761dfeef179b72df.1715347488.git.jani.nikula@intel.com
parent 78e90e00
...@@ -85,7 +85,7 @@ struct bochs_device { ...@@ -85,7 +85,7 @@ struct bochs_device {
u16 yres_virtual; u16 yres_virtual;
u32 stride; u32 stride;
u32 bpp; u32 bpp;
struct edid *edid; const struct drm_edid *drm_edid;
/* drm */ /* drm */
struct drm_device *dev; struct drm_device *dev;
...@@ -199,10 +199,10 @@ static int bochs_hw_load_edid(struct bochs_device *bochs) ...@@ -199,10 +199,10 @@ static int bochs_hw_load_edid(struct bochs_device *bochs)
if (drm_edid_header_is_valid(header) != 8) if (drm_edid_header_is_valid(header) != 8)
return -1; return -1;
kfree(bochs->edid); drm_edid_free(bochs->drm_edid);
bochs->edid = drm_do_get_edid(&bochs->connector, bochs->drm_edid = drm_edid_read_custom(&bochs->connector,
bochs_get_edid_block, bochs); bochs_get_edid_block, bochs);
if (bochs->edid == NULL) if (!bochs->drm_edid)
return -1; return -1;
return 0; return 0;
...@@ -303,7 +303,7 @@ static void bochs_hw_fini(struct drm_device *dev) ...@@ -303,7 +303,7 @@ static void bochs_hw_fini(struct drm_device *dev)
if (bochs->fb_map) if (bochs->fb_map)
iounmap(bochs->fb_map); iounmap(bochs->fb_map);
pci_release_regions(to_pci_dev(dev->dev)); pci_release_regions(to_pci_dev(dev->dev));
kfree(bochs->edid); drm_edid_free(bochs->drm_edid);
} }
static void bochs_hw_blank(struct bochs_device *bochs, bool blank) static void bochs_hw_blank(struct bochs_device *bochs, bool blank)
...@@ -471,12 +471,9 @@ static const struct drm_simple_display_pipe_funcs bochs_pipe_funcs = { ...@@ -471,12 +471,9 @@ static const struct drm_simple_display_pipe_funcs bochs_pipe_funcs = {
static int bochs_connector_get_modes(struct drm_connector *connector) static int bochs_connector_get_modes(struct drm_connector *connector)
{ {
struct bochs_device *bochs = int count;
container_of(connector, struct bochs_device, connector);
int count = 0;
if (bochs->edid) count = drm_edid_connector_add_modes(connector);
count = drm_add_edid_modes(connector, bochs->edid);
if (!count) { if (!count) {
count = drm_add_modes_noedid(connector, 8192, 8192); count = drm_add_modes_noedid(connector, 8192, 8192);
...@@ -507,10 +504,10 @@ static void bochs_connector_init(struct drm_device *dev) ...@@ -507,10 +504,10 @@ static void bochs_connector_init(struct drm_device *dev)
drm_connector_helper_add(connector, &bochs_connector_connector_helper_funcs); drm_connector_helper_add(connector, &bochs_connector_connector_helper_funcs);
bochs_hw_load_edid(bochs); bochs_hw_load_edid(bochs);
if (bochs->edid) { if (bochs->drm_edid) {
DRM_INFO("Found EDID data blob.\n"); DRM_INFO("Found EDID data blob.\n");
drm_connector_attach_edid_property(connector); drm_connector_attach_edid_property(connector);
drm_connector_update_edid_property(connector, bochs->edid); drm_edid_connector_update(&bochs->connector, bochs->drm_edid);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment