Re: [PATCH] mips: Remove q-accessors from non-64bit platforms

From: Maciej W. Rozycki
Date: Thu Jun 20 2019 - 14:19:18 EST


On Thu, 20 Jun 2019, Paul Burton wrote:

> So this seems pretty reasonable. Build testing all our defconfigs only
> showed up one issue for decstation_defconfig & decstation_r4k_defconfig:
>
> drivers/net/fddi/defza.c: In function 'fza_reads':
> drivers/net/fddi/defza.c:88:17: error: implicit declaration of
> function 'readq_relaxed'; did you mean 'readw_relaxed'?
> [-Werror=implicit-function-declaration]
> #define readq_u readq_relaxed
> ^~~~~~~~~~~~~
> drivers/net/fddi/defza.c:126:13: note: in expansion of macro 'readq_u'
> *dst++ = readq_u(src++);
> ^~~~~~~
> drivers/net/fddi/defza.c: In function 'fza_writes':
> drivers/net/fddi/defza.c:92:18: error: implicit declaration of
> function 'writeq_relaxed'; did you mean 'writel_relaxed'?
> [-Werror=implicit-function-declaration]
> #define writeq_u writeq_relaxed
> ^~~~~~~~~~~~~~
> drivers/net/fddi/defza.c:151:4: note: in expansion of macro 'writeq_u'
> writeq_u(*src++, dst++);
> ^~~~~~~~
> CC net/core/scm.o
> cc1: some warnings being treated as errors
> make[4]: *** [scripts/Makefile.build:279: drivers/net/fddi/defza.o] Error 1
>
> These uses of readq_relaxed & writeq_relaxed are both conditional upon
> sizeof(unsigned long) == 8, ie. upon CONFIG_64BIT=y so they're not going
> to present a runtime issue but we need to provide some implementation of
> the *q accessors to keep the compiler happy.
>
> I see a few options:
>
> 1) We could just have defza.c include <io-64-nonatomic-lo-hi.h> to get
> the appropriate declarations, which should then get optimized away by
> the compiler anyway & never actually be used.

This, definitely.

> 2) We could have defza.h #define its readq_u & writeq_u macros
> differently for CONFIG_32BIT=y kernels, perhaps using
> __compiletime_error to catch any bogus use of them.
>
> 3) We could do the same in a generic header, though if nobody else has
> needed it so far & this is the only place we need it then maybe it's
> not worth it.
>
> So I'm thinking option 2 might be best, as below. Having said that I
> don't mind option 1 either - it's simple. Maciej do you have any
> preference?

The use of 64-bit operations to access option's packet memory, which is
true SRAM, i.e. no side effects, is to improve throughput only and there's
no need for atomicity here nor also any kind of barriers, except at the
conclusion. Splitting 64-bit accesses into 32-bit halves in software
would not be a functional error here.

I benchmarked it back in the day and the difference was noticeable with
actual network transmissions between loops using 32-bit (LW/SW) and 64-bit
(LD/SD) accesses respectively, though I may not be able to track down the
figures anymore as it must have been some 18 years ago. The performance
of the MB ASIC used to interface the R4400 CPU to DRAM and TURBOchannel
with the 5000/260 systems was stellar as it was specifically designed with
high throughput in mind, as an upgrade to the exiting R3400-based 5000/240
systems (the CPU and the ASIC are both on a daughtercard), though new such
machines used to be sold as well.

For the record the CPU and TURBOchannel run at 60MHz (40MHz with the
R3400) and 25MHz respectively with these systems.

Thanks for the heads-up!

Maciej