Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3006286imu; Mon, 19 Nov 2018 09:15:41 -0800 (PST) X-Google-Smtp-Source: AFSGD/UTghwpX4xJ3rP6vRrSt+79KjgEk3FRM2jmogFXm0qAh0nQp43vMxbn9mI0tkFuo/nAnbnM X-Received: by 2002:a17:902:e012:: with SMTP id ca18mr5610788plb.218.1542647741650; Mon, 19 Nov 2018 09:15:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542647741; cv=none; d=google.com; s=arc-20160816; b=uZutHxv+PNcIBVjwRuSKm5OvlBJQ4sg3DpZCy044rKF6+PxY/2e/8jYCzkYyBkRaXE iZs39U1TkBFPtAKgwn+apBuvpj/1pNu5Jwex3w9gu6CtlRb9MJQTYK1K6BvGIZKBuxyp Qrr7Orbeg/xC3pfcE4HkjgnP5qGROYIyV0fIh6AzLn9gdiSjouJaiT7UW6lloPtkSDfN TuyJgrpMGNvElxLdA2ybq+YUhlwvR1z6KwGVenm3oCtg0St1sQfznfczKZ5TVOtJR5nh lxNrtVa4OPztXTGaSJ50EGSklfY1RsZwJll1TnE743w/gqbOWQ9epuMQ4gBFmFocTOpp S0mQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=rYbPJCu6uwleG5UUrMFXQnN/sthPJTYgoKxzE8TVnbA=; b=TlMHrSdLDlIp6ycM65w2b/cODwvAvsEjB0uCNWL6P9PwnPcMBlT/bbGiMriO8WUSKH QHwHDF5eVQxtJpjVZYfte6eSvnd7f4uHotCh0MpLSjBQLPstYLFlBtJgZSHqmuyUg63p aZF2Hpim+BEsa2FAsYTXOUOPNSJ2nRjhzimSVmveL9YzEbtwTVg8iCrkEYQzed2xVngN 0t2PZnsBU8BCYoOSFF/S9+pNEjmZP+sfGbjluJxjsRDMmvRgwr4PBRzrdCw5w64FpYh2 VTIqaSXEYV9/jCS3dWjH9ENoqvfkrntOAnfc4fx5rugDteT9SjZaClVWIUwFR6capWIB 8piA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=muvov+9y; 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 j10si40264774pgt.155.2018.11.19.09.15.25; Mon, 19 Nov 2018 09:15:41 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=default header.b=muvov+9y; 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 S2406519AbeKTD2j (ORCPT + 99 others); Mon, 19 Nov 2018 22:28:39 -0500 Received: from mail.kernel.org ([198.145.29.99]:43050 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2406494AbeKTD2i (ORCPT ); Mon, 19 Nov 2018 22:28:38 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (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 2A6E92146D; Mon, 19 Nov 2018 17:04:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542647061; bh=KAYOIM3BxHanHeiUM824R3ME1CIPfgzqSb7w4ygfFvg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=muvov+9ySiB26Xrj1YKqPKw9xolqYdzK8Pr74AeV5kP7EVbBvl+8V7BeblyQsH48k /mlJwk1FhGpDUGwZ3U7J0sKJGdbAE7YYc/COzokzjg9wSGsLqEnlaZYPX0oxEDfxTg FNEdIhKAefQZw6gOMfd80DW1Ed32jeCONPWQDB5M= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Maxime Ripard , Eugen Hristev , Ludovic Desroches , Stable@vger.kernel.org, Jonathan Cameron Subject: [PATCH 3.18 36/90] iio: adc: at91: fix acking DRDY irq on simple conversions Date: Mon, 19 Nov 2018 17:29:18 +0100 Message-Id: <20181119162626.667625701@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162620.585061184@linuxfoundation.org> References: <20181119162620.585061184@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.18-stable review patch. If anyone has any objections, please let me know. ------------------ From: Eugen Hristev commit bc1b45326223e7e890053cf6266357adfa61942d upstream. When doing simple conversions, the driver did not acknowledge the DRDY irq. If this irq status is not acked, it will be left pending, and as soon as a trigger is enabled, the irq handler will be called, it doesn't know why this status has occurred because no channel is pending, and then it will go int a irq loop and board will hang. To avoid this situation, read the LCDR after a raw conversion is done. Fixes: 0e589d5fb ("ARM: AT91: IIO: Add AT91 ADC driver.") Cc: Maxime Ripard Signed-off-by: Eugen Hristev Acked-by: Ludovic Desroches Cc: Signed-off-by: Jonathan Cameron Signed-off-by: Greg Kroah-Hartman --- drivers/iio/adc/at91_adc.c | 2 ++ 1 file changed, 2 insertions(+) --- a/drivers/iio/adc/at91_adc.c +++ b/drivers/iio/adc/at91_adc.c @@ -276,6 +276,8 @@ static void handle_adc_eoc_trigger(int i iio_trigger_poll(idev->trig); } else { st->last_value = at91_adc_readl(st, AT91_ADC_CHAN(st, st->chnb)); + /* Needed to ACK the DRDY interruption */ + at91_adc_readl(st, AT91_ADC_LCDR); st->done = true; wake_up_interruptible(&st->wq_data_avail); }