Re: [PATCH 13/30] net: Don't do pointless kmalloc return value casts in zd1211 driver
From: Jesper Juhl <hidden>
Date: 2007-08-30 20:20:39
Also in:
linux-wireless, lkml
From: Jesper Juhl <hidden>
Date: 2007-08-30 20:20:39
Also in:
linux-wireless, lkml
On 30/08/2007, Daniel Drake [off-list ref] wrote:
Jesper Juhl wrote:quoted
Since kmalloc() returns a void pointer there is no reason to cast its return value. This patch also removes a pointless initialization of a variable.NAK: adds a sparse warning zd_chip.c:116:15: warning: implicit cast to nocast type
Ok, I must admit I didn't check with sparse since it seemed pointless - we usually never cast void pointers to other pointer types, specifically because the C language nicely guarantees that the right thing will happen without the cast. Sometimes we have to cast them to integer types, su sure we need the cast there. But what on earth makes a "zd_addr_t *" so special that we have to explicitly cast a "void *" to that type? I see it's defined as typedef u32 __nocast zd_addr_t; in drivers/net/wireless/zd1211rw/zd_types.h , but why the __nocast ? What would be wrong in applying my patch that removes the cast of the kmalloc() return value and then also remove the "__nocast" here? -- Jesper Juhl [off-list ref] Don't top-post http://www.catb.org/~esr/jargon/html/T/top-post.html Plain text mails only, please http://www.expita.com/nomime.html