From patchwork Mon Aug 16 20:15:44 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "F.A.Sulaiman" X-Patchwork-Id: 497784 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-16.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 5E6A1C4338F for ; Mon, 16 Aug 2021 20:16:17 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 32D6960EE4 for ; Mon, 16 Aug 2021 20:16:17 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230496AbhHPUQs (ORCPT ); Mon, 16 Aug 2021 16:16:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60966 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230204AbhHPUQr (ORCPT ); Mon, 16 Aug 2021 16:16:47 -0400 Received: from mail-pj1-x1034.google.com (mail-pj1-x1034.google.com [IPv6:2607:f8b0:4864:20::1034]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BAEB4C0613C1 for ; Mon, 16 Aug 2021 13:16:15 -0700 (PDT) Received: by mail-pj1-x1034.google.com with SMTP id bo18so28443198pjb.0 for ; Mon, 16 Aug 2021 13:16:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=itfac-mrt-ac-lk.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id; bh=uxfQfSQSFoAsFeVFiZhI4kW7ni4FlZYbGclvdDrrQVc=; b=HCopz6eKzYD/fcMJb+eHiiJqmesDIwe/gE982cJVCFDGUXqb/jGZFO10HCSwCQWgAJ jdR7gRpeVO4HhqTCw6QJ94Pz3I07kyIlZkCon9N2JHNEC6AaejLEM7tMTONIfOQ+sNmK G3j86BLUFgpJp3f9ksmUAwCtHuUtU9Rb0trDe0fSM6+LHUY7KhiF2NRlCcTKZG3QhxKb HbcDgYNeb3PmuFcqoX95RB1B1uddlrZDELi06bYOOROj+/zR963MztStaGvqbniTG3T7 1RTXRSD7ryl6AYWiPRbdD8BQKJ/J/94BHCI2ymhQdyb8bIZJrTS9ofednCvA15tCWkee 5VGQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=uxfQfSQSFoAsFeVFiZhI4kW7ni4FlZYbGclvdDrrQVc=; b=dWOZOrTKVGPNzv9w+0uShnFLC9kHd9tAbfSos9vtGyCkv4PNKQiL3y+6cwshdYzfU8 pRPOvMNixmYKT7BLraSrau7cNJnScW0FyUfZ6PqBDfpHE6Lzn+x4KcGuyFaQJW2ZdNnB S2c1x9tfSL6OeRmizCYzPny5IwzmgVvMR/oa343ptx8qpADIFh29Npo+JKKochJSWOjU 9+TSgk5i2AYZI+47wOYMhqfIh2mdW9pF5B0ClaIogmd6TdKneMCY3UC58Qoz9zf1qmwb jWkuF4PQdcVa1WK9MVZhopi2eaH+dEgyCkqOyyBMz/0evjLH8/ZtdJf4czLUm5mlqZpM 3iRg== X-Gm-Message-State: AOAM531ly/DUOEKyw9TE6ASxAq2h7MkHFFBvtjniXt4aZR2IaqpA3Rn8 ywBz1c/66/wCpc1Yd8GMFyN+ X-Google-Smtp-Source: ABdhPJxwXsCpKyomKe1LiFyRGDZbW99MV8DkQN6o+CYs5yX4LcLOCRrtGSmfXqM8BcjjFM/WacsR4A== X-Received: by 2002:a65:5a8e:: with SMTP id c14mr517569pgt.125.1629144975001; Mon, 16 Aug 2021 13:16:15 -0700 (PDT) Received: from localhost.localdomain ([123.231.122.209]) by smtp.gmail.com with ESMTPSA id y13sm6168pjn.34.2021.08.16.13.16.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 16 Aug 2021 13:16:14 -0700 (PDT) From: "F.A.Sulaiman" To: jikos@kernel.org, benjamin.tissoires@redhat.com Cc: "F.A.Sulaiman" , linux-input@vger.kernel.org, linux-kernel@vger.kernel.org, paskripkin@gmail.com Subject: [PATCH] fix slab-out-of-bounds Write in betop_probe Date: Tue, 17 Aug 2021 01:45:44 +0530 Message-Id: <20210816201544.26405-1-asha.16@itfac.mrt.ac.lk> X-Mailer: git-send-email 2.17.1 Precedence: bulk List-ID: X-Mailing-List: linux-input@vger.kernel.org This patch resolves the bug 'KASAN: slab-out-of-bounds Write in betop_probe' reported by Syzbot. This checkes hid_device's input is non empty before it's been used. Signed-off-by: F.A. SULAIMAN Reported-by: kernel test robot Reported-by: kernel test robot Reported-by: kernel test robot Reviewed-by: Pavel Skripkin --- drivers/hid/hid-betopff.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/drivers/hid/hid-betopff.c b/drivers/hid/hid-betopff.c index 467d789f9bc2..27b57aef9a0a 100644 --- a/drivers/hid/hid-betopff.c +++ b/drivers/hid/hid-betopff.c @@ -121,8 +121,18 @@ static int betopff_init(struct hid_device *hid) static int betop_probe(struct hid_device *hdev, const struct hid_device_id *id) { + struct hid_input *hidinput; + struct input_dev *dev; int ret; + if (list_empty(&hdev->inputs)) { + hid_err(hdev, "no inputs found\n"); + return -ENODEV; + } + + hidinput = list_first_entry(&hdev->inputs, struct hid_input, list); + dev = hidinput->input; + if (id->driver_data) hdev->quirks |= HID_QUIRK_MULTI_INPUT;