On 15.03.2018 21:47, Kees Cook wrote:
> As part of removing VLAs from the kernel[1], we want to build with -Wvla,
> but it is overly pessimistic and only accepts constant expressions for
> stack array sizes, instead of also constant values. The max() macro
> triggers the warning, so this refactors these uses of max() to use the
> new const_max() instead.
> 
> [1] https://lkml.org/lkml/2018/3/7/621

For the btrfs portion :

Reviewed-by: Nikolay Borisov <nbori...@suse.com>

> 
> Signed-off-by: Kees Cook <keesc...@chromium.org>
> ---
>  drivers/input/touchscreen/cyttsp4_core.c |  2 +-
>  fs/btrfs/tree-checker.c                  |  3 ++-
>  lib/vsprintf.c                           |  4 ++--
>  net/ipv4/proc.c                          |  8 ++++----
>  net/ipv6/proc.c                          | 10 ++++------
>  5 files changed, 13 insertions(+), 14 deletions(-)
> 
> diff --git a/drivers/input/touchscreen/cyttsp4_core.c 
> b/drivers/input/touchscreen/cyttsp4_core.c
> index 727c3232517c..f89497940051 100644
> --- a/drivers/input/touchscreen/cyttsp4_core.c
> +++ b/drivers/input/touchscreen/cyttsp4_core.c
> @@ -868,7 +868,7 @@ static void cyttsp4_get_mt_touches(struct cyttsp4_mt_data 
> *md, int num_cur_tch)
>       struct cyttsp4_touch tch;
>       int sig;
>       int i, j, t = 0;
> -     int ids[max(CY_TMA1036_MAX_TCH, CY_TMA4XX_MAX_TCH)];
> +     int ids[const_max(CY_TMA1036_MAX_TCH, CY_TMA4XX_MAX_TCH)];
>  
>       memset(ids, 0, si->si_ofs.tch_abs[CY_TCH_T].max * sizeof(int));
>       for (i = 0; i < num_cur_tch; i++) {
> diff --git a/fs/btrfs/tree-checker.c b/fs/btrfs/tree-checker.c
> index c3c8d48f6618..1ddd6cc3c4fc 100644
> --- a/fs/btrfs/tree-checker.c
> +++ b/fs/btrfs/tree-checker.c
> @@ -341,7 +341,8 @@ static int check_dir_item(struct btrfs_root *root,
>                */
>               if (key->type == BTRFS_DIR_ITEM_KEY ||
>                   key->type == BTRFS_XATTR_ITEM_KEY) {
> -                     char namebuf[max(BTRFS_NAME_LEN, XATTR_NAME_MAX)];
> +                     char namebuf[const_max(BTRFS_NAME_LEN,
> +                                            XATTR_NAME_MAX)];
>  
>                       read_extent_buffer(leaf, namebuf,
>                                       (unsigned long)(di + 1), name_len);
> diff --git a/lib/vsprintf.c b/lib/vsprintf.c
> index d7a708f82559..9d5610b643ce 100644
> --- a/lib/vsprintf.c
> +++ b/lib/vsprintf.c
> @@ -744,8 +744,8 @@ char *resource_string(char *buf, char *end, struct 
> resource *res,
>  #define FLAG_BUF_SIZE                (2 * sizeof(res->flags))
>  #define DECODED_BUF_SIZE     sizeof("[mem - 64bit pref window disabled]")
>  #define RAW_BUF_SIZE         sizeof("[mem - flags 0x]")
> -     char sym[max(2*RSRC_BUF_SIZE + DECODED_BUF_SIZE,
> -                  2*RSRC_BUF_SIZE + FLAG_BUF_SIZE + RAW_BUF_SIZE)];
> +     char sym[const_max(2*RSRC_BUF_SIZE + DECODED_BUF_SIZE,
> +                        2*RSRC_BUF_SIZE + FLAG_BUF_SIZE + RAW_BUF_SIZE)];
>  
>       char *p = sym, *pend = sym + sizeof(sym);
>       int decode = (fmt[0] == 'R') ? 1 : 0;
> diff --git a/net/ipv4/proc.c b/net/ipv4/proc.c
> index dc5edc8f7564..fad6f989004e 100644
> --- a/net/ipv4/proc.c
> +++ b/net/ipv4/proc.c
> @@ -46,7 +46,7 @@
>  #include <net/sock.h>
>  #include <net/raw.h>
>  
> -#define TCPUDP_MIB_MAX max_t(u32, UDP_MIB_MAX, TCP_MIB_MAX)
> +#define TCPUDP_MIB_MAX const_max(UDP_MIB_MAX, TCP_MIB_MAX)
>  
>  /*
>   *   Report socket allocation statistics [m...@utu.fi]
> @@ -404,7 +404,7 @@ static int snmp_seq_show_tcp_udp(struct seq_file *seq, 
> void *v)
>       struct net *net = seq->private;
>       int i;
>  
> -     memset(buff, 0, TCPUDP_MIB_MAX * sizeof(unsigned long));
> +     memset(buff, 0, sizeof(buff));
>  
>       seq_puts(seq, "\nTcp:");
>       for (i = 0; snmp4_tcp_list[i].name; i++)
> @@ -421,7 +421,7 @@ static int snmp_seq_show_tcp_udp(struct seq_file *seq, 
> void *v)
>                       seq_printf(seq, " %lu", buff[i]);
>       }
>  
> -     memset(buff, 0, TCPUDP_MIB_MAX * sizeof(unsigned long));
> +     memset(buff, 0, sizeof(buff));
>  
>       snmp_get_cpu_field_batch(buff, snmp4_udp_list,
>                                net->mib.udp_statistics);
> @@ -432,7 +432,7 @@ static int snmp_seq_show_tcp_udp(struct seq_file *seq, 
> void *v)
>       for (i = 0; snmp4_udp_list[i].name; i++)
>               seq_printf(seq, " %lu", buff[i]);
>  
> -     memset(buff, 0, TCPUDP_MIB_MAX * sizeof(unsigned long));
> +     memset(buff, 0, sizeof(buff));
>  
>       /* the UDP and UDP-Lite MIBs are the same */
>       seq_puts(seq, "\nUdpLite:");
> diff --git a/net/ipv6/proc.c b/net/ipv6/proc.c
> index b67814242f78..58bbfc4fa7fa 100644
> --- a/net/ipv6/proc.c
> +++ b/net/ipv6/proc.c
> @@ -30,10 +30,8 @@
>  #include <net/transp_v6.h>
>  #include <net/ipv6.h>
>  
> -#define MAX4(a, b, c, d) \
> -     max_t(u32, max_t(u32, a, b), max_t(u32, c, d))
> -#define SNMP_MIB_MAX MAX4(UDP_MIB_MAX, TCP_MIB_MAX, \
> -                     IPSTATS_MIB_MAX, ICMP_MIB_MAX)
> +#define SNMP_MIB_MAX const_max(const_max(UDP_MIB_MAX, TCP_MIB_MAX), \
> +                            const_max(IPSTATS_MIB_MAX, ICMP_MIB_MAX))
>  
>  static int sockstat6_seq_show(struct seq_file *seq, void *v)
>  {
> @@ -199,7 +197,7 @@ static void snmp6_seq_show_item(struct seq_file *seq, 
> void __percpu *pcpumib,
>       int i;
>  
>       if (pcpumib) {
> -             memset(buff, 0, sizeof(unsigned long) * SNMP_MIB_MAX);
> +             memset(buff, 0, sizeof(buff));
>  
>               snmp_get_cpu_field_batch(buff, itemlist, pcpumib);
>               for (i = 0; itemlist[i].name; i++)
> @@ -218,7 +216,7 @@ static void snmp6_seq_show_item64(struct seq_file *seq, 
> void __percpu *mib,
>       u64 buff64[SNMP_MIB_MAX];
>       int i;
>  
> -     memset(buff64, 0, sizeof(u64) * SNMP_MIB_MAX);
> +     memset(buff64, 0, sizeof(buff64));
>  
>       snmp_get_cpu_field64_batch(buff64, itemlist, mib, syncpoff);
>       for (i = 0; itemlist[i].name; i++)
> 

Reply via email to