RE: [PATCH] gpio:asm28xx-18xx: new driver

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Bjorn Helgaas,
    Thank for your detailed explanation and benefited me a lot.
  I am sorry for your confusion. As you mentioned, i have a single PCIe switch port
and also implements some GPIOs.

>Your driver looks for PCI_VENDOR_ID_ASMEDIA devices: [1b21:2824], [1b21:2812], [1b21:2806], [1b21:1824], etc).
>But I haven't found a second driver that needs to claim these devices. 
   these devices are PCIe switch port and use "pcieport" as main driver.

Hi Bartosz Golaszewski and linus Walleij,
   Thanks for your help. I almost know the problem of this driver. Sorry! This is my mistake to use driver's framework incorrectly. 

BR,
   Richard 

-----Original Message-----
From: Bjorn Helgaas <helgaas@xxxxxxxxxx> 
Sent: Saturday, June 6, 2020 1:13 AM
To: Richard Hsu <saraon640529@xxxxxxxxx>
Cc: Richard Hsu(許育彰) <Richard_Hsu@xxxxxxxxxxxxxx>; Yd Tseng(曾裕達) <Yd_Tseng@xxxxxxxxxxxxxx>; Jesse1 Chang(張國器) <Jesse1_Chang@xxxxxxxxxxxxxx>; linus.walleij@xxxxxxxxxx; bgolaszewski@xxxxxxxxxxxx; bhelgaas@xxxxxxxxxx; linux-gpio@xxxxxxxxxxxxxxx; linux-pci@xxxxxxxxxxxxxxx; Lee Jones <lee.jones@xxxxxxxxxx>
Subject: Re: [PATCH] gpio:asm28xx-18xx: new driver

[+cc Lee in case he can shed light on the MFD question below]

On Mon, Jun 01, 2020 at 03:36:04PM +0800, Richard Hsu wrote:
> Hi Bjorn Helgaas,
>  1. What are the other functions and where is the other driver?
>  >PCI bus and GPIO can be considered as two functions independently.
>  And the driver is located at drivers/gpio/gpio-amd8111.c

I'm obviously missing the point here; sorry for being slow.

drivers/gpio/gpio-amd8111.c uses for_each_pci_dev() to look for PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_8111_SMBUS [1022:746b] devices.
drivers/i2c/busses/i2c-amd756.c claims that same device using the normal PCI probe mechanism.

In this case both i2c-amd756 and gpio-amd8111 want to use the same device, so there's at least a reason why gpio-amd8111 uses the non-standard mechanism.

Your driver looks for PCI_VENDOR_ID_ASMEDIA devices: [1b21:2824], [1b21:2812], [1b21:2806], [1b21:1824], etc).  But I haven't found a second driver that needs to claim these devices.

I can't tell what any of these devices are (other than that they seem to have some GPIO).  You might want to add them to the Linux PCI database at https://pci-ids.ucw.cz/read/PC/1b21 .  If you do, then "lspci" will show the correct names for them.

You mention below that these devices are PCIe bridges.  If that's the case, they would be claimed by the "pcieport" driver in the PCI core (drivers/pci/pcie/portdrv_pci.c).  If you collect the output of "sudo lspci -vvxxxx", it would tell us whether the pcieport driver will claim it.

If it does, then we have a problem because the PCIe port services (AER, PME, DPC, etc) currently require pcieport.  If you want the AER, PME, etc functionality in addition to GPIO, then we have to figure out how to coordinate things.

>  2.We end up with multiple drivers controlling the device without any 
> coordination between them?
>  >Yes,because two functions are independently in the device,and the 
> main driver for PCI bus function is more important.We wish they can't 
> be affected and coordinated between two drivers as much as possible.If 
> main driver is affected,it is more serious.
>  In our case,we have gpio registers on pci configuration space of 
> asm28xx pci-e bridge(with main pci bus driver).If we want to use it by 
> another driver that use gpio subsystem /sys/class/ gpio/(sysfs 
> interface).I find the driver(gpio-amd8111.c) that meet our 
> request.Sorry! i am not best friend with git,and reply mail in the 
> same way.
> 
> 
> Hi Bartosz Golaszewski,
>  Thank you.And i have studied PCI MFD device in drivers/mfd.

I'm not familiar with drivers/mfd.  It looks like it might be useful for cases where a single PCI function implements multiple sorts of functionality.

But if the problem is that you have a single function that is a PCIe switch port and also implements some GPIOs, I doubt drivers/mfd will help.  In that case, both the existing pcieport driver and your new gpio-asm28xx-18xx driver would need to operate the same function, and we'd have to make some significant changes to both of them to fit into the MFD framework.

Long-term, I think it would be good to move the pcieport things directly into the PCI core instead of being a separate driver.  We've tripped over this problem before with things like performance counters in PCIe ports.

> Maybe,it is not what i am looking for.This type of device include core 
> and miscellaneous function drivers.And function drivers export 
> resources(io/mem/dma) to sysfs.Fist,we can't implement another pci bus 
> driver as core driver,and secondly, it don't use gpio subsystem with 
> /sys/class/gpio/(sysfs interface).
>  So,you will review this driver and upstream to mainline kernel?
==================================================================================================================
This email and any attachments to it contain confidential information and are intended solely for the use of the individual to whom it 
is addressed.If you are not the intended recipient or receive it accidentally, please immediately notify the sender by e-mail and delete 
the message and any attachments from your computer system, and destroy all hard copies. If any, please be advised that any unauthorized 
disclosure, copying, distribution or any action taken or omitted in reliance on this, is illegal and prohibited. Furthermore, any views 
or opinions expressed are solely those of the author and do not represent those of ASMedia Technology Inc. Thank you for your cooperation.
==================================================================================================================




[Index of Archives]     [DMA Engine]     [Linux Coverity]     [Linux USB]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Greybus]

  Powered by Linux