diff options
author | Heiko Carstens <hca@linux.ibm.com> | 2021-07-05 20:16:10 +0200 |
---|---|---|
committer | Vasily Gorbik <gor@linux.ibm.com> | 2021-07-08 22:12:17 +0200 |
commit | 41d71fe59cce41237f24f3b7bdc1b414069a34ed (patch) | |
tree | 9469aec2543453d14747353a53d4b6d74f246378 /samples/connector | |
parent | bb250e64e4702774ddee052b57136ab222f59ce1 (diff) | |
download | lwn-41d71fe59cce41237f24f3b7bdc1b414069a34ed.tar.gz lwn-41d71fe59cce41237f24f3b7bdc1b414069a34ed.zip |
s390: introduce proper type handling call_on_stack() macro
The existing CALL_ON_STACK() macro allows for subtle bugs:
- There is no type checking of the function that is being called. That
is: missing or too many arguments do not cause any compile error or
warning. The same is true if the return type of the called function
changes. This can lead to quite random bugs.
- Sign and zero extension of arguments is missing. Given that the s390
C ABI requires that the caller of a function performs proper sign
and zero extension this can also lead to subtle bugs.
- If arguments to the CALL_ON_STACK() macros contain functions calls
register corruption can happen due to register asm constructs being
used.
Therefore introduce a new call_on_stack() macro which is supposed to
fix all these problems.
Reviewed-by: Sven Schnelle <svens@linux.ibm.com>
Signed-off-by: Heiko Carstens <hca@linux.ibm.com>
Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
Diffstat (limited to 'samples/connector')
0 files changed, 0 insertions, 0 deletions