lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <533CD04F.8060003@cn.fujitsu.com>
Date:	Thu, 3 Apr 2014 11:06:55 +0800
From:	Zhang Yanfei <zhangyanfei@...fujitsu.com>
To:	Li Zhong <zhong@...ux.vnet.ibm.com>
CC:	LKML <linux-kernel@...r.kernel.org>, <nfont@...ux.vnet.ibm.com>,
	<gregkh@...uxfoundation.org>,
	Andrew Morton <akpm@...ux-foundation.org>,
	KAMEZAWA Hiroyuki <kamezawa.hiroyu@...fujitsu.com>,
	KOSAKI Motohiro <kosaki.motohiro@...fujitsu.com>,
	Dave Hansen <dave.hansen@...el.com>
Subject: Re: [RFC PATCH] memory driver: make phys_index/end_phys_index reflect
 the start/end section number

On 04/03/2014 10:37 AM, Li Zhong wrote:
> On Thu, 2014-04-03 at 09:37 +0800, Zhang Yanfei wrote:
>> Add ccing
>>
>> On 04/02/2014 04:56 PM, Li Zhong wrote:
>>> I noticed the phys_index and end_phys_index under 
>>> /sys/devices/system/memory/memoryXXX/ have the same value, e.g.
>>> (for the test machine, one memory block has 8 sections, that is 
>>>  sections_per_block equals 8)
>>>
>>> # cd /sys/devices/system/memory/memory100/
>>> # cat phys_index end_phys_index 
>>> 00000064
>>> 00000064
>>>
>>> Seems they should reflect the start/end section number respectively, which 
>>> also matches what is said in Documentation/memory-hotplug.txt
>>
> Hi Yanfei, 
> 
> Thanks for the review. 
> 
>> Indeed. I've noticed this before. The value in 'end_phys_index' doesn't
>> match what it really means. But, the name itself is vague, it looks like
>> it is the index of some page frame. (we keep this name for compatibility?)
> 
> I guess so, Dave just reminded me that the RFC would also break
> userspace..
> 
> And now my plan is: 
>  leave the code unchanged
>  update the document, state the end_phys_index/phys_index are the same,
> and means the memory block index

Ah. I doubt whether there is userspace tool which is using the two sysfiles?
for example, the memory100 directory itself can tell us which block it is.
So why there is the two files under it give the same meaning.

If there is userspace tool using the two files, does it use 'end_phys_index'
in the correct way? That said, if a userspace tool knows what the 'end_phys_index'
really mean, does it still need it since we have 'phys_index' with the same value?

>  [optional] create two new files start_sec_nr, end_sec_nr if needed

These two are the really meaningful sysfiles for userspace, IMO.

> 
> Do you have any other suggestions? 

No. I think we should wait for other guys to comment more.

Thanks.

> 
> Thanks, Zhong
> 
>>
>> The corresponding member in struct memory_block is:
>>
>> struct memory_block {
>>         unsigned long start_section_nr;
>>         unsigned long end_section_nr;
>> ...
>>
>> The two members seem to have the right name, and have the right value in kernel.
>>
>>
>>>
>>> This patch tries to modify that so the two files could show the start/end
>>> section number of the memory block.
>>>
>>> After this change, output of the above example looks like:
>>>
>>> # cat phys_index end_phys_index 
>>> 00000320
>>> 00000327
>>>
>>> Signed-off-by: Li Zhong <zhong@...ux.vnet.ibm.com>
>>> ---
>>>  drivers/base/memory.c | 4 ++--
>>>  1 file changed, 2 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/drivers/base/memory.c b/drivers/base/memory.c
>>> index bece691..b10f2fa 100644
>>> --- a/drivers/base/memory.c
>>> +++ b/drivers/base/memory.c
>>> @@ -114,7 +114,7 @@ static ssize_t show_mem_start_phys_index(struct device *dev,
>>>  	struct memory_block *mem = to_memory_block(dev);
>>>  	unsigned long phys_index;
>>>  
>>> -	phys_index = mem->start_section_nr / sections_per_block;
>>> +	phys_index = mem->start_section_nr;
>>>  	return sprintf(buf, "%08lx\n", phys_index);
>>>  }
>>>  
>>> @@ -124,7 +124,7 @@ static ssize_t show_mem_end_phys_index(struct device *dev,
>>>  	struct memory_block *mem = to_memory_block(dev);
>>>  	unsigned long phys_index;
>>>  
>>> -	phys_index = mem->end_section_nr / sections_per_block;
>>> +	phys_index = mem->end_section_nr;
>>>  	return sprintf(buf, "%08lx\n", phys_index);
>>>  }
>>>  
>>>
>>>
>>> --
>>> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
>>> the body of a message to majordomo@...r.kernel.org
>>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>> Please read the FAQ at  http://www.tux.org/lkml/
>>>
>>
>>
> 
> 
> .
> 


-- 
Thanks.
Zhang Yanfei
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ