Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755280AbbHLPRn (ORCPT ); Wed, 12 Aug 2015 11:17:43 -0400 Received: from smtp-out-194.synserver.de ([212.40.185.194]:1065 "EHLO smtp-out-194.synserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755073AbbHLPRl (ORCPT ); Wed, 12 Aug 2015 11:17:41 -0400 X-SynServer-TrustedSrc: 1 X-SynServer-AuthUser: lars@metafoo.de X-SynServer-PPID: 8920 Message-ID: <55CB6391.7060502@metafoo.de> Date: Wed, 12 Aug 2015 17:17:37 +0200 From: Lars-Peter Clausen User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Icedove/31.7.0 MIME-Version: 1.0 To: Xander Huff , jic23@kernel.org, bigeasy@linutronix.de CC: knaack.h@gmx.de, pmeerw@pmeerw.net, michal.simek@xilinx.com, soren.brinkmann@xilinx.com, linux-iio@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rt-users@vger.kernel.org, linux-kernel@vger.kernel.org, joe.hershberger@ni.com, joshc@ni.com, nathan.sullivan@ni.com, jaeden.amero@ni.com Subject: Re: [PATCH v4] iio: adc: xilinx-xadc: Push interrupts into hardirq context References: <55C07160.5040907@metafoo.de> <1439334049-28671-1-git-send-email-xander.huff@ni.com> In-Reply-To: <1439334049-28671-1-git-send-email-xander.huff@ni.com> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1638 Lines: 38 On 08/12/2015 01:00 AM, Xander Huff wrote: > The driver currently registers a pair of irq handlers using > request_threaded_irq(), however the synchronization mechanism between the > hardirq and the threadedirq handler is a regular spinlock. > > Unfortunately, this breaks PREEMPT_RT builds, where a spinlock can sleep, > and is thus not able to be acquired from a hardirq handler. This patch gets > rid of the threaded handler and pushes all interrupt handling into the > hardirq context, and uses request_irq(). > > To validate that this change has no impact on RT performance, here are > cyclictest values with no processes running: > > $ sudo cyclictest -S -m -p 98 > # /dev/cpu_dma_latency set to 0us > policy: fifo: loadavg: 0.00 0.01 0.05 1/174 2539 > T: 0 ( 1405) P:98 I:1000 C:167010520 Min: 9 Act: 12 Avg: 12 Max: 75 > T: 1 ( 1862) P:98 I:1500 C:111340339 Min: 9 Act: 12 Avg: 12 Max: 73 > > Then, all xadc raw handles were accessed in a continuous loop via > /sys/bus/iio/devices/iio:device0: > > $ sudo cyclictest -S -m -p 98 > # /dev/cpu_dma_latency set to 0us > policy: fifo: loadavg: 7.84 7.70 7.63 3/182 4260 > T: 0 ( 2559) P:98 I:1000 C:241557018 Min: 11 Act: 18 Avg: 21 Max: 74 > T: 1 ( 2560) P:98 I:1500 C:161038006 Min: 10 Act: 21 Avg: 20 Max: 73 > > Signed-off-by: Xander Huff Looks good, thanks. Acked-by: Lars-Peter Clausen -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/