Re: [PATCH 6/6] ptp_ocelot: support 4 programmable pins

From: Richard Cochran
Date: Wed Mar 25 2020 - 09:41:53 EST


On Wed, Mar 25, 2020 at 03:08:46AM +0000, Y.b. Lu wrote:

> The calling should be like this,
> ptp_set_pinfunc (hold pincfg_mux)
> ---> ptp_disable_pinfunc
> ---> .enable
> ---> ptp_find_pin (hold pincfg_mux)

I see. The call

ptp_disable_pinfunc() --> .enable()

is really

ptp_disable_pinfunc() --> .enable(on=0)

or disable.

All of the other drivers (except mv88e6xxx which has a bug) avoid the
deadlock by only calling ptp_find_pin() when invoked by .enable(on=1);

Of course, that is horrible, and I am going to find a way to fix it.

For now, maybe you can drop the "programmable pins" feature for your
driver? After all, the pins are not programmable.

Thanks,
Richard