提交 759e4f83 编写于 作者: T Thomas Hellstrom 提交者: Dave Airlie

drm/ttm: Fixes for "Memory accounting rework."

ttm:
Fix error paths when kobject_add returns an error.
Signed-off-by: NThomas Hellstrom <thellstrom@vmware.com>
Signed-off-by: NDave Airlie <airlied@redhat.com>
上级 7f5f4db2
...@@ -244,6 +244,7 @@ static int ttm_mem_init_kernel_zone(struct ttm_mem_global *glob, ...@@ -244,6 +244,7 @@ static int ttm_mem_init_kernel_zone(struct ttm_mem_global *glob,
{ {
struct ttm_mem_zone *zone = kzalloc(sizeof(*zone), GFP_KERNEL); struct ttm_mem_zone *zone = kzalloc(sizeof(*zone), GFP_KERNEL);
uint64_t mem; uint64_t mem;
int ret;
if (unlikely(!zone)) if (unlikely(!zone))
return -ENOMEM; return -ENOMEM;
...@@ -259,9 +260,14 @@ static int ttm_mem_init_kernel_zone(struct ttm_mem_global *glob, ...@@ -259,9 +260,14 @@ static int ttm_mem_init_kernel_zone(struct ttm_mem_global *glob,
zone->used_mem = 0; zone->used_mem = 0;
zone->glob = glob; zone->glob = glob;
glob->zone_kernel = zone; glob->zone_kernel = zone;
glob->zones[glob->num_zones++] = zone;
kobject_init(&zone->kobj, &ttm_mem_zone_kobj_type); kobject_init(&zone->kobj, &ttm_mem_zone_kobj_type);
return kobject_add(&zone->kobj, &glob->kobj, zone->name); ret = kobject_add(&zone->kobj, &glob->kobj, zone->name);
if (unlikely(ret != 0)) {
kobject_put(&zone->kobj);
return ret;
}
glob->zones[glob->num_zones++] = zone;
return 0;
} }
#ifdef CONFIG_HIGHMEM #ifdef CONFIG_HIGHMEM
...@@ -270,6 +276,7 @@ static int ttm_mem_init_highmem_zone(struct ttm_mem_global *glob, ...@@ -270,6 +276,7 @@ static int ttm_mem_init_highmem_zone(struct ttm_mem_global *glob,
{ {
struct ttm_mem_zone *zone = kzalloc(sizeof(*zone), GFP_KERNEL); struct ttm_mem_zone *zone = kzalloc(sizeof(*zone), GFP_KERNEL);
uint64_t mem; uint64_t mem;
int ret;
if (unlikely(!zone)) if (unlikely(!zone))
return -ENOMEM; return -ENOMEM;
...@@ -288,9 +295,14 @@ static int ttm_mem_init_highmem_zone(struct ttm_mem_global *glob, ...@@ -288,9 +295,14 @@ static int ttm_mem_init_highmem_zone(struct ttm_mem_global *glob,
zone->used_mem = 0; zone->used_mem = 0;
zone->glob = glob; zone->glob = glob;
glob->zone_highmem = zone; glob->zone_highmem = zone;
glob->zones[glob->num_zones++] = zone;
kobject_init(&zone->kobj, &ttm_mem_zone_kobj_type); kobject_init(&zone->kobj, &ttm_mem_zone_kobj_type);
return kobject_add(&zone->kobj, &glob->kobj, zone->name); ret = kobject_add(&zone->kobj, &glob->kobj, zone->name);
if (unlikely(ret != 0)) {
kobject_put(&zone->kobj);
return ret;
}
glob->zones[glob->num_zones++] = zone;
return 0;
} }
#else #else
static int ttm_mem_init_dma32_zone(struct ttm_mem_global *glob, static int ttm_mem_init_dma32_zone(struct ttm_mem_global *glob,
...@@ -298,6 +310,7 @@ static int ttm_mem_init_dma32_zone(struct ttm_mem_global *glob, ...@@ -298,6 +310,7 @@ static int ttm_mem_init_dma32_zone(struct ttm_mem_global *glob,
{ {
struct ttm_mem_zone *zone = kzalloc(sizeof(*zone), GFP_KERNEL); struct ttm_mem_zone *zone = kzalloc(sizeof(*zone), GFP_KERNEL);
uint64_t mem; uint64_t mem;
int ret;
if (unlikely(!zone)) if (unlikely(!zone))
return -ENOMEM; return -ENOMEM;
...@@ -327,9 +340,14 @@ static int ttm_mem_init_dma32_zone(struct ttm_mem_global *glob, ...@@ -327,9 +340,14 @@ static int ttm_mem_init_dma32_zone(struct ttm_mem_global *glob,
zone->used_mem = 0; zone->used_mem = 0;
zone->glob = glob; zone->glob = glob;
glob->zone_dma32 = zone; glob->zone_dma32 = zone;
glob->zones[glob->num_zones++] = zone;
kobject_init(&zone->kobj, &ttm_mem_zone_kobj_type); kobject_init(&zone->kobj, &ttm_mem_zone_kobj_type);
return kobject_add(&zone->kobj, &glob->kobj, zone->name); ret = kobject_add(&zone->kobj, &glob->kobj, zone->name);
if (unlikely(ret != 0)) {
kobject_put(&zone->kobj);
return ret;
}
glob->zones[glob->num_zones++] = zone;
return 0;
} }
#endif #endif
...@@ -348,8 +366,10 @@ int ttm_mem_global_init(struct ttm_mem_global *glob) ...@@ -348,8 +366,10 @@ int ttm_mem_global_init(struct ttm_mem_global *glob)
ret = kobject_add(&glob->kobj, ret = kobject_add(&glob->kobj,
ttm_get_kobj(), ttm_get_kobj(),
"memory_accounting"); "memory_accounting");
if (unlikely(ret != 0)) if (unlikely(ret != 0)) {
goto out_no_zone; kobject_put(&glob->kobj);
return ret;
}
si_meminfo(&si); si_meminfo(&si);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册