Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp816587imm; Fri, 27 Jul 2018 06:41:10 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfIAKXW5y7pymgKhZwICxkDadFOmHRA8Qx08pMeq9uioTFhq2dVcuUfuciz9jneVJTBDbj4 X-Received: by 2002:a63:3190:: with SMTP id x138-v6mr6192191pgx.60.1532698870092; Fri, 27 Jul 2018 06:41:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532698870; cv=none; d=google.com; s=arc-20160816; b=Pe00Dlh8DnOhDDu+2L4jVh6i8VWl31YWcbXTchdzuSFl0Ob8+ec7A2WrFgyuCkQdca NnhC/6/yoedlQmCvnYde39jWtT35SAF/EQq5wj5Qa2a+K21z2VuAL8RMw7cK6uEz+jDS pdbYokp3nrbdipVGfhWU91IPyJWmmQiSj2iLw5M2pcEVEUTGDp3ilj1eQU8L4+m/8MrX OeeD3wZoMYvb0yH7WHe+S654TghxDYpy8qL3Kgpf2qfZbYbsPVBuJRAc05WAUs59KkGz EDAkRu7Fe0tbiatGSMoDI8uEkEpxoGaZ2MYrerOIvaI/woMLKOQZ7/O+lqPdpBJoWVk4 sw+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :arc-authentication-results; bh=H5mt6RWBrIdXE+DkEwZF0j28/mOdzGpArOXOkS1OBC8=; b=VPNoLJR1jCEU6hkC2PJoWz+MN0vxLEujFNLOF3l1hTIK4HEh6BgHBnoxIokqrgY5Nd SRMqk8rAHN94XqV2qvU8YiSOKAQ8Nlo5hAxMkPPvws94N/s59S4bsoRGVE+NIrbFPTbx miGRoXtlo0p3mA8VGxR1F4WDqqHnN7b0ldnUB80u6SP1TtrpDpGMziA5qA2lTs7ZD3MY NS4EK5ECLkqvyuhMkXDccQKlD4UrtYKQ/I5MHFrkzffBICEYQpkP4DZXeYCKK0OPVYIs xMbVQqZ9dCMGClqfro7s6xfXslK3OgEas42T5WUiTJpTQUafi3ep2eg2BOvtIl8cKaoe csJg== 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 34-v6si3846892pgs.243.2018.07.27.06.40.55; Fri, 27 Jul 2018 06:41:10 -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 S1732619AbeG0PBn (ORCPT + 99 others); Fri, 27 Jul 2018 11:01:43 -0400 Received: from bran.ispras.ru ([83.149.199.196]:23467 "EHLO smtp.ispras.ru" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1730682AbeG0PBn (ORCPT ); Fri, 27 Jul 2018 11:01:43 -0400 Received: from myklebust.intra.ispras.ru (unknown [10.10.2.207]) by smtp.ispras.ru (Postfix) with ESMTP id E84DE203B2; Fri, 27 Jul 2018 16:39:41 +0300 (MSK) From: Anton Vasilyev To: Greg Kroah-Hartman Cc: Anton Vasilyev , Jiri Slaby , linux-kernel@vger.kernel.org, ldv-project@linuxtesting.org Subject: [PATCH] tty: rocket: Fix possible buffer overwrite on register_PCI Date: Fri, 27 Jul 2018 16:39:31 +0300 Message-Id: <20180727133931.12701-1-vasilyev@ispras.ru> X-Mailer: git-send-email 2.18.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If number of isa and pci boards exceed NUM_BOARDS on the path rp_init()->init_PCI()->register_PCI() then buffer overwrite occurs in register_PCI() on assign rcktpt_io_addr[i]. The patch adds check on upper bound for index of registered board in register_PCI. Found by Linux Driver Verification project (linuxtesting.org). Signed-off-by: Anton Vasilyev --- drivers/tty/rocket.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/tty/rocket.c b/drivers/tty/rocket.c index bdd17d2aaafd..b121d8f8f3d7 100644 --- a/drivers/tty/rocket.c +++ b/drivers/tty/rocket.c @@ -1881,7 +1881,7 @@ static __init int register_PCI(int i, struct pci_dev *dev) ByteIO_t UPCIRingInd = 0; if (!dev || !pci_match_id(rocket_pci_ids, dev) || - pci_enable_device(dev)) + pci_enable_device(dev) || i >= NUM_BOARDS) return 0; rcktpt_io_addr[i] = pci_resource_start(dev, 0); -- 2.18.0