Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3701672pxk; Tue, 29 Sep 2020 04:12:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyUT4H0xqoYNgaRoMyWJjkU5I0UVgr2Vn1R1k1fmr6SuxKcsI4ekp+HT6AzBARC2YWbf29n X-Received: by 2002:a17:906:2e05:: with SMTP id n5mr1854612eji.75.1601377969028; Tue, 29 Sep 2020 04:12:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601377969; cv=none; d=google.com; s=arc-20160816; b=JEQIurdhGvvcc0FLpsHu0ndFrTYSAbirzqS4+Ys12hgTXvZBsVZ3RgBZFO5KJCkYXN xmaVLtkrNkr4kNr6UamLN+yMXgMIAXCY/Sasbi9K1WnM4IYYiDMTQee9M0SDwv1tuYLJ 8pSuCq6VCw5watWCxRBp0vZSHpe7F1ActDZbbrd/qZEyakJ5UpPRDq3lb06C0k6XyMxq BkHstofKaOvbPFlFxCLGyHcc7etytqGXkjTV+gcblRgqgN42AU64kG6Ke5cVnYBLuRmI xetsomVVifl2hvs9WyhMN83lZuvyUoPstG5PUNCSP5RCQuilBIE7oXtF/uwGhXxeQY9w /GDg== 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=e9n4wV1MHvUL+toz719wW/FcPREHRJ6TCjKQ8rnDFX4=; b=HwS4KptMQWuU4dV+cmY9G8cI3FrgNzQSqXbF0RuADdRp4b4z9xV3WelWuTuSlPtwhh xR3ErZk0FOktgqMPLeON4aKFPp6MuKAB7w1dJQIc1+fuQk2NpImHx5kL+tDE1dV0MQN4 EUZ3KpfMKd+xxNFNNA2AdaMagZHOJGIrk4BRSIEZ5b+4VP7yVY7b2PYzAUkoX/RwU3Ve ym3uqDSR127jQXFK/kZT3xXJy778aLCRhpUSNXTZ/P0Flr5quYABT4f0cTKtcyW6rf3m AZMmSHWjaMnzgj/+/bm0Z3nVNx3zB7grzEOrjnCVw1/dkYmI3RqHiYDOuYGcd4kRYuGw cBWQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=XFbuseJU; 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 di24si2409606edb.608.2020.09.29.04.12.25; Tue, 29 Sep 2020 04:12:49 -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=XFbuseJU; 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 S1728743AbgI2LKV (ORCPT + 99 others); Tue, 29 Sep 2020 07:10:21 -0400 Received: from mail.kernel.org ([198.145.29.99]:50826 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728681AbgI2LKJ (ORCPT ); Tue, 29 Sep 2020 07:10:09 -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 F220721D7F; Tue, 29 Sep 2020 11:10:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1601377808; bh=ktwXjJcoQBFeqzF3sVgSfhk9Th+iEadBnBf1ZaBJVBA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XFbuseJU17mmGfuKQrfHdh7kf7wRkrbIe83QXMGmGQ3pul5J/f4BZ1U99bUyAn+s0 CbGTREN9bgY1pKtVcfc6NPJHwF96RBZ8XYJN/R/cq02vzDJhHkWj3PwKapjyOekNVF 9ti6KZwsmlp38rartArM9an8rYT+2SdBdb3Y/QNQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Madhuparna Bhowmik , Sasha Levin Subject: [PATCH 4.9 079/121] drivers: char: tlclk.c: Avoid data race between init and interrupt handler Date: Tue, 29 Sep 2020 13:00:23 +0200 Message-Id: <20200929105934.096762923@linuxfoundation.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200929105930.172747117@linuxfoundation.org> References: <20200929105930.172747117@linuxfoundation.org> User-Agent: quilt/0.66 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: Madhuparna Bhowmik [ Upstream commit 44b8fb6eaa7c3fb770bf1e37619cdb3902cca1fc ] After registering character device the file operation callbacks can be called. The open callback registers interrupt handler. Therefore interrupt handler can execute in parallel with rest of the init function. To avoid such data race initialize telclk_interrupt variable and struct alarm_events before registering character device. Found by Linux Driver Verification project (linuxtesting.org). Signed-off-by: Madhuparna Bhowmik Link: https://lore.kernel.org/r/20200417153451.1551-1-madhuparnabhowmik10@gmail.com Signed-off-by: Greg Kroah-Hartman Signed-off-by: Sasha Levin --- drivers/char/tlclk.c | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/drivers/char/tlclk.c b/drivers/char/tlclk.c index 100cd1de9939d..59e1e94d12c01 100644 --- a/drivers/char/tlclk.c +++ b/drivers/char/tlclk.c @@ -777,17 +777,21 @@ static int __init tlclk_init(void) { int ret; + telclk_interrupt = (inb(TLCLK_REG7) & 0x0f); + + alarm_events = kzalloc( sizeof(struct tlclk_alarms), GFP_KERNEL); + if (!alarm_events) { + ret = -ENOMEM; + goto out1; + } + ret = register_chrdev(tlclk_major, "telco_clock", &tlclk_fops); if (ret < 0) { printk(KERN_ERR "tlclk: can't get major %d.\n", tlclk_major); + kfree(alarm_events); return ret; } tlclk_major = ret; - alarm_events = kzalloc( sizeof(struct tlclk_alarms), GFP_KERNEL); - if (!alarm_events) { - ret = -ENOMEM; - goto out1; - } /* Read telecom clock IRQ number (Set by BIOS) */ if (!request_region(TLCLK_BASE, 8, "telco_clock")) { @@ -796,7 +800,6 @@ static int __init tlclk_init(void) ret = -EBUSY; goto out2; } - telclk_interrupt = (inb(TLCLK_REG7) & 0x0f); if (0x0F == telclk_interrupt ) { /* not MCPBL0010 ? */ printk(KERN_ERR "telclk_interrupt = 0x%x non-mcpbl0010 hw.\n", @@ -837,8 +840,8 @@ out3: release_region(TLCLK_BASE, 8); out2: kfree(alarm_events); -out1: unregister_chrdev(tlclk_major, "telco_clock"); +out1: return ret; } -- 2.25.1