[PATCH] identify_ppc_sys_by_name_and_id function implementation final
Vitaly Bordug
vbordug at ru.mvista.com
Sat Aug 13 01:37:24 EST 2005
Marcelo Tosatti wrote:
> On Thu, Aug 11, 2005 at 07:25:20PM +0400, Vitaly Bordug wrote:
>
>>Marcelo Tosatti wrote:
>>
>>>On Wed, Aug 10, 2005 at 02:16:57PM -0500, Kumar Gala wrote:
>>>
>>>
>>>>+static int __init find_chip_by_name_and_id(char *name, u32 id)
>>>>+{
>>>>+ int ret = -1;
>>>>+ unsigned int i = 0;
>>>>+ unsigned int j = 0;
>>>>+ unsigned int dups = 0;
>>>>+
>>>>+ unsigned int matched[count_sys_specs()];
>>>>
>>>>Is is legit in the kernel to use dynamically sized array?
>>>
>>>
>>>kmalloc() is certainly safer - why not use it?
>>
>>Practically , version with kmalloc works, but setup_arch and thus this
>>function is called before mem_init, so I just wonder if kmalloc can
>>handle this case. On the other hand, I don't like to deal with
>>alloc_bootmem() if mem_init_done!=1 and kmalloc otherwise (like ocp
>>does) just for the temporary buffer.
>>
>>But it's the only _right_ way (or I 've missed something) - sure I'll
>>follow it.
>
>
> I dont see any problem with dynamic array usage on the kernel (maybe someone
> else has good argumentation against it).
>
> Just that you have a 4kb stack. Does count_sys_specs() have an appropriate
> maximum?
>
>
Yes it does, but there is no define for it. The ppc_sys_specs array
should always end at the "default match" - element with name field set
to "" and value=0 (without it every existing ppc_sys identify will fall
into infinite loop). This array is defined in syslib/<board>_sys.c end
is finite of course. Its size depends on amount of supported boards.
So, if the dynamic array is ok with conditions, it will be great.
But now I'm inclined to implement the same using kmalloc/alloc_bootmem
to prevent flame when it will proceed. BTW, will free_bootmem properly
release the memory allocated by alloc_bootmem()? I haven't encountered
examples of this so far...
--
Sincerely,
Vitaly
More information about the Linuxppc-embedded
mailing list