mirror of
https://github.com/torvalds/linux.git
synced 2026-03-08 01:04:41 +01:00
coccinelle: Add kmalloc_objs conversion script
Finds and converts sized kmalloc-family of allocations into the typed kmalloc_obj-family of allocations. Link: https://patch.msgid.link/20251203233036.3212363-5-kees@kernel.org Signed-off-by: Kees Cook <kees@kernel.org>
This commit is contained in:
parent
e4c8b46b92
commit
bdc5071d7f
1 changed files with 124 additions and 0 deletions
124
scripts/coccinelle/api/kmalloc_objs.cocci
Normal file
124
scripts/coccinelle/api/kmalloc_objs.cocci
Normal file
|
|
@ -0,0 +1,124 @@
|
|||
// SPDX-License-Identifier: GPL-2.0-only
|
||||
/// Use kmalloc_obj family of macros for allocations
|
||||
///
|
||||
// Confidence: High
|
||||
// Options: --include-headers-for-types --all-includes --include-headers --keep-comments
|
||||
|
||||
virtual patch
|
||||
|
||||
@initialize:python@
|
||||
@@
|
||||
import sys
|
||||
|
||||
def alloc_array(name):
|
||||
func = "FAILED_RENAME"
|
||||
if name == "kmalloc_array":
|
||||
func = "kmalloc_objs"
|
||||
elif name == "kvmalloc_array":
|
||||
func = "kvmalloc_objs"
|
||||
elif name == "kcalloc":
|
||||
func = "kzalloc_objs"
|
||||
elif name == "kvcalloc":
|
||||
func = "kvzalloc_objs"
|
||||
else:
|
||||
print(f"Unknown transform for {name}", file=sys.stderr)
|
||||
return func
|
||||
|
||||
// This excludes anything that is assigning to or from integral types or
|
||||
// string literals. Everything else gets the sizeof() extracted for the
|
||||
// kmalloc_obj() type/var argument. sizeof(void *) is also excluded because
|
||||
// it will need case-by-case double-checking to make sure the right type is
|
||||
// being assigned.
|
||||
@direct depends on patch && !(file in "tools") && !(file in "samples")@
|
||||
typedef u8, u16, u32, u64;
|
||||
typedef __u8, __u16, __u32, __u64;
|
||||
typedef uint8_t, uint16_t, uint32_t, uint64_t;
|
||||
typedef uchar, ushort, uint, ulong;
|
||||
typedef __le16, __le32, __le64;
|
||||
typedef __be16, __be32, __be64;
|
||||
typedef wchar_t;
|
||||
type INTEGRAL = {u8,__u8,uint8_t,char,unsigned char,uchar,wchar_t,
|
||||
u16,__u16,uint16_t,unsigned short,ushort,
|
||||
u32,__u32,uint32_t,unsigned int,uint,
|
||||
u64,__u64,uint64_t,unsigned long,ulong,
|
||||
__le16,__le32,__le64,__be16,__be32,__be64};
|
||||
char [] STRING;
|
||||
INTEGRAL *BYTES;
|
||||
INTEGRAL **BYTES_PTRS;
|
||||
type TYPE;
|
||||
expression VAR;
|
||||
expression GFP;
|
||||
expression COUNT;
|
||||
expression FLEX;
|
||||
expression E;
|
||||
identifier ALLOC =~ "^kv?[mz]alloc$";
|
||||
fresh identifier ALLOC_OBJ = ALLOC ## "_obj";
|
||||
fresh identifier ALLOC_FLEX = ALLOC ## "_flex";
|
||||
identifier ALLOC_ARRAY = {kmalloc_array,kvmalloc_array,kcalloc,kvcalloc};
|
||||
fresh identifier ALLOC_OBJS = script:python(ALLOC_ARRAY) { alloc_array(ALLOC_ARRAY) };
|
||||
@@
|
||||
|
||||
(
|
||||
- VAR = ALLOC((sizeof(*VAR)), GFP)
|
||||
+ VAR = ALLOC_OBJ(*VAR, GFP)
|
||||
|
|
||||
ALLOC((\(sizeof(STRING)\|sizeof(INTEGRAL)\|sizeof(INTEGRAL *)\)), GFP)
|
||||
|
|
||||
BYTES = ALLOC((sizeof(E)), GFP)
|
||||
|
|
||||
BYTES = ALLOC((sizeof(TYPE)), GFP)
|
||||
|
|
||||
BYTES_PTRS = ALLOC((sizeof(E)), GFP)
|
||||
|
|
||||
BYTES_PTRS = ALLOC((sizeof(TYPE)), GFP)
|
||||
|
|
||||
ALLOC((sizeof(void *)), GFP)
|
||||
|
|
||||
- ALLOC((sizeof(E)), GFP)
|
||||
+ ALLOC_OBJ(E, GFP)
|
||||
|
|
||||
- ALLOC((sizeof(TYPE)), GFP)
|
||||
+ ALLOC_OBJ(TYPE, GFP)
|
||||
|
|
||||
ALLOC_ARRAY(COUNT, (\(sizeof(STRING)\|sizeof(INTEGRAL)\|sizeof(INTEGRAL *)\)), GFP)
|
||||
|
|
||||
BYTES = ALLOC_ARRAY(COUNT, (sizeof(E)), GFP)
|
||||
|
|
||||
BYTES = ALLOC_ARRAY(COUNT, (sizeof(TYPE)), GFP)
|
||||
|
|
||||
BYTES_PTRS = ALLOC_ARRAY(COUNT, (sizeof(E)), GFP)
|
||||
|
|
||||
BYTES_PTRS = ALLOC_ARRAY(COUNT, (sizeof(TYPE)), GFP)
|
||||
|
|
||||
ALLOC_ARRAY((\(sizeof(STRING)\|sizeof(INTEGRAL)\|sizeof(INTEGRAL *)\)), COUNT, GFP)
|
||||
|
|
||||
BYTES = ALLOC_ARRAY((sizeof(E)), COUNT, GFP)
|
||||
|
|
||||
BYTES = ALLOC_ARRAY((sizeof(TYPE)), COUNT, GFP)
|
||||
|
|
||||
BYTES_PTRS = ALLOC_ARRAY((sizeof(E)), COUNT, GFP)
|
||||
|
|
||||
BYTES_PTRS = ALLOC_ARRAY((sizeof(TYPE)), COUNT, GFP)
|
||||
|
|
||||
ALLOC_ARRAY(COUNT, (sizeof(void *)), GFP)
|
||||
|
|
||||
ALLOC_ARRAY((sizeof(void *)), COUNT, GFP)
|
||||
|
|
||||
- ALLOC_ARRAY(COUNT, (sizeof(E)), GFP)
|
||||
+ ALLOC_OBJS(E, COUNT, GFP)
|
||||
|
|
||||
- ALLOC_ARRAY(COUNT, (sizeof(TYPE)), GFP)
|
||||
+ ALLOC_OBJS(TYPE, COUNT, GFP)
|
||||
|
|
||||
- ALLOC_ARRAY((sizeof(E)), COUNT, GFP)
|
||||
+ ALLOC_OBJS(E, COUNT, GFP)
|
||||
|
|
||||
- ALLOC_ARRAY((sizeof(TYPE)), COUNT, GFP)
|
||||
+ ALLOC_OBJS(TYPE, COUNT, GFP)
|
||||
|
|
||||
- ALLOC(struct_size(VAR, FLEX, COUNT), GFP)
|
||||
+ ALLOC_FLEX(*VAR, FLEX, COUNT, GFP)
|
||||
|
|
||||
- ALLOC(struct_size_t(TYPE, FLEX, COUNT), GFP)
|
||||
+ ALLOC_FLEX(TYPE, FLEX, COUNT, GFP)
|
||||
)
|
||||
Loading…
Add table
Add a link
Reference in a new issue