* Re: linux-next: manual merge of the akpm tree with the openrisc tree [not found] <20110718185608.97377aa900b014aa010830a2@canb.auug.org.au> @ 2011-07-18 11:02 ` Jonas Bonn 2011-07-18 11:02 ` Jonas Bonn 2011-07-18 14:05 ` [PATCH 1/1] asm-generic: delay.h fix udelay and ndelay for 8 bit args Jonas Bonn 0 siblings, 2 replies; 3+ messages in thread From: Jonas Bonn @ 2011-07-18 11:02 UTC (permalink / raw) To: Stephen Rothwell Cc: Andrew Morton, linux-next, linux-kernel, linux-arch@vger.kernel.org On Mon, 2011-07-18 at 18:56 +1000, Stephen Rothwell wrote: > Hi Andrew, > > Today's linux-next merge of the scsi-post-merge tree got a conflict in > arch/x86/include/asm/delay.h between commit 10f53642f115 ("asm-generic: > move archictures to common delay.h") from the openrisc tree and commit > "With a non-constant 8-bit argument, a call to udelay() generates a > warning:" from the akpm tree. > > I just dropped this patch from the akpm tree as the former commit > consolidated this code into asm-generic/delay.h (which doesn't solve the > problem). Applying the change from Andrew's patch to asm-generic/delay.h looks like the sane thing to do. I can do that in my tree and then Andrew can drop the patch from his tree... does that sound reasonable? Just so others don't have to go digging for it, the patch in question is: http://userweb.kernel.org/~akpm/mmotm/broken-out/arch-x86-include-asm-delayh-fix-udelay-and-ndelay-for-8-bit-args.patch /Jonas ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: linux-next: manual merge of the akpm tree with the openrisc tree 2011-07-18 11:02 ` linux-next: manual merge of the akpm tree with the openrisc tree Jonas Bonn @ 2011-07-18 11:02 ` Jonas Bonn 2011-07-18 14:05 ` [PATCH 1/1] asm-generic: delay.h fix udelay and ndelay for 8 bit args Jonas Bonn 1 sibling, 0 replies; 3+ messages in thread From: Jonas Bonn @ 2011-07-18 11:02 UTC (permalink / raw) To: Stephen Rothwell Cc: Andrew Morton, linux-next, linux-kernel, linux-arch@vger.kernel.org On Mon, 2011-07-18 at 18:56 +1000, Stephen Rothwell wrote: > Hi Andrew, > > Today's linux-next merge of the scsi-post-merge tree got a conflict in > arch/x86/include/asm/delay.h between commit 10f53642f115 ("asm-generic: > move archictures to common delay.h") from the openrisc tree and commit > "With a non-constant 8-bit argument, a call to udelay() generates a > warning:" from the akpm tree. > > I just dropped this patch from the akpm tree as the former commit > consolidated this code into asm-generic/delay.h (which doesn't solve the > problem). Applying the change from Andrew's patch to asm-generic/delay.h looks like the sane thing to do. I can do that in my tree and then Andrew can drop the patch from his tree... does that sound reasonable? Just so others don't have to go digging for it, the patch in question is: http://userweb.kernel.org/~akpm/mmotm/broken-out/arch-x86-include-asm-delayh-fix-udelay-and-ndelay-for-8-bit-args.patch /Jonas ^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH 1/1] asm-generic: delay.h fix udelay and ndelay for 8 bit args 2011-07-18 11:02 ` linux-next: manual merge of the akpm tree with the openrisc tree Jonas Bonn 2011-07-18 11:02 ` Jonas Bonn @ 2011-07-18 14:05 ` Jonas Bonn 1 sibling, 0 replies; 3+ messages in thread From: Jonas Bonn @ 2011-07-18 14:05 UTC (permalink / raw) To: sfr Cc: linux-next, linux-kernel, Andrew Morton, Ingo Molnar, Thomas Gleixner, H. Peter Anvin, linux-arch, Jonas Bonn From: Andrew Morton <akpm@linux-foundation.org> With a non-constant 8-bit argument, a call to udelay() generates a warning: drivers/gpu/drm/radeon/atom.c: In function 'atom_op_delay': drivers/gpu/drm/radeon/atom.c:654: warning: comparison is always false due to limited range of data type The code looks like it works OK with an 8-bit arg, and the calling code is doing nothing wrong, so udelay() needs fixing. Fixing it was rather tricky. Simply typecasting `n' in the comparison with 20000 didn't change anything. Hence the divide-by-20000 trick. Using a do{}while loop didn't work because udelay() is used in ?: statements, hence the ({...}) construct. While I was there I replaced the brain-bending ?:?:?: mess with nice if/else code. Probably other architectures are generating the same warning and can use a similar change. Cc: Ingo Molnar <mingo@elte.hu> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: <linux-arch@vger.kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Jonas Bonn <jonas@southpole.se> --- Here's a patch that should resolve the merge conflict. This applies Andrew's changes on top of the new asm-generic/delay.h instead of the x86 arch-specific one. I've tested this for OpenRISC and the changed macros don't cause any problems there. Let me know if this is OK and I'll throw it into the OpenRISC tree together with the other delay.h modifications. Thanks, Jonas include/asm-generic/delay.h | 33 +++++++++++++++++++++++++++------ 1 files changed, 27 insertions(+), 6 deletions(-) diff --git a/include/asm-generic/delay.h b/include/asm-generic/delay.h index 6511b99..0f79054 100644 --- a/include/asm-generic/delay.h +++ b/include/asm-generic/delay.h @@ -10,14 +10,35 @@ extern void __ndelay(unsigned long nsecs); extern void __const_udelay(unsigned long xloops); extern void __delay(unsigned long loops); +/* + * The weird n/20000 thing suppresses a "comparison is always false due to + * limited range of data type" warning with non-const 8-bit arguments. + */ + /* 0x10c7 is 2**32 / 1000000 (rounded up) */ -#define udelay(n) (__builtin_constant_p(n) ? \ - ((n) > 20000 ? __bad_udelay() : __const_udelay((n) * 0x10c7ul)) : \ - __udelay(n)) +#define udelay(n) \ + ({ \ + if (__builtin_constant_p(n)) { \ + if ((n) / 20000 >= 1) \ + __bad_udelay(); \ + else \ + __const_udelay((n) * 0x10c7ul); \ + } else { \ + __udelay(n); \ + } \ + }) /* 0x5 is 2**32 / 1000000000 (rounded up) */ -#define ndelay(n) (__builtin_constant_p(n) ? \ - ((n) > 20000 ? __bad_ndelay() : __const_udelay((n) * 5ul)) : \ - __ndelay(n)) +#define ndelay(n) \ + ({ \ + if (__builtin_constant_p(n)) { \ + if ((n) / 20000 >= 1) \ + __bad_ndelay(); \ + else \ + __const_udelay((n) * 5ul); \ + } else { \ + __ndelay(n); \ + } \ + }) #endif /* __ASM_GENERIC_DELAY_H */ -- 1.7.4.1 ^ permalink raw reply related [flat|nested] 3+ messages in thread
end of thread, other threads:[~2011-07-18 14:06 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20110718185608.97377aa900b014aa010830a2@canb.auug.org.au>
2011-07-18 11:02 ` linux-next: manual merge of the akpm tree with the openrisc tree Jonas Bonn
2011-07-18 11:02 ` Jonas Bonn
2011-07-18 14:05 ` [PATCH 1/1] asm-generic: delay.h fix udelay and ndelay for 8 bit args Jonas Bonn
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).