Re: [PATCH 16/21] sysfs: implement bin_buffer

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



(We went off-list just now. Adding lkml again.)

On 5/1/07, Tejun Heo <[email protected]> wrote:
Satyam Sharma wrote:
> On 4/28/07, Tejun Heo <[email protected]> wrote:
>> Implement bin_buffer which contains a mutex and pointer to PAGE_SIZE
>> buffer to properly synchronize accesses to per-openfile buffer and
>> prepare for immediate-kobj-disconnect.
>>
>> Signed-off-by: Tejun Heo <[email protected]>
>> ---
>> [...]
>> @@ -135,14 +160,22 @@ static int open(struct inode * inode, struct
>> file * file)
>>                 goto Error;
>>
>>         error = -ENOMEM;
>> -       file->private_data = kmalloc(PAGE_SIZE, GFP_KERNEL);
>> -       if (!file->private_data)
>> +       bb = kzalloc(sizeof(*bb), GFP_KERNEL);
>> +       if (!bb)
>>                 goto Error;
>>
>> +       bb->buffer = kmalloc(PAGE_SIZE, GFP_KERNEL);
>
> You could simply do a __get_free_page() here instead of a
> kmalloc(PAGE_SIZE).

Yes, I could but 1. the original code was done using kmalloc

Yes, I saw that, but you could change it just as well. In any case,
this will only make fs/sysfs/bin.c similar to what is being done in
fs/sysfs/file.c. We allocate the buffer page backing the attribute's
data in fill_read_buffer() and fill_write_buffer() using
get_zeroed_page() and not kzalloc().

2. I'm not sure __get_free_page() is better than kmalloc(PAGE_SIZE, ), is it?

If you know for sure that you require *exactly* PAGE_SIZE bytes, then
yes, it is.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux