• Alexey Dobriyan's avatar
    netlink: 2-clause nla_ok() · 4f7df337
    Alexey Dobriyan authored
    nla_ok() consists of 3 clauses:
    
    	1) int rem >= (int)sizeof(struct nlattr)
    
    	2) u16 nla_len >= sizeof(struct nlattr)
    
    	3) u16 nla_len <= int rem
    
    The statement is that clause (1) is redundant.
    
    What it does is ensuring that "rem" is a positive number,
    so that in clause (3) positive number will be compared to positive number
    with no problems.
    
    However, "u16" fully fits into "int" and integers do not change value
    when upcasting even to signed type. Negative integers will be rejected
    by clause (3) just fine. Small positive integers will be rejected
    by transitivity of comparison operator.
    
    NOTE: all of the above DOES NOT apply to nlmsg_ok() where ->nlmsg_len is
    u32(!), so 3 clauses AND A CAST TO INT are necessary.
    
    Obligatory space savings report: -1.6 KB
    
    	$ ./scripts/bloat-o-meter ../vmlinux-000* ../vmlinux-001*
    	add/remove: 0/0 grow/shrink: 3/63 up/down: 35/-1692 (-1657)
    	function                                     old     new   delta
    	validate_scan_freqs                          142     155     +13
    	tcf_em_tree_validate                         867     879     +12
    	dcbnl_ieee_del                               328     338     +10
    	netlbl_cipsov4_add_common.isra               218     215      -3
    		...
    	ovs_nla_put_actions                          888     806     -82
    	netlbl_cipsov4_add_std                      1648    1566     -82
    	nl80211_parse_sched_scan                    2889    2780    -109
    	ip_tun_from_nlattr                          3086    2945    -141
    Signed-off-by: default avatarAlexey Dobriyan <adobriyan@gmail.com>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    4f7df337
netlink.h 38.9 KB