On 5/26/2020 3:01 PM, Andrew Lunn wrote:
>>> +/* When high resolution timers aren't built-in: we can't use
>>> usleep_range() as
>>> + * we would sleep way too long. Use udelay() instead.
>>> + */
>>> +#define mscc_readl_poll_timeout(addr, val, cond, delay_us, timeout_us)
>>> \
>>> +({ \
>>> + if (!IS_ENABLED(CONFIG_HIGH_RES_TIMERS)) \
>>> + readl_poll_timeout_atomic(addr, val, cond, delay_us, \
>>> + timeout_us); \
>>> + readl_poll_timeout(addr, val, cond, delay_us, timeout_us); \
>>> +})
>>> +
>>
>> I would make this a regular function which would not harm the compiler's
>> ability to optimize it, but would give you type checking. With that fixed:
>
> Hi Florian
>
> cond makes that difficult, since it is not a parameter in the usual
> sense, but an expression to evaluate if the polling should terminate.
>
> readl_poll_timeout() and readl_poll_timeout_atomic() themselves are
> #define's, and there are more levels of macros under them.
Oh that's right, thanks for reminding me of this.
--
Florian
- Re: [PATCH net-next 1/4] net: phy: mscc-miim: use m... Florian Fainelli
- [PATCH net-next 3/4] net: phy: mscc-miim: improve waitin... Antoine Tenart
- Re: [PATCH net-next 3/4] net: phy: mscc-miim: impro... Alexandre Belloni
- Re: [PATCH net-next 3/4] net: phy: mscc-miim: impro... Florian Fainelli
- [PATCH net-next 2/4] net: phy: mscc-miim: remove redunda... Antoine Tenart
- Re: [PATCH net-next 2/4] net: phy: mscc-miim: remov... Alexandre Belloni
- Re: [PATCH net-next 2/4] net: phy: mscc-miim: remov... Florian Fainelli
- [PATCH net-next 4/4] net: phy: mscc-miim: read poll when... Antoine Tenart
- Re: [PATCH net-next 4/4] net: phy: mscc-miim: read ... Florian Fainelli
- Re: [PATCH net-next 4/4] net: phy: mscc-miim: r... Andrew Lunn
- Re: [PATCH net-next 4/4] net: phy: mscc-mii... Florian Fainelli
- Re: [PATCH net-next 0/4] net: phy: mscc-miim: reduce wai... Andrew Lunn
- Re: [PATCH net-next 0/4] net: phy: mscc-miim: reduc... Antoine Tenart
- Re: [PATCH net-next 0/4] net: phy: mscc-miim: reduce wai... David Miller

