diff options
author | Kees Cook <keescook@chromium.org> | 2018-06-12 16:55:00 -0400 |
---|---|---|
committer | Kees Cook <keescook@chromium.org> | 2018-06-12 19:19:22 -0400 |
commit | 6da2ec56059c3c7a7e5f729e6349e74ace1e5c57 (patch) | |
tree | 2278b513e904a46e930a856da3ed3ac5bc3fe4a4 /drivers/tty | |
parent | 1c542f38ab8d30d9c852a16d49ac5a15267bbf1f (diff) |
treewide: kmalloc() -> kmalloc_array()
The kmalloc() function has a 2-factor argument form, kmalloc_array(). This
patch replaces cases of:
kmalloc(a * b, gfp)
with:
kmalloc_array(a * b, gfp)
as well as handling cases of:
kmalloc(a * b * c, gfp)
with:
kmalloc(array3_size(a, b, c), gfp)
as it's slightly less ugly than:
kmalloc_array(array_size(a, b), c, gfp)
This does, however, attempt to ignore constant size factors like:
kmalloc(4 * 1024, gfp)
though any constants defined via macros get caught up in the conversion.
Any factors with a sizeof() of "unsigned char", "char", and "u8" were
dropped, since they're redundant.
The tools/ directory was manually excluded, since it has its own
implementation of kmalloc().
The Coccinelle script used for this was:
// Fix redundant parens around sizeof().
@@
type TYPE;
expression THING, E;
@@
(
kmalloc(
- (sizeof(TYPE)) * E
+ sizeof(TYPE) * E
, ...)
|
kmalloc(
- (sizeof(THING)) * E
+ sizeof(THING) * E
, ...)
)
// Drop single-byte sizes and redundant parens.
@@
expression COUNT;
typedef u8;
typedef __u8;
@@
(
kmalloc(
- sizeof(u8) * (COUNT)
+ COUNT
, ...)
|
kmalloc(
- sizeof(__u8) * (COUNT)
+ COUNT
, ...)
|
kmalloc(
- sizeof(char) * (COUNT)
+ COUNT
, ...)
|
kmalloc(
- sizeof(unsigned char) * (COUNT)
+ COUNT
, ...)
|
kmalloc(
- sizeof(u8) * COUNT
+ COUNT
, ...)
|
kmalloc(
- sizeof(__u8) * COUNT
+ COUNT
, ...)
|
kmalloc(
- sizeof(char) * COUNT
+ COUNT
, ...)
|
kmalloc(
- sizeof(unsigned char) * COUNT
+ COUNT
, ...)
)
// 2-factor product with sizeof(type/expression) and identifier or constant.
@@
type TYPE;
expression THING;
identifier COUNT_ID;
constant COUNT_CONST;
@@
(
- kmalloc
+ kmalloc_array
(
- sizeof(TYPE) * (COUNT_ID)
+ COUNT_ID, sizeof(TYPE)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(TYPE) * COUNT_ID
+ COUNT_ID, sizeof(TYPE)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(TYPE) * (COUNT_CONST)
+ COUNT_CONST, sizeof(TYPE)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(TYPE) * COUNT_CONST
+ COUNT_CONST, sizeof(TYPE)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(THING) * (COUNT_ID)
+ COUNT_ID, sizeof(THING)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(THING) * COUNT_ID
+ COUNT_ID, sizeof(THING)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(THING) * (COUNT_CONST)
+ COUNT_CONST, sizeof(THING)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(THING) * COUNT_CONST
+ COUNT_CONST, sizeof(THING)
, ...)
)
// 2-factor product, only identifiers.
@@
identifier SIZE, COUNT;
@@
- kmalloc
+ kmalloc_array
(
- SIZE * COUNT
+ COUNT, SIZE
, ...)
// 3-factor product with 1 sizeof(type) or sizeof(expression), with
// redundant parens removed.
@@
expression THING;
identifier STRIDE, COUNT;
type TYPE;
@@
(
kmalloc(
- sizeof(TYPE) * (COUNT) * (STRIDE)
+ array3_size(COUNT, STRIDE, sizeof(TYPE))
, ...)
|
kmalloc(
- sizeof(TYPE) * (COUNT) * STRIDE
+ array3_size(COUNT, STRIDE, sizeof(TYPE))
, ...)
|
kmalloc(
- sizeof(TYPE) * COUNT * (STRIDE)
+ array3_size(COUNT, STRIDE, sizeof(TYPE))
, ...)
|
kmalloc(
- sizeof(TYPE) * COUNT * STRIDE
+ array3_size(COUNT, STRIDE, sizeof(TYPE))
, ...)
|
kmalloc(
- sizeof(THING) * (COUNT) * (STRIDE)
+ array3_size(COUNT, STRIDE, sizeof(THING))
, ...)
|
kmalloc(
- sizeof(THING) * (COUNT) * STRIDE
+ array3_size(COUNT, STRIDE, sizeof(THING))
, ...)
|
kmalloc(
- sizeof(THING) * COUNT * (STRIDE)
+ array3_size(COUNT, STRIDE, sizeof(THING))
, ...)
|
kmalloc(
- sizeof(THING) * COUNT * STRIDE
+ array3_size(COUNT, STRIDE, sizeof(THING))
, ...)
)
// 3-factor product with 2 sizeof(variable), with redundant parens removed.
@@
expression THING1, THING2;
identifier COUNT;
type TYPE1, TYPE2;
@@
(
kmalloc(
- sizeof(TYPE1) * sizeof(TYPE2) * COUNT
+ array3_size(COUNT, sizeof(TYPE1), sizeof(TYPE2))
, ...)
|
kmalloc(
- sizeof(TYPE1) * sizeof(THING2) * (COUNT)
+ array3_size(COUNT, sizeof(TYPE1), sizeof(TYPE2))
, ...)
|
kmalloc(
- sizeof(THING1) * sizeof(THING2) * COUNT
+ array3_size(COUNT, sizeof(THING1), sizeof(THING2))
, ...)
|
kmalloc(
- sizeof(THING1) * sizeof(THING2) * (COUNT)
+ array3_size(COUNT, sizeof(THING1), sizeof(THING2))
, ...)
|
kmalloc(
- sizeof(TYPE1) * sizeof(THING2) * COUNT
+ array3_size(COUNT, sizeof(TYPE1), sizeof(THING2))
, ...)
|
kmalloc(
- sizeof(TYPE1) * sizeof(THING2) * (COUNT)
+ array3_size(COUNT, sizeof(TYPE1), sizeof(THING2))
, ...)
)
// 3-factor product, only identifiers, with redundant parens removed.
@@
identifier STRIDE, SIZE, COUNT;
@@
(
kmalloc(
- (COUNT) * STRIDE * SIZE
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
|
kmalloc(
- COUNT * (STRIDE) * SIZE
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
|
kmalloc(
- COUNT * STRIDE * (SIZE)
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
|
kmalloc(
- (COUNT) * (STRIDE) * SIZE
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
|
kmalloc(
- COUNT * (STRIDE) * (SIZE)
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
|
kmalloc(
- (COUNT) * STRIDE * (SIZE)
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
|
kmalloc(
- (COUNT) * (STRIDE) * (SIZE)
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
|
kmalloc(
- COUNT * STRIDE * SIZE
+ array3_size(COUNT, STRIDE, SIZE)
, ...)
)
// Any remaining multi-factor products, first at least 3-factor products,
// when they're not all constants...
@@
expression E1, E2, E3;
constant C1, C2, C3;
@@
(
kmalloc(C1 * C2 * C3, ...)
|
kmalloc(
- (E1) * E2 * E3
+ array3_size(E1, E2, E3)
, ...)
|
kmalloc(
- (E1) * (E2) * E3
+ array3_size(E1, E2, E3)
, ...)
|
kmalloc(
- (E1) * (E2) * (E3)
+ array3_size(E1, E2, E3)
, ...)
|
kmalloc(
- E1 * E2 * E3
+ array3_size(E1, E2, E3)
, ...)
)
// And then all remaining 2 factors products when they're not all constants,
// keeping sizeof() as the second factor argument.
@@
expression THING, E1, E2;
type TYPE;
constant C1, C2, C3;
@@
(
kmalloc(sizeof(THING) * C2, ...)
|
kmalloc(sizeof(TYPE) * C2, ...)
|
kmalloc(C1 * C2 * C3, ...)
|
kmalloc(C1 * C2, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(TYPE) * (E2)
+ E2, sizeof(TYPE)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(TYPE) * E2
+ E2, sizeof(TYPE)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(THING) * (E2)
+ E2, sizeof(THING)
, ...)
|
- kmalloc
+ kmalloc_array
(
- sizeof(THING) * E2
+ E2, sizeof(THING)
, ...)
|
- kmalloc
+ kmalloc_array
(
- (E1) * E2
+ E1, E2
, ...)
|
- kmalloc
+ kmalloc_array
(
- (E1) * (E2)
+ E1, E2
, ...)
|
- kmalloc
+ kmalloc_array
(
- E1 * E2
+ E1, E2
, ...)
)
Signed-off-by: Kees Cook <keescook@chromium.org>
Diffstat (limited to 'drivers/tty')
-rw-r--r-- | drivers/tty/hvc/hvcs.c | 3 | ||||
-rw-r--r-- | drivers/tty/isicom.c | 2 | ||||
-rw-r--r-- | drivers/tty/serial/atmel_serial.c | 5 | ||||
-rw-r--r-- | drivers/tty/vt/consolemap.c | 7 | ||||
-rw-r--r-- | drivers/tty/vt/keyboard.c | 4 | ||||
-rw-r--r-- | drivers/tty/vt/selection.c | 3 |
6 files changed, 14 insertions, 10 deletions
diff --git a/drivers/tty/hvc/hvcs.c b/drivers/tty/hvc/hvcs.c index 1db1d97e72e7..cb4db1b3ca3c 100644 --- a/drivers/tty/hvc/hvcs.c +++ b/drivers/tty/hvc/hvcs.c | |||
@@ -1441,7 +1441,8 @@ static int hvcs_alloc_index_list(int n) | |||
1441 | { | 1441 | { |
1442 | int i; | 1442 | int i; |
1443 | 1443 | ||
1444 | hvcs_index_list = kmalloc(n * sizeof(hvcs_index_count),GFP_KERNEL); | 1444 | hvcs_index_list = kmalloc_array(n, sizeof(hvcs_index_count), |
1445 | GFP_KERNEL); | ||
1445 | if (!hvcs_index_list) | 1446 | if (!hvcs_index_list) |
1446 | return -ENOMEM; | 1447 | return -ENOMEM; |
1447 | hvcs_index_count = n; | 1448 | hvcs_index_count = n; |
diff --git a/drivers/tty/isicom.c b/drivers/tty/isicom.c index bdd3027ef01b..8d96e86966f1 100644 --- a/drivers/tty/isicom.c +++ b/drivers/tty/isicom.c | |||
@@ -1477,7 +1477,7 @@ static int load_firmware(struct pci_dev *pdev, | |||
1477 | goto errrelfw; | 1477 | goto errrelfw; |
1478 | } | 1478 | } |
1479 | 1479 | ||
1480 | data = kmalloc(word_count * 2, GFP_KERNEL); | 1480 | data = kmalloc_array(word_count, 2, GFP_KERNEL); |
1481 | if (data == NULL) { | 1481 | if (data == NULL) { |
1482 | dev_err(&pdev->dev, "Card%d, firmware upload " | 1482 | dev_err(&pdev->dev, "Card%d, firmware upload " |
1483 | "failed, not enough memory\n", index + 1); | 1483 | "failed, not enough memory\n", index + 1); |
diff --git a/drivers/tty/serial/atmel_serial.c b/drivers/tty/serial/atmel_serial.c index 55b3eff148b1..8e4428725848 100644 --- a/drivers/tty/serial/atmel_serial.c +++ b/drivers/tty/serial/atmel_serial.c | |||
@@ -2738,8 +2738,9 @@ static int atmel_serial_probe(struct platform_device *pdev) | |||
2738 | 2738 | ||
2739 | if (!atmel_use_pdc_rx(&atmel_port->uart)) { | 2739 | if (!atmel_use_pdc_rx(&atmel_port->uart)) { |
2740 | ret = -ENOMEM; | 2740 | ret = -ENOMEM; |
2741 | data = kmalloc(sizeof(struct atmel_uart_char) | 2741 | data = kmalloc_array(ATMEL_SERIAL_RINGSIZE, |
2742 | * ATMEL_SERIAL_RINGSIZE, GFP_KERNEL); | 2742 | sizeof(struct atmel_uart_char), |
2743 | GFP_KERNEL); | ||
2743 | if (!data) | 2744 | if (!data) |
2744 | goto err_alloc_ring; | 2745 | goto err_alloc_ring; |
2745 | atmel_port->rx_ring.buf = data; | 2746 | atmel_port->rx_ring.buf = data; |
diff --git a/drivers/tty/vt/consolemap.c b/drivers/tty/vt/consolemap.c index 722a6690c70d..7c7ada0b3ea0 100644 --- a/drivers/tty/vt/consolemap.c +++ b/drivers/tty/vt/consolemap.c | |||
@@ -231,7 +231,7 @@ static void set_inverse_trans_unicode(struct vc_data *conp, | |||
231 | q = p->inverse_trans_unicode; | 231 | q = p->inverse_trans_unicode; |
232 | if (!q) { | 232 | if (!q) { |
233 | q = p->inverse_trans_unicode = | 233 | q = p->inverse_trans_unicode = |
234 | kmalloc(MAX_GLYPH * sizeof(u16), GFP_KERNEL); | 234 | kmalloc_array(MAX_GLYPH, sizeof(u16), GFP_KERNEL); |
235 | if (!q) | 235 | if (!q) |
236 | return; | 236 | return; |
237 | } | 237 | } |
@@ -479,7 +479,8 @@ con_insert_unipair(struct uni_pagedir *p, u_short unicode, u_short fontpos) | |||
479 | 479 | ||
480 | p1 = p->uni_pgdir[n = unicode >> 11]; | 480 | p1 = p->uni_pgdir[n = unicode >> 11]; |
481 | if (!p1) { | 481 | if (!p1) { |
482 | p1 = p->uni_pgdir[n] = kmalloc(32*sizeof(u16 *), GFP_KERNEL); | 482 | p1 = p->uni_pgdir[n] = kmalloc_array(32, sizeof(u16 *), |
483 | GFP_KERNEL); | ||
483 | if (!p1) return -ENOMEM; | 484 | if (!p1) return -ENOMEM; |
484 | for (i = 0; i < 32; i++) | 485 | for (i = 0; i < 32; i++) |
485 | p1[i] = NULL; | 486 | p1[i] = NULL; |
@@ -487,7 +488,7 @@ con_insert_unipair(struct uni_pagedir *p, u_short unicode, u_short fontpos) | |||
487 | 488 | ||
488 | p2 = p1[n = (unicode >> 6) & 0x1f]; | 489 | p2 = p1[n = (unicode >> 6) & 0x1f]; |
489 | if (!p2) { | 490 | if (!p2) { |
490 | p2 = p1[n] = kmalloc(64*sizeof(u16), GFP_KERNEL); | 491 | p2 = p1[n] = kmalloc_array(64, sizeof(u16), GFP_KERNEL); |
491 | if (!p2) return -ENOMEM; | 492 | if (!p2) return -ENOMEM; |
492 | memset(p2, 0xff, 64*sizeof(u16)); /* No glyphs for the characters (yet) */ | 493 | memset(p2, 0xff, 64*sizeof(u16)); /* No glyphs for the characters (yet) */ |
493 | } | 494 | } |
diff --git a/drivers/tty/vt/keyboard.c b/drivers/tty/vt/keyboard.c index 5d412df8e943..d5b4a2b44ab8 100644 --- a/drivers/tty/vt/keyboard.c +++ b/drivers/tty/vt/keyboard.c | |||
@@ -1624,7 +1624,7 @@ int vt_do_diacrit(unsigned int cmd, void __user *udp, int perm) | |||
1624 | struct kbdiacr *dia; | 1624 | struct kbdiacr *dia; |
1625 | int i; | 1625 | int i; |
1626 | 1626 | ||
1627 | dia = kmalloc(MAX_DIACR * sizeof(struct kbdiacr), | 1627 | dia = kmalloc_array(MAX_DIACR, sizeof(struct kbdiacr), |
1628 | GFP_KERNEL); | 1628 | GFP_KERNEL); |
1629 | if (!dia) | 1629 | if (!dia) |
1630 | return -ENOMEM; | 1630 | return -ENOMEM; |
@@ -1657,7 +1657,7 @@ int vt_do_diacrit(unsigned int cmd, void __user *udp, int perm) | |||
1657 | struct kbdiacrsuc __user *a = udp; | 1657 | struct kbdiacrsuc __user *a = udp; |
1658 | void *buf; | 1658 | void *buf; |
1659 | 1659 | ||
1660 | buf = kmalloc(MAX_DIACR * sizeof(struct kbdiacruc), | 1660 | buf = kmalloc_array(MAX_DIACR, sizeof(struct kbdiacruc), |
1661 | GFP_KERNEL); | 1661 | GFP_KERNEL); |
1662 | if (buf == NULL) | 1662 | if (buf == NULL) |
1663 | return -ENOMEM; | 1663 | return -ENOMEM; |
diff --git a/drivers/tty/vt/selection.c b/drivers/tty/vt/selection.c index 7851383fbd6c..90ea1cc52b7a 100644 --- a/drivers/tty/vt/selection.c +++ b/drivers/tty/vt/selection.c | |||
@@ -280,7 +280,8 @@ int set_selection(const struct tiocl_selection __user *sel, struct tty_struct *t | |||
280 | 280 | ||
281 | /* Allocate a new buffer before freeing the old one ... */ | 281 | /* Allocate a new buffer before freeing the old one ... */ |
282 | multiplier = use_unicode ? 3 : 1; /* chars can take up to 3 bytes */ | 282 | multiplier = use_unicode ? 3 : 1; /* chars can take up to 3 bytes */ |
283 | bp = kmalloc(((sel_end-sel_start)/2+1)*multiplier, GFP_KERNEL); | 283 | bp = kmalloc_array((sel_end - sel_start) / 2 + 1, multiplier, |
284 | GFP_KERNEL); | ||
284 | if (!bp) { | 285 | if (!bp) { |
285 | printk(KERN_WARNING "selection: kmalloc() failed\n"); | 286 | printk(KERN_WARNING "selection: kmalloc() failed\n"); |
286 | clear_selection(); | 287 | clear_selection(); |