From: Maxime Coquelin <maxime.coquelin-qxv4g6HH51o@public.gmane.org>
To: Kishon Vijay Abraham I <kishon-l0cyMroinI0@public.gmane.org>,
Peter Griffin
<peter.griffin-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>,
linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org,
linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
srinivas.kandagatla-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org,
patrice.chotard-qxv4g6HH51o@public.gmane.org,
peppe.cavallaro-qxv4g6HH51o@public.gmane.org,
arnd-r2nGTMty4D4@public.gmane.org
Cc: lee.jones-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org,
devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
netdev-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: [PATCH v2 2/7] phy: miphy365x: Pass sysconfig register offsets via syscfg dt property.
Date: Fri, 30 Jan 2015 12:48:16 +0100 [thread overview]
Message-ID: <54CB6F80.3040906@st.com> (raw)
In-Reply-To: <54CB661A.7050706-l0cyMroinI0@public.gmane.org>
On 01/30/2015 12:08 PM, Kishon Vijay Abraham I wrote:
> Hi,
>
> On Friday 30 January 2015 04:18 PM, Maxime Coquelin wrote:
>> Hi Kishon,
>>
>> On 01/30/2015 11:35 AM, Kishon Vijay Abraham I wrote:
>>> Hi,
>>>
>>> On Wednesday 07 January 2015 08:34 PM, Peter Griffin wrote:
>>>> Based on Arnds review comments here https://lkml.org/lkml/2014/11/13/161,
>>>> update the miphy365 phy driver to access sysconfig register offsets via
>>>> syscfg dt property.
>>>>
>>>> This is because the reg property should not be mixing address spaces
>>>> like it does currently for miphy365. This change then also aligns us
>>>> to how other platforms such as keystone and bcm7445 pass there syscon
>>>> offsets via DT.
>>>>
>>>> This patch breaks DT compatibility, but this platform is considered WIP,
>>>> and is only used by a few developers who are upstreaming support for it.
>>>> This change has been done as a single atomic commit to ensure it is
>>>> bisectable.
>>> I'm dropping this from my tree since I didn't get Ack from
>>> "arch/arm/boot/dts/stih416.dtsi" Maintainer.
>> Sorry, on cover letter, I replied the series looked good to me.
>> So you can add:
>>
>> Acked-by: Maxime Coquelin <maxime.coquelin-qxv4g6HH51o@public.gmane.org>
>>
>> And even:
>>
>> Tested-by: Maxime Coquelin <maxime.coquelin-qxv4g6HH51o@public.gmane.org>
> Thanks. I'll merge them now.
> I'd assume there won't be any conflicts when it gets merged to linus tree.
Thanks Kishon,
I have merged this patch with the last DT pull-request I sent for v3.20,
and didn't had any conflicts.
So I'm confident there won't be any issue.
Br,
Maxime
>
> Cheers
> Kishon
>
>> Kind regards,
>> Maxime
>>
>>> Thanks
>>> Kishon
>>>> Signed-off-by: Peter Griffin <peter.griffin-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
>>>> Reviewed-by: Arnd Bergmann <arnd-r2nGTMty4D4@public.gmane.org>
>>>> ---
>>>> .../devicetree/bindings/phy/phy-miphy365x.txt | 15 +++++------
>>>> arch/arm/boot/dts/stih416.dtsi | 10 ++++----
>>>> drivers/phy/phy-miphy365x.c | 29
>>>> ++++++++--------------
>>>> 3 files changed, 23 insertions(+), 31 deletions(-)
>>>>
>>>> diff --git a/Documentation/devicetree/bindings/phy/phy-miphy365x.txt
>>>> b/Documentation/devicetree/bindings/phy/phy-miphy365x.txt
>>>> index 42c8808..9802d5d 100644
>>>> --- a/Documentation/devicetree/bindings/phy/phy-miphy365x.txt
>>>> +++ b/Documentation/devicetree/bindings/phy/phy-miphy365x.txt
>>>> @@ -6,8 +6,10 @@ for SATA and PCIe.
>>>> Required properties (controller (parent) node):
>>>> - compatible : Should be "st,miphy365x-phy"
>>>> -- st,syscfg : Should be a phandle of the system configuration register
>>>> group
>>>> - which contain the SATA, PCIe mode setting bits
>>>> +- st,syscfg : Phandle / integer array property. Phandle of sysconfig group
>>>> + containing the miphy registers and integer array should contain
>>>> + an entry for each port sub-node, specifying the control
>>>> + register offset inside the sysconfig group.
>>>> Required nodes : A sub-node is required for each channel the controller
>>>> provides. Address range information including the usual
>>>> @@ -26,7 +28,6 @@ Required properties (port (child) node):
>>>> registers filled in "reg":
>>>> - sata: For SATA devices
>>>> - pcie: For PCIe devices
>>>> - - syscfg: To specify the syscfg based config register
>>>> Optional properties (port (child) node):
>>>> - st,sata-gen : Generation of locally attached SATA IP.
>>>> Expected values
>>>> @@ -39,20 +40,20 @@ Example:
>>>> miphy365x_phy: miphy365x@fe382000 {
>>>> compatible = "st,miphy365x-phy";
>>>> - st,syscfg = <&syscfg_rear>;
>>>> + st,syscfg = <&syscfg_rear 0x824 0x828>;
>>>> #address-cells = <1>;
>>>> #size-cells = <1>;
>>>> ranges;
>>>> phy_port0: port@fe382000 {
>>>> - reg = <0xfe382000 0x100>, <0xfe394000 0x100>, <0x824 0x4>;
>>>> - reg-names = "sata", "pcie", "syscfg";
>>>> + reg = <0xfe382000 0x100>, <0xfe394000 0x100>;
>>>> + reg-names = "sata", "pcie";
>>>> #phy-cells = <1>;
>>>> st,sata-gen = <3>;
>>>> };
>>>> phy_port1: port@fe38a000 {
>>>> - reg = <0xfe38a000 0x100>, <0xfe804000 0x100>, <0x828 0x4>;;
>>>> + reg = <0xfe38a000 0x100>, <0xfe804000 0x100>;;
>>>> reg-names = "sata", "pcie", "syscfg";
>>>> #phy-cells = <1>;
>>>> st,pcie-tx-pol-inv;
>>>> diff --git a/arch/arm/boot/dts/stih416.dtsi b/arch/arm/boot/dts/stih416.dtsi
>>>> index fad9073..85afe01 100644
>>>> --- a/arch/arm/boot/dts/stih416.dtsi
>>>> +++ b/arch/arm/boot/dts/stih416.dtsi
>>>> @@ -283,21 +283,21 @@
>>>> miphy365x_phy: phy@fe382000 {
>>>> compatible = "st,miphy365x-phy";
>>>> - st,syscfg = <&syscfg_rear>;
>>>> + st,syscfg = <&syscfg_rear 0x824 0x828>;
>>>> #address-cells = <1>;
>>>> #size-cells = <1>;
>>>> ranges;
>>>> phy_port0: port@fe382000 {
>>>> #phy-cells = <1>;
>>>> - reg = <0xfe382000 0x100>, <0xfe394000 0x100>, <0x824 0x4>;
>>>> - reg-names = "sata", "pcie", "syscfg";
>>>> + reg = <0xfe382000 0x100>, <0xfe394000 0x100>;
>>>> + reg-names = "sata", "pcie";
>>>> };
>>>> phy_port1: port@fe38a000 {
>>>> #phy-cells = <1>;
>>>> - reg = <0xfe38a000 0x100>, <0xfe804000 0x100>, <0x828 0x4>;
>>>> - reg-names = "sata", "pcie", "syscfg";
>>>> + reg = <0xfe38a000 0x100>, <0xfe804000 0x100>;
>>>> + reg-names = "sata", "pcie";
>>>> };
>>>> };
>>>> diff --git a/drivers/phy/phy-miphy365x.c b/drivers/phy/phy-miphy365x.c
>>>> index 6ab43a8..6c80154 100644
>>>> --- a/drivers/phy/phy-miphy365x.c
>>>> +++ b/drivers/phy/phy-miphy365x.c
>>>> @@ -141,7 +141,7 @@ struct miphy365x_phy {
>>>> bool pcie_tx_pol_inv;
>>>> bool sata_tx_pol_inv;
>>>> u32 sata_gen;
>>>> - u64 ctrlreg;
>>>> + u32 ctrlreg;
>>>> u8 type;
>>>> };
>>>> @@ -179,7 +179,7 @@ static int miphy365x_set_path(struct miphy365x_phy
>>>> *miphy_phy,
>>>> bool sata = (miphy_phy->type == MIPHY_TYPE_SATA);
>>>> return regmap_update_bits(miphy_dev->regmap,
>>>> - (unsigned int)miphy_phy->ctrlreg,
>>>> + miphy_phy->ctrlreg,
>>>> SYSCFG_SELECT_SATA_MASK,
>>>> sata << SYSCFG_SELECT_SATA_POS);
>>>> }
>>>> @@ -445,7 +445,6 @@ int miphy365x_get_addr(struct device *dev, struct
>>>> miphy365x_phy *miphy_phy,
>>>> {
>>>> struct device_node *phynode = miphy_phy->phy->dev.of_node;
>>>> const char *name;
>>>> - const __be32 *taddr;
>>>> int type = miphy_phy->type;
>>>> int ret;
>>>> @@ -455,22 +454,6 @@ int miphy365x_get_addr(struct device *dev, struct
>>>> miphy365x_phy *miphy_phy,
>>>> return ret;
>>>> }
>>>> - if (!strncmp(name, "syscfg", 6)) {
>>>> - taddr = of_get_address(phynode, index, NULL, NULL);
>>>> - if (!taddr) {
>>>> - dev_err(dev, "failed to fetch syscfg address\n");
>>>> - return -EINVAL;
>>>> - }
>>>> -
>>>> - miphy_phy->ctrlreg = of_translate_address(phynode, taddr);
>>>> - if (miphy_phy->ctrlreg == OF_BAD_ADDR) {
>>>> - dev_err(dev, "failed to translate syscfg address\n");
>>>> - return -EINVAL;
>>>> - }
>>>> -
>>>> - return 0;
>>>> - }
>>>> -
>>>> if (!((!strncmp(name, "sata", 4) && type == MIPHY_TYPE_SATA) ||
>>>> (!strncmp(name, "pcie", 4) && type == MIPHY_TYPE_PCIE)))
>>>> return 0;
>>>> @@ -606,7 +589,15 @@ static int miphy365x_probe(struct platform_device *pdev)
>>>> return ret;
>>>> phy_set_drvdata(phy, miphy_dev->phys[port]);
>>>> +
>>>> port++;
>>>> + /* sysconfig offsets are indexed from 1 */
>>>> + ret = of_property_read_u32_index(np, "st,syscfg", port,
>>>> + &miphy_phy->ctrlreg);
>>>> + if (ret) {
>>>> + dev_err(&pdev->dev, "No sysconfig offset found\n");
>>>> + return ret;
>>>> + }
>>>> }
>>>> provider = devm_of_phy_provider_register(&pdev->dev, miphy365x_xlate);
>>>>
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2015-01-30 11:48 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-01-07 15:04 [PATCH v2 0/7] Fix sti drivers whcih mix reg address spaces Peter Griffin
[not found] ` <1420643052-4506-1-git-send-email-peter.griffin-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2015-01-07 15:04 ` [PATCH v2 1/7] phy: phy-stih407-usb: Pass sysconfig register offsets via syscfg property Peter Griffin
2015-01-07 15:04 ` [PATCH v2 2/7] phy: miphy365x: Pass sysconfig register offsets via syscfg dt property Peter Griffin
2015-01-30 10:35 ` Kishon Vijay Abraham I
2015-01-30 10:48 ` Maxime Coquelin
2015-01-30 11:08 ` Kishon Vijay Abraham I
[not found] ` <54CB661A.7050706-l0cyMroinI0@public.gmane.org>
2015-01-30 11:48 ` Maxime Coquelin [this message]
2015-01-07 15:04 ` [PATCH v2 4/7] ARM: STi: DT: STiH410: Add usb2 picophy dt nodes Peter Griffin
2015-01-11 23:54 ` [PATCH v2 0/7] Fix sti drivers whcih mix reg address spaces David Miller
[not found] ` <20150111.185445.1288456704842706068.davem-fT/PcQaiUtIeIZ0/mPfg9Q@public.gmane.org>
2015-01-14 12:17 ` Maxime Coquelin
2015-01-07 15:04 ` [PATCH v2 3/7] ARM: STi: DT: STiH407: Add usb2 picophy dt nodes Peter Griffin
2015-01-07 15:04 ` [PATCH v2 5/7] ARM: STi: DT: STiH410: Add DT nodes for the ehci and ohci usb controllers Peter Griffin
2015-01-07 15:04 ` [PATCH v2 6/7] ARM: multi_v7_defconfig: Enable stih407 usb picophy Peter Griffin
2015-01-07 15:04 ` [PATCH v2 7/7] stmmac: dwmac-sti: Pass sysconfig register offset via syscon dt property Peter Griffin
2015-01-09 12:45 ` [PATCH v2 0/7] Fix sti drivers whcih mix reg address spaces Maxime Coquelin
2015-01-21 8:54 ` Kishon Vijay Abraham I
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=54CB6F80.3040906@st.com \
--to=maxime.coquelin-qxv4g6hh51o@public.gmane.org \
--cc=arnd-r2nGTMty4D4@public.gmane.org \
--cc=devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=kishon-l0cyMroinI0@public.gmane.org \
--cc=lee.jones-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org \
--cc=linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org \
--cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=netdev-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=patrice.chotard-qxv4g6HH51o@public.gmane.org \
--cc=peppe.cavallaro-qxv4g6HH51o@public.gmane.org \
--cc=peter.griffin-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org \
--cc=srinivas.kandagatla-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).