mirror of
https://github.com/FEX-Emu/linux.git
synced 2024-12-19 15:39:07 +00:00
9c340d80f6
I had added the __CHOOSE_MODE syntax to fix some warnings with newer GCC's in the uml-fix-cond-expr-as-lvalues-warning patch. Here is the update from the version I sent to make it work also when only one mode (TT or SKAS) is enabled. Signed-off-by: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
36 lines
804 B
C
36 lines
804 B
C
/*
|
|
* Copyright (C) 2002 Jeff Dike (jdike@karaya.com)
|
|
* Licensed under the GPL
|
|
*/
|
|
|
|
#ifndef __CHOOSE_MODE_H__
|
|
#define __CHOOSE_MODE_H__
|
|
|
|
#include "uml-config.h"
|
|
|
|
#if defined(UML_CONFIG_MODE_TT) && defined(UML_CONFIG_MODE_SKAS)
|
|
#define CHOOSE_MODE(tt, skas) (mode_tt ? (tt) : (skas))
|
|
|
|
extern int mode_tt;
|
|
static inline void *__choose_mode(void *tt, void *skas) {
|
|
return mode_tt ? tt : skas;
|
|
}
|
|
|
|
#define __CHOOSE_MODE(tt, skas) (*( (typeof(tt) *) __choose_mode(&(tt), &(skas))))
|
|
|
|
#elif defined(UML_CONFIG_MODE_SKAS)
|
|
#define CHOOSE_MODE(tt, skas) (skas)
|
|
|
|
#elif defined(UML_CONFIG_MODE_TT)
|
|
#define CHOOSE_MODE(tt, skas) (tt)
|
|
#endif
|
|
|
|
#define CHOOSE_MODE_PROC(tt, skas, args...) \
|
|
CHOOSE_MODE(tt(args), skas(args))
|
|
|
|
#ifndef __CHOOSE_MODE
|
|
#define __CHOOSE_MODE(tt, skas) CHOOSE_MODE(tt, skas)
|
|
#endif
|
|
|
|
#endif
|