sg_init_table zeroes its first argument, so the allocation of that argument
doesn't have to.
the semantic patch that makes this change is as follows:
(http://coccinelle.lip6.fr/)
// <smpl>
@@
expression x,n,flags;
@@
x =
- kcalloc
+ kmalloc_array
  (n,sizeof(*x),flags)
...
sg_init_table(x,n)
// </smpl>
Link: https://lore.kernel.org/r/1600601186-7420-3-git-send-email-Julia.Lawall@inria.fr
Signed-off-by: Julia Lawall <Julia.Lawall@inria.fr>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
 
                if (sg_per_table < total_sg_needed)
                        chain_entry = 1;
 
-               sg = kcalloc(sg_per_table + chain_entry, sizeof(*sg),
+               sg = kmalloc_array(sg_per_table + chain_entry, sizeof(*sg),
                                GFP_KERNEL);
                if (!sg)
                        return -ENOMEM;