summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMa Ling <ling.ma@intel.com>2009-04-16 11:51:25 +0200
committerDave Airlie <airlied@redhat.com>2009-04-20 02:03:46 +0200
commit77d26dc9b9805f322f5a1f6e559b18ad66205bd9 (patch)
treee09b35638a3d0fb9bd319498ec406ffd95a199eb
parentdrm: count reaches -1 (diff)
downloadlinux-77d26dc9b9805f322f5a1f6e559b18ad66205bd9.tar.xz
linux-77d26dc9b9805f322f5a1f6e559b18ad66205bd9.zip
drm: clean dirty memory after device release
In current code we register/unregister connector object by drm_sysfs_connector_add/remove function. However under some cases, we need to dynamically register or unregister device multiple times, so we have to go through register -> unregister ->register routine. Because after device_unregister function our memory is dirty, we need to do clean operation in order to re-register the device, otherwise the system will crash. The patch intends to clean device after device release. Signed-off-by: Ma Ling <ling.ma@intel.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r--drivers/gpu/drm/drm_sysfs.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/gpu/drm/drm_sysfs.c b/drivers/gpu/drm/drm_sysfs.c
index bc0c6849360c..022876ae34f0 100644
--- a/drivers/gpu/drm/drm_sysfs.c
+++ b/drivers/gpu/drm/drm_sysfs.c
@@ -132,6 +132,7 @@ void drm_sysfs_destroy(void)
*/
static void drm_sysfs_device_release(struct device *dev)
{
+ memset(dev, 0, sizeof(struct device));
return;
}