diff options
| author | David S. Miller <davem@davemloft.net> | 2010-03-22 20:05:26 -0700 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2010-03-22 20:05:26 -0700 | 
| commit | 91c030b4d6445ebe9fbddb86d584441f300df15c (patch) | |
| tree | e8a48e3ad9e0448c690268175e555fa651983546 /drivers/base/memory.c | |
| parent | 7c3456fdb503071787f7f972de1069b9cacd16f0 (diff) | |
| parent | ae6be51ed01d6c4aaf249a207b4434bc7785853b (diff) | |
Merge branch 'master' of /home/davem/src/GIT/linux-2.6/
Diffstat (limited to 'drivers/base/memory.c')
| -rw-r--r-- | drivers/base/memory.c | 15 | 
1 files changed, 10 insertions, 5 deletions
| diff --git a/drivers/base/memory.c b/drivers/base/memory.c index 2f8691511190..db0848e54cc6 100644 --- a/drivers/base/memory.c +++ b/drivers/base/memory.c @@ -429,12 +429,16 @@ static inline int memory_fail_init(void)   * differentiation between which *physical* devices each   * section belongs to...   */ +int __weak arch_get_memory_phys_device(unsigned long start_pfn) +{ +	return 0; +}  static int add_memory_block(int nid, struct mem_section *section, -			unsigned long state, int phys_device, -			enum mem_add_context context) +			unsigned long state, enum mem_add_context context)  {  	struct memory_block *mem = kzalloc(sizeof(*mem), GFP_KERNEL); +	unsigned long start_pfn;  	int ret = 0;  	if (!mem) @@ -443,7 +447,8 @@ static int add_memory_block(int nid, struct mem_section *section,  	mem->phys_index = __section_nr(section);  	mem->state = state;  	mutex_init(&mem->state_mutex); -	mem->phys_device = phys_device; +	start_pfn = section_nr_to_pfn(mem->phys_index); +	mem->phys_device = arch_get_memory_phys_device(start_pfn);  	ret = register_memory(mem, section);  	if (!ret) @@ -515,7 +520,7 @@ int remove_memory_block(unsigned long node_id, struct mem_section *section,   */  int register_new_memory(int nid, struct mem_section *section)  { -	return add_memory_block(nid, section, MEM_OFFLINE, 0, HOTPLUG); +	return add_memory_block(nid, section, MEM_OFFLINE, HOTPLUG);  }  int unregister_memory_section(struct mem_section *section) @@ -548,7 +553,7 @@ int __init memory_dev_init(void)  		if (!present_section_nr(i))  			continue;  		err = add_memory_block(0, __nr_to_section(i), MEM_ONLINE, -					0, BOOT); +				       BOOT);  		if (!ret)  			ret = err;  	} | 
