Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp4431181imm; Mon, 14 May 2018 07:29:39 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoVF+MJMeYyqFLVbPnTl1AAV2jaetfZnZrp2Whnf7RLCApo7THPMK9zVEqoLo3nR4HSm8qV X-Received: by 2002:a17:902:5481:: with SMTP id e1-v6mr10030953pli.137.1526308178996; Mon, 14 May 2018 07:29:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526308178; cv=none; d=google.com; s=arc-20160816; b=ojiZMFMCrt7L+Qg7Nh/gLMKjJ1EKNTpv7kp2y2Z6LP9IcwWxFcZM+Vmz8js7+iqFhA 4y9Dhz/aBWgxTwizospBWrbEHQSm67xA08VFBS6tTpMbLJKNslZRiB1D7FV1LpICKDdV 71ujLILrGku4x3ys9ze7uPTpsVFZmNAdUp0aQtIwjfvyMUj1WD0pnDmk/kn944pMPbW8 jpR/1PEUKyiCpoX0HSJF15rm+jv5jUTg8OmAsDVjsyzsWw0mzFTvn4RUXrKOCVk9AZF6 pxTvujnbNKRYiKKLNvyCeO6IC26MgZXy6YvAYx5cwbc/o64FbTcgPcOntAbN911fiTzu vfeQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=lo1LKhakxtGHYMHq+SRZZM4SNflP4PJTmCXdhAqnhow=; b=c947yCwnFS1v2xf+zFYGlmcDh8NLDu3ZF5QbJAv2aybHzgKEr2TpiSfJFJIFOGArfI v9OyaScHGWk2Foe7U5Muc+68YOlnb1gpqSx+M7xStypm6OCYEVRAkcDGI6EuDxqba4Ag IOKkwCvQNIWk1sAuN6M/kkzY4CW9jDRY4BmsMr5p5x3IhtHjHFyBYR4lsG2YUQABYQi0 dSzd/HOFxalCTEBsl13SXNW5jb07/1rGNDzAv+OBhw8ktkSll1QNd9hR3f0vx0VCaauZ Po/01AjQkm/H5wVUzaS88RkKG3rObLHmdga4XLdvDdhZ3AV5WJtGv+q7/Cycp9XrcHeC uzIg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=WYZvGCtS; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v190-v6si9533104pfb.324.2018.05.14.07.29.24; Mon, 14 May 2018 07:29:38 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=WYZvGCtS; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932570AbeENO2q (ORCPT + 99 others); Mon, 14 May 2018 10:28:46 -0400 Received: from mail-vk0-f45.google.com ([209.85.213.45]:43753 "EHLO mail-vk0-f45.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932560AbeENO2o (ORCPT ); Mon, 14 May 2018 10:28:44 -0400 Received: by mail-vk0-f45.google.com with SMTP id x191-v6so7602153vke.10 for ; Mon, 14 May 2018 07:28:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=lo1LKhakxtGHYMHq+SRZZM4SNflP4PJTmCXdhAqnhow=; b=WYZvGCtSUp7u0EA1HegjOlvIgqrMNGBifY2RD3e0Di4eboph7xtiz1OT5iDYisFACn Toyao/ZNJ7biSsrKM1w16YRwb9dUwUY5iOLfKkQrD+ybctptk6/1R4hU+Glnqjj1CGR9 oZoMixTm5NqeDPrTzws/AEBkR2m9tsYH+ZQTPL+9M5JRI0FpW31GDdAOLmA08eQqbPoc sae6dJJJFn4amyKwwV2SNYFJmrS90ODEdP/QAU4V2tUa7J97efx6/VX01KVv6ZsFeT4u 81zI/nONwgE1GWONawYzzWncPP5x2gJofkwG0DUWpthQ9T7nzJ1CEkNeks7XNrB8smoq XZmg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=lo1LKhakxtGHYMHq+SRZZM4SNflP4PJTmCXdhAqnhow=; b=tJEi7C/lT4ZKUxa3MqubufVYfWGcFKAqUlJ4erTvs54nI5uAi1Z5TL/t5iiO0OgikY dOfQPYL5CZx/++hx2oybJvXZBTIKP4zkcG6fgi62Hg19/KUnEQRthHbbFajQxXDp1dOS E+bkd28UjNUebQbjrhpomXFm9NAdkvkFB+MRUyHJzLcAck74W7zHPmNV37/S3xw4vlJO RNpEVcj/yiiE/pLDvjfWcsX8VE2efEtOj63CPVPSHKXMrRYWcob72TIOIfMGnyFyBoGu x2h5ZdiCWjplg414IkpLPuUFBSog3mikljQrCZ/U2Ss13obn6PMptoO9Ssiv8+bLShcu 5VOg== X-Gm-Message-State: ALKqPwczFV/HNcIJ1n9hKsr0b1iLf0ppJPyvoZoGRPxDRfqocX/h/5H8 OxgVLAJPzihDSLqX1jh6NnLd80ZFAezYejOdaBI= X-Received: by 2002:a1f:93c3:: with SMTP id v186-v6mr11133550vkd.67.1526308122816; Mon, 14 May 2018 07:28:42 -0700 (PDT) MIME-Version: 1.0 Received: by 10.103.144.74 with HTTP; Mon, 14 May 2018 07:28:42 -0700 (PDT) In-Reply-To: <1526303498.3494.11.camel@pengutronix.de> References: <5af57fea.1c69fb81.885f0.2377.GMRIR@mx.google.com> <20180511123915.GC16141@n2100.armlinux.org.uk> <1526303498.3494.11.camel@pengutronix.de> From: Pintu Kumar Date: Mon, 14 May 2018 19:58:42 +0530 Message-ID: Subject: Re: Delivery Status Notification (Failure) To: Lucas Stach Cc: Russell King - ARM Linux , open list , linux-arm-kernel@lists.infradead.org, kernelnewbies@kernelnewbies.org Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, May 14, 2018 at 6:41 PM, Lucas Stach wrote: > Am Montag, den 14.05.2018, 17:42 +0530 schrieb Pintu Kumar: >> Hi, >> >> Is there any work around possible to set IRQ affinity for some GPIO >> interrupt ? >> How to avoid CPU0 to receive the current GPIO interrupt ? >> How do we assign GPIO interrupts to any CPU other than CPU0 ? >> Is it possible to isolate CPU0 for a sometime, from my GPIO driver so >> that GPIO interrupt can be served by another CPU ? >> >> Need your inputs to decide whether it is still possible to set >> affinity for GPIO interrupt, or its impossible ? > > This is not possible. The GPIO IRQs are aggregated into one GPC/GIC IRQ > line per GPIO bank, so it is not possible to change affinity of a > single GPIO interrupt to another CPU. OK. Thanks for your confirmation. > Best we could do is change the > affinity of the whole bank, OK. How can we do this on the fly from my driver code. If you have any reference please let me know. This is required only for experimental purpose to prove the point to be mgmt. My idea is, from the driver, change the affinity of the whole bank. So, the GPIO interrupt can be delivered on to this specific CPU bank. Once I am done, I will revert back to the old bank. Please give me some hint on how to do this from my kernel module.... > but given the limited usefulness of > something like that, nobody bothered to implement such a thing. > > Regards, > Lucas > >> >> >> On Fri, May 11, 2018 at 8:07 PM, Pintu Kumar >> wrote: >> > On Fri, May 11, 2018 at 6:34 PM, Lucas Stach > > e> wrote: >> > > Am Freitag, den 11.05.2018, 13:39 +0100 schrieb Russell King - >> > > ARM Linux: >> > > > On Fri, May 11, 2018 at 05:07:37PM +0530, Pintu Kumar wrote: >> > > > > Hi, >> > > > > >> > > > > I need one help. >> > > > > I am using i.MX7 Sabre board with kernel version 4.1.15 >> > > > > >> > > > > Let's say I am interested in GPIO number: 21 >> > > > > I wanted to set CPU affinity for particular GPIO->IRQ number, >> > > > > so I >> > > > > tried the below steps: >> > > > > root@10:~# echo 21 > /sys/class/gpio/export >> > > > > root@10:~# echo "rising" > /sys/class/gpio/gpio21/edge >> > > > > root@10:~# cat /proc/interrupts | grep 21 >> > > > > 47: 0 0 gpio-mxc 21 Edge gpiolib >> > > > > root@10:~# cat /sys/class/gpio/gpio21/direction >> > > > > in >> > > > > root@10:~# cat /proc/irq/47/smp_affinity >> > > > > 3 >> > > > > root@10:~# echo 2 > /proc/irq/47/smp_affinity >> > > > > -bash: echo: write error: Input/output error >> > > > > >> > > > > But I get input/output error. >> > > > > When I debug further, found that irq_can_set_affinity is >> > > > > returning 0: >> > > > > [ 0.000000] genirq: irq_can_set_affinity (0): balance: 1, >> > > > > irq_data.chip: a81b7e48, irq_set_affinity: (null) >> > > > > [ 0.000000] write_irq_affinity: FAIL >> > > > > >> > > > > I also tried first setting /proc/irq/default_smp_affinity to >> > > > > 2 (from 3). >> > > > > This change is working, but the smp_affinity setting for the >> > > > > new IRQ >> > > > > is not working. >> > > > > >> > > > > When I try to set smp_affinity for mmc0, then it works. >> > > > > # cat /proc/interrupts | grep mmc >> > > > > 295: 55 0 GPCV2 22 Edge mmc0 >> > > > > 296: 0 0 GPCV2 23 Edge mmc1 >> > > > > 297: 52 0 GPCV2 24 Edge mmc2 >> > > > > >> > > > > root@10:~# echo 2 > /proc/irq/295/smp_affinity >> > > > > root@10:~# >> > > > > >> > > > > >> > > > > So, I wanted to know what are the conditions for which >> > > > > setting >> > > > > smp_affinity for an IRQ will work ? >> > > > > >> > > > > Is there any way by which I can set CPU affinity to a GPIO -> >> > > > > IRQ ? >> > > > > Whether, irq_set_affinity_hint() will work in this case ? >> > > > >> > > > IRQ affinity is only supported where interrupts are _directly_ >> > > > wired to >> > > > the GIC. It's the GIC which does the interrupt steering to the >> > > > CPU >> > > > cores. >> > > > >> > > > Interrupts on downstream interrupt controllers (such as GPCV2) >> > > > have no >> > > > ability to be directed independently to other CPUs - the only >> > > > possible >> > > > way to change the mapping is to move _all_ interrupts on that >> > > > controller, >> > > > and any downstream chained interrupts at GIC level. >> > > > >> > > > Hence why Interrupt 295 has no irq_set_affinity function: there >> > > > is no way >> > > > for the interrupt controller itself to change the affinity of >> > > > the input >> > > > interrupt. >> > > >> > > The GPCv2 though is a secondary IRQ controller which has a 1:1 >> > > mapping >> > > of its input IRQs to the upstream GIC IRQ lines. Affinity can >> > > thus be >> > > handled by forwarding the request to the GIC by >> > > irq_chip_set_affinity_parent(). >> > > >> > > As this is handled correctly in the upstream kernel since the >> > > first >> > > commit introducing support for the GPCv2, it seems the issue is >> > > only >> > > present in some downstream kernel. >> > > >> > >> > OK. Thanks so much for your reply. >> > >> > I saw some of the drivers using irq_set_affinity_hint() to force >> > the >> > IRQ affinity to a particular CPU. >> > This is the sample: >> > { >> > cpumask_clear(mask); >> > cpumask_set_cpu(cpu, mask); >> > irq_set_affinity_hint(irq, mask); >> > } >> > >> > Whether this logic will work for a particular GPIO pin ? >> > >> > >> > > Regards, >> > > Lucas