Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3710016pxk; Tue, 29 Sep 2020 04:26:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzd57Qb47+nsIEcgBthDoSbOM3ejQlCpr9yGaplNtqusxUZSlRs2lKEpoxF2YGtOscwx577 X-Received: by 2002:a05:6402:1d05:: with SMTP id dg5mr2618968edb.67.1601378812642; Tue, 29 Sep 2020 04:26:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601378812; cv=none; d=google.com; s=arc-20160816; b=tc50BlI/xj/ab8IGGyPGwjlXcRQk3K0QfLDvBDPTif8g9V2sZ5IEYqBsk+8HkoZzyl fjaM8aJ27e+EXTrIL3cf6k4y8LH/yBMryvLVa0AgpjtXqyNsHKm4BVpooc5Jm1pqyLoF aPepiuLUWPiC5NdCRVDIi4+KHh8clMWoBMTxaEGIaYNco930RJucSDO97zKP3s3XJG2c 8KP3ORISyPeDneZ84jfHJmxpqU7kAycYbjPqKjtWZTQEQM3eHFUQq1VnJ4PpflsPGqbu XkCnbZygdmqFXMP4I1L2SeJOX+RbHkm5AmJD/yM6jm/G+tOU3010F23Pg+KNe9Fmloac 2YHQ== 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=E50JvWH63IY4eXJvdZ399pOIzFoCo01UXa5fjn91qf4=; b=u7KiI3vgJYe1IPyWAZNFYlO3E9LkmG83Cz4ubUP2mdGqd/NsAL8Wdaks21zzr+4lGm KH8LzcZ2jr5owJKTQvl28Huc+AZHF2FaHKjBfVZo6I1jKtB40+O0E7eamZLnVLrFoZhA +egP4qIb2c+3RjmpfUc5K6SmhaOcFkMmhhdGKGYNGBDp4Mm1nlLPrczlz2E6vSGB7rmg YPFzTt0fcsDrz8vbv2bbabklhTV8+pssabTvGmvHxMrEq4IDbLhtJedQwiqarGg+bH1d 1n2LktUfFRnCF2T3ILSdPHdnomctub5uOVrcRV01dEVFC0VxOP0C5ZnCDN+7MpqEHKCp bB9w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="I/LaOguo"; 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 da1si2476861edb.102.2020.09.29.04.26.28; Tue, 29 Sep 2020 04:26:52 -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="I/LaOguo"; 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 S1729645AbgI2LRY (ORCPT + 99 others); Tue, 29 Sep 2020 07:17:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:33998 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729624AbgI2LRI (ORCPT ); Tue, 29 Sep 2020 07:17:08 -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 0446921D7D; Tue, 29 Sep 2020 11:17:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1601378228; bh=LTl5jy1HfdZaViFwcvCdmYJVjKxaG0vJezeAgYPRQpU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=I/LaOguonNnBPwy9uqlAcykDpQoqBTRP0e4AQJxL4CpF1yXkweWqJZzfgpNFco1x1 kSr+1VXZVOoCPYAC+w0judxLe/HNnows7Ip8zSN1KDT2kbSpHO5PF0DetR8z28c3oV HMO3yviDDKJSPA/xKGfyyiTfQXsYrsVZa/0gTKWg= 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.14 106/166] drivers: char: tlclk.c: Avoid data race between init and interrupt handler Date: Tue, 29 Sep 2020 13:00:18 +0200 Message-Id: <20200929105940.499721714@linuxfoundation.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200929105935.184737111@linuxfoundation.org> References: <20200929105935.184737111@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 6210bff46341e..52fadc46e7a97 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