Received: by 10.213.65.68 with SMTP id h4csp827594imn; Tue, 20 Mar 2018 16:57:23 -0700 (PDT) X-Google-Smtp-Source: AG47ELvUzxi47dCd3q383vfJymAiUksE33t0PUWowmVHUn73pxCrFk785l3I4M2SyM/a2G1mWYHX X-Received: by 10.98.198.92 with SMTP id m89mr15187227pfg.73.1521590243745; Tue, 20 Mar 2018 16:57:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521590243; cv=none; d=google.com; s=arc-20160816; b=npON6dM/aEhDLwMkgJZuEf/kiVAi0zeIpe7gwyRBVD9+Fftww9/6MGjFTrGDD12LJq eGeUWlOJcBAacf386yjBD72mB6JxOj/iq+L2RRtr5ckC7uyEK3fRBtnlsgp78sU2pbRm cObh2TQe8Abu8ut6Q3iXffLQn2qtDCkSSvuGjZv2hHwGQol8QGJWXgrheqcVyMqt4Iox 4jhOGkDhkNd/NUGEOScydk0Bl1HBEMZCsITh/pO9xNITfSL4gn1k+sktm3E0y2htYsnL Jcy3Ghszus70i/TOX+Q0gc0EOIK3mmWmVie1FfKRQjQD1evUNTPgNGl0bO11SWo9Zfnm YiUg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:content-disposition :mime-version:message-id:subject:cc:to:from:date :arc-authentication-results; bh=opDRUqnftAVylxkF4v2u7kuCHSmPcXUQZ1Q5f5yOst8=; b=YRMqV7KH6ar+2Cq2Eu4nrd+/YJPieMrIdhgl0ePA3SyN/ZO2aYeHyIaAgiLzXlcSlE iwqRY8B9pmdOX2Fiz+ki8DVoUZMnlJ8c7mpwkJIwrj7DesevqmYXdPkrs0oYvliWvKmD xNYs6ZnPvDRgdSBAKL6g+ykWAaBe+jdZ/nTeLzVnfnHHqvdSZYca7xyv0Nz2LUakl7/S wXuAHzQpv6xnUNfTKSJfnDmTlCfTyhjEv0Scd7v8Xa8dk1YhEgiXVTXdz56yAFJwaAsA o7ABz4F1yIh9NyyTP2aWCBIyR6Aww6bUSutVA2BGUQCFvawDpI22xKqYPOmraQuOMroc JbzQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p24si1884527pgn.797.2018.03.20.16.57.08; Tue, 20 Mar 2018 16:57:23 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751587AbeCTX4M (ORCPT + 99 others); Tue, 20 Mar 2018 19:56:12 -0400 Received: from gateway20.websitewelcome.com ([192.185.55.25]:46814 "EHLO gateway20.websitewelcome.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751018AbeCTX4L (ORCPT ); Tue, 20 Mar 2018 19:56:11 -0400 X-Greylist: delayed 1285 seconds by postgrey-1.27 at vger.kernel.org; Tue, 20 Mar 2018 19:56:11 EDT Received: from cm11.websitewelcome.com (cm11.websitewelcome.com [100.42.49.5]) by gateway20.websitewelcome.com (Postfix) with ESMTP id 0B132400D4CCE for ; Tue, 20 Mar 2018 18:34:46 -0500 (CDT) Received: from gator4166.hostgator.com ([108.167.133.22]) by cmsmtp with SMTP id yQmEetKcWA3CSyQmEe5JnI; Tue, 20 Mar 2018 18:34:46 -0500 Received: from 187-162-24-133.static.axtel.net ([187.162.24.133]:63567 helo=embeddedor) by gator4166.hostgator.com with esmtpa (Exim 4.89_1) (envelope-from ) id 1eyQmD-000ULO-IA; Tue, 20 Mar 2018 18:34:45 -0500 Date: Tue, 20 Mar 2018 18:34:44 -0500 From: "Gustavo A. R. Silva" To: Marcel Holtmann , Johan Hedberg , "David S. Miller" Cc: linux-bluetooth@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, "Gustavo A. R. Silva" Subject: [PATCH] Bluetooth: Remove VLA usage in aes_cmac Message-ID: <20180320233444.GA14446@embeddedor.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.5.24 (2015-08-30) X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - gator4166.hostgator.com X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - embeddedor.com X-BWhitelist: no X-Source-IP: 187.162.24.133 X-Source-L: No X-Exim-ID: 1eyQmD-000ULO-IA X-Source: X-Source-Args: X-Source-Dir: X-Source-Sender: 187-162-24-133.static.axtel.net (embeddedor) [187.162.24.133]:63567 X-Source-Auth: gustavo@embeddedor.com X-Email-Count: 6 X-Source-Cap: Z3V6aWRpbmU7Z3V6aWRpbmU7Z2F0b3I0MTY2Lmhvc3RnYXRvci5jb20= X-Local-Domain: yes Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In preparation to enabling -Wvla, remove VLA and replace it with dynamic memory allocation instead. The use of stack Variable Length Arrays needs to be avoided, as they can be a vector for stack exhaustion, which can be both a runtime bug or a security flaw. Also, in general, as code evolves it is easy to lose track of how big a VLA can get. Thus, we can end up having runtime failures that are hard to debug. Also, fixed as part of the directive to remove all VLAs from the kernel: https://lkml.org/lkml/2018/3/7/621 Signed-off-by: Gustavo A. R. Silva --- net/bluetooth/smp.c | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/net/bluetooth/smp.c b/net/bluetooth/smp.c index a2ddae2..23c694d 100644 --- a/net/bluetooth/smp.c +++ b/net/bluetooth/smp.c @@ -173,7 +173,7 @@ static int aes_cmac(struct crypto_shash *tfm, const u8 k[16], const u8 *m, size_t len, u8 mac[16]) { uint8_t tmp[16], mac_msb[16], msg_msb[CMAC_MSG_MAX]; - SHASH_DESC_ON_STACK(desc, tfm); + struct shash_desc *shash; int err; if (len > CMAC_MSG_MAX) @@ -184,8 +184,13 @@ static int aes_cmac(struct crypto_shash *tfm, const u8 k[16], const u8 *m, return -EINVAL; } - desc->tfm = tfm; - desc->flags = 0; + shash = kzalloc(sizeof(*shash) + crypto_shash_descsize(tfm), + GFP_KERNEL); + if (!shash) + return -ENOMEM; + + shash->tfm = tfm; + shash->flags = 0; /* Swap key and message from LSB to MSB */ swap_buf(k, tmp, 16); @@ -200,8 +205,9 @@ static int aes_cmac(struct crypto_shash *tfm, const u8 k[16], const u8 *m, return err; } - err = crypto_shash_digest(desc, msg_msb, len, mac_msb); - shash_desc_zero(desc); + err = crypto_shash_digest(shash, msg_msb, len, mac_msb); + shash_desc_zero(shash); + kfree(shash); if (err) { BT_ERR("Hash computation error %d", err); return err; -- 2.7.4