On Sun, Nov 16, 2014 at 06:13:28PM +0800, Christopher Li wrote: > On Wed, Nov 12, 2014 at 11:34 PM, Ard Biesheuvel > <ard.biesheuvel@xxxxxxxxxx> wrote: > > > > Well, I spent some time playing around with this: > > > > This one is accepted: > > > > static __attribute__((__pure__)) int pure1(void) > > { > > int i = 0; > > return i; > > } > > > > This one is not accepted: > > > > static __attribute__((__pure__)) void *pure2(void) > > { > > void *i = (void *)0; > > return i; > > } > > > > Thanks for the test case. I have commit your test case with a bit more > test case regarding function pointer assign. > > The change is in chrisl repository reveiw-pure-attr branch: > https://git.kernel.org/cgit/devel/sparse/chrisl/sparse.git/log/?h=review-pure-attr > > I purpose this fix for it. It can pass your test case. > This patch limit the pure attribute to functions. Wait, is the above being parsed as applying the pure attribute to the return value rather than to the function? Or is that not the issue here? - Josh Triplett -- To unsubscribe from this list: send the line "unsubscribe linux-efi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html