diff options
author | Neal Liu <[email protected]> | 2020-07-27 11:25:46 +0800 |
---|---|---|
committer | Rafael J. Wysocki <[email protected]> | 2020-07-29 18:38:30 +0200 |
commit | efe9711214e6138a5a2a46ca4068bfce50c03444 (patch) | |
tree | 73343cbdd485268e6e4186b2c947a865895d0b00 /scripts/gdb/linux/symbols.py | |
parent | 81f94ddfeceddb3b8ffa6cfe5ddd3b896711d9ad (diff) |
cpuidle: change enter_s2idle() prototype
Control Flow Integrity(CFI) is a security mechanism that disallows
changes to the original control flow graph of a compiled binary,
making it significantly harder to perform such attacks.
init_state_node() assign same function callback to different
function pointer declarations.
static int init_state_node(struct cpuidle_state *idle_state,
const struct of_device_id *matches,
struct device_node *state_node) { ...
idle_state->enter = match_id->data; ...
idle_state->enter_s2idle = match_id->data; }
Function declarations:
struct cpuidle_state { ...
int (*enter) (struct cpuidle_device *dev,
struct cpuidle_driver *drv,
int index);
void (*enter_s2idle) (struct cpuidle_device *dev,
struct cpuidle_driver *drv,
int index); };
In this case, either enter() or enter_s2idle() would cause CFI check
failed since they use same callee.
Align function prototype of enter() since it needs return value for
some use cases. The return value of enter_s2idle() is no
need currently.
Signed-off-by: Neal Liu <[email protected]>
Reviewed-by: Sami Tolvanen <[email protected]>
Signed-off-by: Rafael J. Wysocki <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/symbols.py')
0 files changed, 0 insertions, 0 deletions