locking/static_keys: Avoid nested functions
clang does not support nested functions inside of an array definition: lib/test_static_keys.c:105:16: error: function definition is not allowed here .test_key = test_key_func(&old_true_key, static_key_true), lib/test_static_keys.c:50:20: note: expanded from macro 'test_key_func' ({bool func(void) { return branch(key); } func; }) That code appears to be a little too clever, so this simplifies it a bit by defining functions outside of the array. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Acked-by: Jason Baron <jbaron@akamai.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: linux-arm-kernel@lists.infradead.org Link: http://lkml.kernel.org/r/1454942223-2781480-1-git-send-email-arnd@arndb.de Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
2a96fd7417
commit
975db45e9c
1 changed files with 42 additions and 20 deletions
|
@ -46,8 +46,11 @@ struct test_key {
|
|||
bool (*test_key)(void);
|
||||
};
|
||||
|
||||
#define test_key_func(key, branch) \
|
||||
({bool func(void) { return branch(key); } func; })
|
||||
#define test_key_func(key, branch) \
|
||||
static bool key ## _ ## branch(void) \
|
||||
{ \
|
||||
return branch(&key); \
|
||||
}
|
||||
|
||||
static void invert_key(struct static_key *key)
|
||||
{
|
||||
|
@ -92,6 +95,25 @@ static int verify_keys(struct test_key *keys, int size, bool invert)
|
|||
return 0;
|
||||
}
|
||||
|
||||
test_key_func(old_true_key, static_key_true)
|
||||
test_key_func(old_false_key, static_key_false)
|
||||
test_key_func(true_key, static_branch_likely)
|
||||
test_key_func(true_key, static_branch_unlikely)
|
||||
test_key_func(false_key, static_branch_likely)
|
||||
test_key_func(false_key, static_branch_unlikely)
|
||||
test_key_func(base_old_true_key, static_key_true)
|
||||
test_key_func(base_inv_old_true_key, static_key_true)
|
||||
test_key_func(base_old_false_key, static_key_false)
|
||||
test_key_func(base_inv_old_false_key, static_key_false)
|
||||
test_key_func(base_true_key, static_branch_likely)
|
||||
test_key_func(base_true_key, static_branch_unlikely)
|
||||
test_key_func(base_inv_true_key, static_branch_likely)
|
||||
test_key_func(base_inv_true_key, static_branch_unlikely)
|
||||
test_key_func(base_false_key, static_branch_likely)
|
||||
test_key_func(base_false_key, static_branch_unlikely)
|
||||
test_key_func(base_inv_false_key, static_branch_likely)
|
||||
test_key_func(base_inv_false_key, static_branch_unlikely)
|
||||
|
||||
static int __init test_static_key_init(void)
|
||||
{
|
||||
int ret;
|
||||
|
@ -102,95 +124,95 @@ static int __init test_static_key_init(void)
|
|||
{
|
||||
.init_state = true,
|
||||
.key = &old_true_key,
|
||||
.test_key = test_key_func(&old_true_key, static_key_true),
|
||||
.test_key = &old_true_key_static_key_true,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &old_false_key,
|
||||
.test_key = test_key_func(&old_false_key, static_key_false),
|
||||
.test_key = &old_false_key_static_key_false,
|
||||
},
|
||||
/* internal keys - new keys */
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &true_key.key,
|
||||
.test_key = test_key_func(&true_key, static_branch_likely),
|
||||
.test_key = &true_key_static_branch_likely,
|
||||
},
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &true_key.key,
|
||||
.test_key = test_key_func(&true_key, static_branch_unlikely),
|
||||
.test_key = &true_key_static_branch_unlikely,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &false_key.key,
|
||||
.test_key = test_key_func(&false_key, static_branch_likely),
|
||||
.test_key = &false_key_static_branch_likely,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &false_key.key,
|
||||
.test_key = test_key_func(&false_key, static_branch_unlikely),
|
||||
.test_key = &false_key_static_branch_unlikely,
|
||||
},
|
||||
/* external keys - old keys */
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &base_old_true_key,
|
||||
.test_key = test_key_func(&base_old_true_key, static_key_true),
|
||||
.test_key = &base_old_true_key_static_key_true,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &base_inv_old_true_key,
|
||||
.test_key = test_key_func(&base_inv_old_true_key, static_key_true),
|
||||
.test_key = &base_inv_old_true_key_static_key_true,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &base_old_false_key,
|
||||
.test_key = test_key_func(&base_old_false_key, static_key_false),
|
||||
.test_key = &base_old_false_key_static_key_false,
|
||||
},
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &base_inv_old_false_key,
|
||||
.test_key = test_key_func(&base_inv_old_false_key, static_key_false),
|
||||
.test_key = &base_inv_old_false_key_static_key_false,
|
||||
},
|
||||
/* external keys - new keys */
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &base_true_key.key,
|
||||
.test_key = test_key_func(&base_true_key, static_branch_likely),
|
||||
.test_key = &base_true_key_static_branch_likely,
|
||||
},
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &base_true_key.key,
|
||||
.test_key = test_key_func(&base_true_key, static_branch_unlikely),
|
||||
.test_key = &base_true_key_static_branch_unlikely,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &base_inv_true_key.key,
|
||||
.test_key = test_key_func(&base_inv_true_key, static_branch_likely),
|
||||
.test_key = &base_inv_true_key_static_branch_likely,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &base_inv_true_key.key,
|
||||
.test_key = test_key_func(&base_inv_true_key, static_branch_unlikely),
|
||||
.test_key = &base_inv_true_key_static_branch_unlikely,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &base_false_key.key,
|
||||
.test_key = test_key_func(&base_false_key, static_branch_likely),
|
||||
.test_key = &base_false_key_static_branch_likely,
|
||||
},
|
||||
{
|
||||
.init_state = false,
|
||||
.key = &base_false_key.key,
|
||||
.test_key = test_key_func(&base_false_key, static_branch_unlikely),
|
||||
.test_key = &base_false_key_static_branch_unlikely,
|
||||
},
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &base_inv_false_key.key,
|
||||
.test_key = test_key_func(&base_inv_false_key, static_branch_likely),
|
||||
.test_key = &base_inv_false_key_static_branch_likely,
|
||||
},
|
||||
{
|
||||
.init_state = true,
|
||||
.key = &base_inv_false_key.key,
|
||||
.test_key = test_key_func(&base_inv_false_key, static_branch_unlikely),
|
||||
.test_key = &base_inv_false_key_static_branch_unlikely,
|
||||
},
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue