Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp1040236pxu; Fri, 16 Oct 2020 02:12:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwWUNGHIY/Y1ot8Y7SGti9QCJbxVPmBy42KjQX+DasUhzJjHl4xZ9C/w+M7fzmWE3rUsEpD X-Received: by 2002:a17:906:7e53:: with SMTP id z19mr2705332ejr.334.1602839523565; Fri, 16 Oct 2020 02:12:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1602839523; cv=none; d=google.com; s=arc-20160816; b=MjfmwdVA1pr8ycsN6WUaV4DRqAVbebGEemkFJ04y2zebefAAwxXP19t6GIJzMhyPk1 xPqZ43uvj3kI53wqiXsW9NnUO0ll861dITqO3f7vBjt2hQA0sR+fvoDiqRXBZClVj6ul RQM52GtZP5TQbE+/ykKEg0MBv2/b9K75rSDwaqIOAOeN6l1MsX6h/5atOkVfV2iyg18B AyMdAz6Ob/ldRyINJpjQ3aXE0FqE/t8CCyxkdYXcKCad/URHp0RptbKmGc7nIami29us 7/O+4dup+nAnhqIB/yKoVZLcHQyprcHLyoGfM0hjdBV73ybaJbf8ibkKYM8Jcj0hvTKl nnEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=A3s/EGXld9wp8+94hEgB6sMq/A7OD5G/1mVv4FD3lck=; b=i2GHWBkMxYpAdp13j3RJSt1nB8VbrwoOvboE1uT8BeHprY0QPSlwRDO+bXtXggUWrL uJdZoqZWvW4B53fsHVSNBzGdUouWv7pNFG1UPSggEWG9f08ciFdAzAZanaQUGb7F0wyG s9jYHTSOsJMTNeXy7Cwb5jJZVej6CZq27lDqBX0knewTd+eP8wgCjBy1pBDvBt/zdCuZ VI+PkhFrh9FQH8bO1BtgT5TwJ30d+4L/7ja0PpIjhXauooNdSPzxOTH2BJh3h7oa52rD NG8CT+6BHiIi1XZaxFlRfAJj4CjylkVfWKWDrBmSoXhTrNxdweVkvZwidBE9fQatS9j4 Wbvw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=TgwSfvQi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id lo12si1270856ejb.355.2020.10.16.02.11.41; Fri, 16 Oct 2020 02:12:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=TgwSfvQi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2394977AbgJPJJB (ORCPT + 99 others); Fri, 16 Oct 2020 05:09:01 -0400 Received: from mail.kernel.org ([198.145.29.99]:35786 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2405113AbgJPJHa (ORCPT ); Fri, 16 Oct 2020 05:07:30 -0400 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D3B69218AC; Fri, 16 Oct 2020 09:07:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1602839250; bh=16/TAZ8EDeUaBagtevxZ1bw/cNO+Dxs9T4s6oryzSFg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=TgwSfvQidN/ABJhK7AjgipLH02RCWGYvtU8g6tYWmb/5jPp7AaFs1oKoWfe51fsQE xNn7pNovUFcsR7naeSWMCjbqtLcE9fC7yvWBvlJg8X6Yn7Zo4TT16O8pDNToworL0v kxZDoLZgYvquxCx2cjvhHWZRzKIfqGMhbDzA44Lg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Luiz Augusto von Dentz , Marcel Holtmann Subject: [PATCH 4.9 01/16] Bluetooth: A2MP: Fix not initializing all members Date: Fri, 16 Oct 2020 11:07:05 +0200 Message-Id: <20201016090437.282797501@linuxfoundation.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201016090437.205626543@linuxfoundation.org> References: <20201016090437.205626543@linuxfoundation.org> User-Agent: quilt/0.66 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Luiz Augusto von Dentz commit eddb7732119d53400f48a02536a84c509692faa8 upstream. This fixes various places where a stack variable is used uninitialized. Signed-off-by: Luiz Augusto von Dentz Signed-off-by: Marcel Holtmann Signed-off-by: Greg Kroah-Hartman --- net/bluetooth/a2mp.c | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) --- a/net/bluetooth/a2mp.c +++ b/net/bluetooth/a2mp.c @@ -233,6 +233,9 @@ static int a2mp_discover_rsp(struct amp_ struct a2mp_info_req req; found = true; + + memset(&req, 0, sizeof(req)); + req.id = cl->id; a2mp_send(mgr, A2MP_GETINFO_REQ, __next_ident(mgr), sizeof(req), &req); @@ -312,6 +315,8 @@ static int a2mp_getinfo_req(struct amp_m if (!hdev || hdev->dev_type != HCI_AMP) { struct a2mp_info_rsp rsp; + memset(&rsp, 0, sizeof(rsp)); + rsp.id = req->id; rsp.status = A2MP_STATUS_INVALID_CTRL_ID; @@ -355,6 +360,8 @@ static int a2mp_getinfo_rsp(struct amp_m if (!ctrl) return -ENOMEM; + memset(&req, 0, sizeof(req)); + req.id = rsp->id; a2mp_send(mgr, A2MP_GETAMPASSOC_REQ, __next_ident(mgr), sizeof(req), &req); @@ -383,6 +390,8 @@ static int a2mp_getampassoc_req(struct a struct a2mp_amp_assoc_rsp rsp; rsp.id = req->id; + memset(&rsp, 0, sizeof(rsp)); + if (tmp) { rsp.status = A2MP_STATUS_COLLISION_OCCURED; amp_mgr_put(tmp); @@ -471,7 +480,6 @@ static int a2mp_createphyslink_req(struc struct a2mp_cmd *hdr) { struct a2mp_physlink_req *req = (void *) skb->data; - struct a2mp_physlink_rsp rsp; struct hci_dev *hdev; struct hci_conn *hcon; @@ -482,6 +490,8 @@ static int a2mp_createphyslink_req(struc BT_DBG("local_id %d, remote_id %d", req->local_id, req->remote_id); + memset(&rsp, 0, sizeof(rsp)); + rsp.local_id = req->remote_id; rsp.remote_id = req->local_id; @@ -560,6 +570,8 @@ static int a2mp_discphyslink_req(struct BT_DBG("local_id %d remote_id %d", req->local_id, req->remote_id); + memset(&rsp, 0, sizeof(rsp)); + rsp.local_id = req->remote_id; rsp.remote_id = req->local_id; rsp.status = A2MP_STATUS_SUCCESS; @@ -682,6 +694,8 @@ static int a2mp_chan_recv_cb(struct l2ca if (err) { struct a2mp_cmd_rej rej; + memset(&rej, 0, sizeof(rej)); + rej.reason = cpu_to_le16(0); hdr = (void *) skb->data; @@ -905,6 +919,8 @@ void a2mp_send_getinfo_rsp(struct hci_de BT_DBG("%s mgr %p", hdev->name, mgr); + memset(&rsp, 0, sizeof(rsp)); + rsp.id = hdev->id; rsp.status = A2MP_STATUS_INVALID_CTRL_ID; @@ -1002,6 +1018,8 @@ void a2mp_send_create_phy_link_rsp(struc if (!mgr) return; + memset(&rsp, 0, sizeof(rsp)); + hs_hcon = hci_conn_hash_lookup_state(hdev, AMP_LINK, BT_CONNECT); if (!hs_hcon) { rsp.status = A2MP_STATUS_UNABLE_START_LINK_CREATION; @@ -1034,6 +1052,8 @@ void a2mp_discover_amp(struct l2cap_chan mgr->bredr_chan = chan; + memset(&req, 0, sizeof(req)); + req.mtu = cpu_to_le16(L2CAP_A2MP_DEFAULT_MTU); req.ext_feat = 0; a2mp_send(mgr, A2MP_DISCOVER_REQ, 1, sizeof(req), &req);