summaryrefslogtreecommitdiffstats
path: root/drivers/block
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2009-04-07 16:59:41 +0200
committerLinus Torvalds <torvalds@linux-foundation.org>2009-04-07 18:05:35 +0200
commitaeeae86859f4319de0a4946b44771d9926eeed54 (patch)
tree2a9520601922a930259a18b666dc2281e8262def /drivers/block
parentMerge branch 'for-2.6.30' of git://git.kernel.org/pub/scm/linux/kernel/git/br... (diff)
downloadlinux-aeeae86859f4319de0a4946b44771d9926eeed54.tar.xz
linux-aeeae86859f4319de0a4946b44771d9926eeed54.zip
Fix build errors due to CONFIG_BRANCH_TRACER=y
The code that enables branch tracing for all (non-constant) branches plays games with the preprocessor and #define's the C 'if ()' construct to do tracing. That's all fine, but it fails for some unusual but valid C code that is sometimes used in macros, notably by the intel-iommu code: if (i=drhd->iommu, drhd->ignored) .. because now the preprocessor complains about multiple arguments to the 'if' macro. So make the macro expansion of this particularly horrid trick use varargs, and handle the case of comma-expressions in if-statements. Use another macro to do it cleanly in just one place. This replaces a patch by David (and acked by Steven) that did this all inside that one already-too-horrid macro. Tested-by: Ingo Molnar <mingo@elte.hu> Cc: David Woodhouse <dwmw2@infradead.org> Cc: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/block')
0 files changed, 0 insertions, 0 deletions