Jason A. Donenfeld
7e3cf0843f
treewide: use get_random_{u8,u16}() when possible, part 1
...
Rather than truncate a 32-bit value to a 16-bit value or an 8-bit value,
simply use the get_random_{u8,u16}() functions, which are faster than
wasting the additional bytes from a 32-bit value. This was done
mechanically with this coccinelle script:
@@
expression E;
identifier get_random_u32 =~ "get_random_int|prandom_u32|get_random_u32";
typedef u16;
typedef __be16;
typedef __le16;
typedef u8;
@@
(
- (get_random_u32() & 0xffff)
+ get_random_u16()
|
- (get_random_u32() & 0xff)
+ get_random_u8()
|
- (get_random_u32() % 65536)
+ get_random_u16()
|
- (get_random_u32() % 256)
+ get_random_u8()
|
- (get_random_u32() >> 16)
+ get_random_u16()
|
- (get_random_u32() >> 24)
+ get_random_u8()
|
- (u16)get_random_u32()
+ get_random_u16()
|
- (u8)get_random_u32()
+ get_random_u8()
|
- (__be16)get_random_u32()
+ (__be16)get_random_u16()
|
- (__le16)get_random_u32()
+ (__le16)get_random_u16()
|
- prandom_u32_max(65536)
+ get_random_u16()
|
- prandom_u32_max(256)
+ get_random_u8()
|
- E->inet_id = get_random_u32()
+ E->inet_id = get_random_u16()
)
@@
identifier get_random_u32 =~ "get_random_int|prandom_u32|get_random_u32";
typedef u16;
identifier v;
@@
- u16 v = get_random_u32();
+ u16 v = get_random_u16();
@@
identifier get_random_u32 =~ "get_random_int|prandom_u32|get_random_u32";
typedef u8;
identifier v;
@@
- u8 v = get_random_u32();
+ u8 v = get_random_u8();
@@
identifier get_random_u32 =~ "get_random_int|prandom_u32|get_random_u32";
typedef u16;
u16 v;
@@
- v = get_random_u32();
+ v = get_random_u16();
@@
identifier get_random_u32 =~ "get_random_int|prandom_u32|get_random_u32";
typedef u8;
u8 v;
@@
- v = get_random_u32();
+ v = get_random_u8();
// Find a potential literal
@literal_mask@
expression LITERAL;
type T;
identifier get_random_u32 =~ "get_random_int|prandom_u32|get_random_u32";
position p;
@@
((T)get_random_u32()@p & (LITERAL))
// Examine limits
@script:python add_one@
literal << literal_mask.LITERAL;
RESULT;
@@
value = None
if literal.startswith('0x'):
value = int(literal, 16)
elif literal[0] in '123456789':
value = int(literal, 10)
if value is None:
print("I don't know how to handle %s" % (literal))
cocci.include_match(False)
elif value < 256:
coccinelle.RESULT = cocci.make_ident("get_random_u8")
elif value < 65536:
coccinelle.RESULT = cocci.make_ident("get_random_u16")
else:
print("Skipping large mask of %s" % (literal))
cocci.include_match(False)
// Replace the literal mask with the calculated result.
@plus_one@
expression literal_mask.LITERAL;
position literal_mask.p;
identifier add_one.RESULT;
identifier FUNC;
@@
- (FUNC()@p & (LITERAL))
+ (RESULT() & LITERAL)
Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Reviewed-by: Kees Cook <keescook@chromium.org>
Reviewed-by: Yury Norov <yury.norov@gmail.com>
Acked-by: Jakub Kicinski <kuba@kernel.org>
Acked-by: Toke Høiland-Jørgensen <toke@toke.dk> # for sch_cake
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2022-10-11 17:42:58 -06:00
..
2022-07-27 18:23:22 -07:00
2022-09-30 12:36:40 +01:00
2021-06-28 15:34:50 -07:00
2020-08-24 16:21:43 -07:00
2021-06-22 11:28:52 -07:00
2022-03-10 14:46:42 -08:00
2021-12-25 17:13:37 +00:00
2022-05-16 10:31:06 +01:00
2019-05-24 17:39:00 +02:00
2022-04-22 12:47:50 +01:00
2020-10-30 15:23:52 -07:00
2018-02-13 13:56:31 -05:00
2019-05-24 17:39:00 +02:00
2021-01-16 19:05:59 -08:00
2022-05-16 10:18:55 +01:00
2022-04-05 09:51:12 +02:00
2019-05-24 17:39:00 +02:00
2021-12-23 11:15:30 +00:00
2022-07-21 13:03:39 -07:00
2021-10-14 07:15:22 -07:00
2022-04-23 22:34:17 +01:00
2022-06-10 16:21:27 -07:00
2021-06-22 11:28:52 -07:00
2022-10-11 17:42:58 -06:00
2022-06-10 16:21:27 -07:00
2019-05-24 17:39:00 +02:00
2019-05-24 17:39:00 +02:00
2022-07-25 19:39:05 -07:00
2022-07-27 18:23:22 -07:00
2021-06-22 11:28:51 -07:00
2021-11-25 21:00:45 -08:00
2021-03-04 13:48:32 -08:00
2022-04-12 15:00:25 +02:00
2022-06-10 16:21:27 -07:00