Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp5144463pxv; Wed, 28 Jul 2021 04:20:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxdhAhu2+U7mx0znCQUY4IWpWxXMrsbWXu1N+XSZSFBxgRWNBLYRS/xZr1KiaAqOovnIdO0 X-Received: by 2002:a02:ad08:: with SMTP id s8mr26239317jan.40.1627471223370; Wed, 28 Jul 2021 04:20:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627471223; cv=none; d=google.com; s=arc-20160816; b=qN5FanYSbnQZpjmetgptVdr6gKQUU1V9fxArhL734S9OrMDM83wmEIHw+LyvmiE+iK gkbePhc1kfsARcwp1b+SgMhb/5vs2VomwivTtFZWB2Y4Q7tF2Ag3wrCzTL6ok3bCcrDn NVWnijIC9FJcAsiZ4D1gF4yyhcrNnsx2t4OsnXkApM3t5Ug4cNBRLODstPjxSkaeQ4ox ohXDuWHyxdCc8wOom3jsahkywK3PcRUsx39dP+EHu1zXaK0OVC00VYF8J6epzV511WmO G1YNBjLz5w6Kcg4FDB4e0R8qUstO9W7rYhSQDX1Y3JDfEJsmlGAf2UCbmBaWV0guSdBi iLrA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:user-agent:references:in-reply-to :subject:cc:to:from:date:content-transfer-encoding:mime-version :dkim-signature; bh=7gd/q/9Efd319bq9/Xek1Wzgq86ZS5+DbyemxYnLNbM=; b=i0LE4xxHt4cpTniwmYuEYSLdjkJhsuv4psKoI0Bl3X8gkpyD4Ch0kccOnufljtiWCK 3hmV8srTsnsgcxEOagQeMQ8CPy2562v99mW6NmAdQrNiZWLKvFTJ0WFZwW1ZXBK3lZhw WpwdSe7SkuV9G9h9h7Pa7GLrnvtDbW0evTfJmEy93UhGULFDf797bqTNRtZcO27XtNsP D6PRpbuP0QJNI9M0idSXhDhYxn0MPW6RGuYlOzVjoD6nj0lxocxUEDCQCTRbT93x0eoQ miS5G8Bncf1tj+QWTxkaEaElt559YJHC53y+/keCp6kx7N+P4b2Vr1RHGU9/l44U6Cl7 iG0Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@walle.cc header.s=mail2016061301 header.b=EGpSJ0lC; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a9si6983600ilr.103.2021.07.28.04.20.11; Wed, 28 Jul 2021 04:20:23 -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=@walle.cc header.s=mail2016061301 header.b=EGpSJ0lC; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235656AbhG1LTT (ORCPT + 99 others); Wed, 28 Jul 2021 07:19:19 -0400 Received: from ssl.serverraum.org ([176.9.125.105]:49329 "EHLO ssl.serverraum.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234722AbhG1LTS (ORCPT ); Wed, 28 Jul 2021 07:19:18 -0400 Received: from ssl.serverraum.org (web.serverraum.org [172.16.0.2]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ssl.serverraum.org (Postfix) with ESMTPSA id 703A622175; Wed, 28 Jul 2021 13:19:14 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=walle.cc; s=mail2016061301; t=1627471154; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=7gd/q/9Efd319bq9/Xek1Wzgq86ZS5+DbyemxYnLNbM=; b=EGpSJ0lCMS2uDVS4hfL0F5Grk6GKZ+3lPJ/TYuKdNMDwuYvMWSDoszzP1EX+m+yDFru2f5 3F8co3OoqPGVJseQSZIdrJ14thRZ0YXF/pZtqtIGqa/ygiS/qvbFc5pZTtZhXttCF5ZU2Z 5ckhGIXV7n5uZKmyyPAxw7CMAqV4vWM= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Wed, 28 Jul 2021 13:19:14 +0200 From: Michael Walle To: Emil Renner Berthing Cc: Drew Fustini , Linus Walleij , Rob Herring , Bartosz Golaszewski , Paul Walmsley , Palmer Dabbelt , Michael Zhu , Geert Uytterhoeven , Fu Wei , linux-kernel , "open list:GPIO SUBSYSTEM" , linux-riscv , "open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS" , Huan Feng Subject: Re: [RFC PATH 2/2] gpio: starfive-jh7100: Add StarFive JH7100 GPIO driver In-Reply-To: References: <20210701002037.912625-1-drew@beagleboard.org> <20210701002037.912625-3-drew@beagleboard.org> <8c59105d32a9936f8806501ecd20e044@walle.cc> <20210726071124.GA9184@x1> <20210727052851.GA3147871@x1> User-Agent: Roundcube Webmail/1.4.11 Message-ID: X-Sender: michael@walle.cc Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am 2021-07-28 12:59, schrieb Emil Renner Berthing: > On Wed, 28 Jul 2021 at 11:49, Michael Walle wrote: >> Hi Drew, >> Am 2021-07-27 07:28, schrieb Drew Fustini: >> [..] >> >> > > Drew please look at drivers/gpio/gpio-ftgpio010.c for an example >> >> > > of GPIO_GENERIC calling bgpio_init() in probe(). >> >> > >> >> > Thank you for the suggestion. However, I am not sure that will work for >> >> > this SoC. >> >> > >> >> > The GPIO registers are described in section 12 of JH7100 datasheet [1] >> >> > and I don't think they fit the expectation of gpio-mmio.c because there >> >> > is a seperate register for each GPIO line for output data value and >> >> > output enable. >> >> > >> >> > There are 64 output data config registers which are 4 bytes wide. There >> >> > are 64 output enable config registers which are 4 bytes wide too. Output >> >> > data and output enable registers for a given GPIO pad are contiguous. >> >> > GPIO0_DOUT_CFG is 0x50 and GPIO0_DOEN_CFG is 0x54 while GPIO1_DOUT_CFG >> >> > is 0x58 and GPIO1_DOEN_CFG is 0x5C. The stride between GPIO pads is >> >> > effectively 8, which yields the formula: GPIOn_DOUT_CFG is 0x50+8n. >> >> > Similarly, GPIO0_DOEN_CFG is 0x54 and thus GPIOn_DOEN_CFG is 0x54+8n. >> >> > >> >> > However, GPIO input data does use just one bit for each line. GPIODIN_0 >> >> > at 0x48 covers GPIO[31:0] and GPIODIN_1 at 0x4c covers GPIO[63:32]. >> >> Mh, I'm not sure I'm understanding the datasheet/registers. _DOUT_CFG >> and _DOEN_CFG seem to specify the pad where this GPIO is mapped to. >> Shouldn't this be some kind of pinctrl then? Apparently you can map >> any GPIO number to any output pad, no? Or at least to all pads >> which are described in Table 11-2. What happens if two different GPIOs >> are mapped to the same pad? Bit 31 in these _CFG seems to be an invert >> bit, but what does it invert? >> >> Similar, the input GPIOs are connected to an output pad by all the >> GPI_*_CFG registers. >> >> To me it seems, that there two multiplexers for each GPIO, where >> you can connect any GPIOn to any input pad and output pad. Sound >> like a huge overkill. I must be missing something here. >> >> But what puzzles me the most, where do I set the actual GPIO output >> value? > > Yeah, it's a little confusing. The DOUT registers choose between a > number of > signals from various peripherals to control the output value of the > pin. Similarly > the DOEN registers chose between a number of signals to control the > output > enable of the pin. However, two of those signals are special in that > they are > constant 0 or constant 1. This is how you control the output value and > output > enable from software like a regular GPIO. > > You're completely right though. This ought to be managed by a proper > pinctrl > driver, and I'm working on one here: > https://github.com/esmil/linux/commits/beaglev-pinctrl Ahh, I see. So for the non-gpio function you have to set a value other than 0 or 1, correct? And as an implementation detail you have to set the corresponding OE pin if the non-gpio function will need a tristate pin (or whatever). So, the _DOUT_CFG will actually be shared between the pinctrl and the gpio driver, right? (I haven't done anything with pinctrl, so this might be a stupid question). -michael