* [PATCH] MIPS: Add KSEG*ADDR definitions to CONFIG_64BIT @ 2019-12-10 17:27 Denis Efremov 2019-12-10 18:57 ` Paul Burton 0 siblings, 1 reply; 5+ messages in thread From: Denis Efremov @ 2019-12-10 17:27 UTC (permalink / raw) To: Ralf Baechle Cc: Denis Efremov, Paul Burton, James Hogan, linux-mips, linux-kernel The patch adds KSEG0ADDR, KSEG1ADDR, KSEG2ADDR, KSEG3ADDR definitions to CONFIG_64BIT ifdef. This fixes broken compilation: CC drivers/watchdog/mtx-1_wdt.o In file included from drivers/watchdog/mtx-1_wdt.c:44: ./arch/mips/include/asm/mach-au1x00/au1000.h: In function ‘alchemy_rdsys’: ./arch/mips/include/asm/mach-au1x00/au1000.h:603:36: error: implicit declaration of function ‘KSEG1ADDR’; did you mean ‘CKSEG1ADDR’? [-Werror=implicit-function-declaration] Signed-off-by: Denis Efremov <efremov@linux.com> --- arch/mips/include/asm/addrspace.h | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/arch/mips/include/asm/addrspace.h b/arch/mips/include/asm/addrspace.h index 59a48c60a065..db663654c1fd 100644 --- a/arch/mips/include/asm/addrspace.h +++ b/arch/mips/include/asm/addrspace.h @@ -65,6 +65,10 @@ #define XKSSEG _CONST64_(0x4000000000000000) #define XKPHYS _CONST64_(0x8000000000000000) #define XKSEG _CONST64_(0xc000000000000000) +#define KSEG0 _CONST64_(0xffffffff80000000) +#define KSEG1 _CONST64_(0xffffffffa0000000) +#define KSSEG _CONST64_(0xffffffffc0000000) +#define KSEG3 _CONST64_(0xffffffffe0000000) #define CKSEG0 _CONST64_(0xffffffff80000000) #define CKSEG1 _CONST64_(0xffffffffa0000000) #define CKSSEG _CONST64_(0xffffffffc0000000) @@ -75,6 +79,14 @@ #define CKSEG2ADDR(a) (CPHYSADDR(a) | CKSEG2) #define CKSEG3ADDR(a) (CPHYSADDR(a) | CKSEG3) +/* + * Map an address to a certain kernel segment + */ +#define KSEG0ADDR(a) (CPHYSADDR(a) | KSEG0) +#define KSEG1ADDR(a) (CPHYSADDR(a) | KSEG1) +#define KSEG2ADDR(a) (CPHYSADDR(a) | KSEG2) +#define KSEG3ADDR(a) (CPHYSADDR(a) | KSEG3) + #else #define CKSEG0ADDR(a) (CPHYSADDR(a) | KSEG0) -- 2.20.1 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] MIPS: Add KSEG*ADDR definitions to CONFIG_64BIT 2019-12-10 17:27 [PATCH] MIPS: Add KSEG*ADDR definitions to CONFIG_64BIT Denis Efremov @ 2019-12-10 18:57 ` Paul Burton 2019-12-10 20:14 ` Denis Efremov 0 siblings, 1 reply; 5+ messages in thread From: Paul Burton @ 2019-12-10 18:57 UTC (permalink / raw) To: Denis Efremov; +Cc: Ralf Baechle, James Hogan, linux-mips, linux-kernel Hi Denis, On Tue, Dec 10, 2019 at 08:27:39PM +0300, Denis Efremov wrote: > The patch adds KSEG0ADDR, KSEG1ADDR, KSEG2ADDR, KSEG3ADDR > definitions to CONFIG_64BIT ifdef. This fixes broken compilation: > CC drivers/watchdog/mtx-1_wdt.o > In file included from drivers/watchdog/mtx-1_wdt.c:44: > ./arch/mips/include/asm/mach-au1x00/au1000.h: In function ‘alchemy_rdsys’: > ./arch/mips/include/asm/mach-au1x00/au1000.h:603:36: error: implicit > declaration of function ‘KSEG1ADDR’; did you mean ‘CKSEG1ADDR’? > [-Werror=implicit-function-declaration] Since this driver is meant to run on a system that only supports 32 bit kernels, I think it would be better to correct its dependencies in Kconfig like so: diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig index 58e7c100b6ad..509cbb6d2cea 100644 --- a/drivers/watchdog/Kconfig +++ b/drivers/watchdog/Kconfig @@ -1648,7 +1648,7 @@ config JZ4740_WDT config WDT_MTX1 tristate "MTX-1 Hardware Watchdog" - depends on MIPS_MTX1 || (MIPS && COMPILE_TEST) + depends on MIPS_MTX1 || (MIPS && 32BIT && COMPILE_TEST) help Hardware driver for the MTX-1 boards. This is a watchdog timer that will reboot the machine after a 100 seconds timer expired. And mark this with the appropriate fixes tag: Fixes: da2a68b3eb47 ("watchdog: Enable COMPILE_TEST where possible") What do you think? Alternatively the driver could just use the existing & equivalent CKSEG1ADDR() macro as the compiler suggested, but in that case it'd be good to check that's the only change needed to build cleanly with CONFIG_64BIT=y. Thanks, Paul ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] MIPS: Add KSEG*ADDR definitions to CONFIG_64BIT 2019-12-10 18:57 ` Paul Burton @ 2019-12-10 20:14 ` Denis Efremov 2019-12-10 23:04 ` Florian Fainelli 0 siblings, 1 reply; 5+ messages in thread From: Denis Efremov @ 2019-12-10 20:14 UTC (permalink / raw) To: Paul Burton; +Cc: Ralf Baechle, James Hogan, linux-mips, linux-kernel Hi, On 10.12.2019 21:57, Paul Burton wrote: > Hi Denis, > > On Tue, Dec 10, 2019 at 08:27:39PM +0300, Denis Efremov wrote: >> The patch adds KSEG0ADDR, KSEG1ADDR, KSEG2ADDR, KSEG3ADDR >> definitions to CONFIG_64BIT ifdef. This fixes broken compilation: >> CC drivers/watchdog/mtx-1_wdt.o >> In file included from drivers/watchdog/mtx-1_wdt.c:44: >> ./arch/mips/include/asm/mach-au1x00/au1000.h: In function ‘alchemy_rdsys’: >> ./arch/mips/include/asm/mach-au1x00/au1000.h:603:36: error: implicit >> declaration of function ‘KSEG1ADDR’; did you mean ‘CKSEG1ADDR’? >> [-Werror=implicit-function-declaration] > > Since this driver is meant to run on a system that only supports 32 bit > kernels, I think it would be better to correct its dependencies in > Kconfig like so: > > diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig > index 58e7c100b6ad..509cbb6d2cea 100644 > --- a/drivers/watchdog/Kconfig > +++ b/drivers/watchdog/Kconfig > @@ -1648,7 +1648,7 @@ config JZ4740_WDT > > config WDT_MTX1 > tristate "MTX-1 Hardware Watchdog" > - depends on MIPS_MTX1 || (MIPS && COMPILE_TEST) > + depends on MIPS_MTX1 || (MIPS && 32BIT && COMPILE_TEST) > help > Hardware driver for the MTX-1 boards. This is a watchdog timer that > will reboot the machine after a 100 seconds timer expired. > > And mark this with the appropriate fixes tag: > > Fixes: da2a68b3eb47 ("watchdog: Enable COMPILE_TEST where possible") > > What do you think? > > Alternatively the driver could just use the existing & equivalent > CKSEG1ADDR() macro as the compiler suggested, but in that case it'd be > good to check that's the only change needed to build cleanly with > CONFIG_64BIT=y. > Thank you for the suggestion. I will prepare V2 and fix the same way other drivers that break the compilation with CONFIG_64BIT and missing KSEG1ADDR. > Thanks, > Paul > ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] MIPS: Add KSEG*ADDR definitions to CONFIG_64BIT 2019-12-10 20:14 ` Denis Efremov @ 2019-12-10 23:04 ` Florian Fainelli 2019-12-11 10:27 ` Denis Efremov 0 siblings, 1 reply; 5+ messages in thread From: Florian Fainelli @ 2019-12-10 23:04 UTC (permalink / raw) To: Denis Efremov, Paul Burton Cc: Ralf Baechle, James Hogan, linux-mips, linux-kernel On 12/10/19 12:14 PM, Denis Efremov wrote: > Hi, > > On 10.12.2019 21:57, Paul Burton wrote: >> Hi Denis, >> >> On Tue, Dec 10, 2019 at 08:27:39PM +0300, Denis Efremov wrote: >>> The patch adds KSEG0ADDR, KSEG1ADDR, KSEG2ADDR, KSEG3ADDR >>> definitions to CONFIG_64BIT ifdef. This fixes broken compilation: >>> CC drivers/watchdog/mtx-1_wdt.o >>> In file included from drivers/watchdog/mtx-1_wdt.c:44: >>> ./arch/mips/include/asm/mach-au1x00/au1000.h: In function ‘alchemy_rdsys’: >>> ./arch/mips/include/asm/mach-au1x00/au1000.h:603:36: error: implicit >>> declaration of function ‘KSEG1ADDR’; did you mean ‘CKSEG1ADDR’? >>> [-Werror=implicit-function-declaration] >> >> Since this driver is meant to run on a system that only supports 32 bit >> kernels, I think it would be better to correct its dependencies in >> Kconfig like so: >> >> diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig >> index 58e7c100b6ad..509cbb6d2cea 100644 >> --- a/drivers/watchdog/Kconfig >> +++ b/drivers/watchdog/Kconfig >> @@ -1648,7 +1648,7 @@ config JZ4740_WDT >> >> config WDT_MTX1 >> tristate "MTX-1 Hardware Watchdog" >> - depends on MIPS_MTX1 || (MIPS && COMPILE_TEST) >> + depends on MIPS_MTX1 || (MIPS && 32BIT && COMPILE_TEST) >> help >> Hardware driver for the MTX-1 boards. This is a watchdog timer that >> will reboot the machine after a 100 seconds timer expired. >> >> And mark this with the appropriate fixes tag: >> >> Fixes: da2a68b3eb47 ("watchdog: Enable COMPILE_TEST where possible") >> >> What do you think? >> >> Alternatively the driver could just use the existing & equivalent >> CKSEG1ADDR() macro as the compiler suggested, but in that case it'd be >> good to check that's the only change needed to build cleanly with >> CONFIG_64BIT=y. >> > > Thank you for the suggestion. I will prepare V2 and fix the same way other > drivers that break the compilation with CONFIG_64BIT and missing KSEG1ADDR. There is a much simpler solution actually: diff --git a/drivers/watchdog/mtx-1_wdt.c b/drivers/watchdog/mtx-1_wdt.c index 8aa1cb4a295f..ea1bbf5ee528 100644 --- a/drivers/watchdog/mtx-1_wdt.c +++ b/drivers/watchdog/mtx-1_wdt.c @@ -41,8 +41,6 @@ #include <linux/uaccess.h> #include <linux/gpio/consumer.h> -#include <asm/mach-au1x00/au1000.h> - #define MTX1_WDT_INTERVAL (5 * HZ) static int ticks = 100 * HZ; and then you can even push this further with: diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig index 1679e0dc869b..982897ff074e 100644 --- a/drivers/watchdog/Kconfig +++ b/drivers/watchdog/Kconfig @@ -1651,7 +1651,7 @@ config JZ4740_WDT config WDT_MTX1 tristate "MTX-1 Hardware Watchdog" - depends on MIPS_MTX1 || (MIPS && COMPILE_TEST) + depends on MIPS_MTX1 || COMPILE_TEST help Hardware driver for the MTX-1 boards. This is a watchdog timer that will reboot the machine after a 100 seconds timer expired. I checked both an alchemy, non-alchemy MIPS build as well as a x86_64 build with the two patches applied. In fact, this entire driver is just an older version of drivers/watchdog/gpio_wdt.c and should be converted to it, if only I had that box available. -- Florian ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] MIPS: Add KSEG*ADDR definitions to CONFIG_64BIT 2019-12-10 23:04 ` Florian Fainelli @ 2019-12-11 10:27 ` Denis Efremov 0 siblings, 0 replies; 5+ messages in thread From: Denis Efremov @ 2019-12-11 10:27 UTC (permalink / raw) To: Florian Fainelli, Paul Burton Cc: Ralf Baechle, James Hogan, linux-mips, linux-kernel On 12/11/19 2:04 AM, Florian Fainelli wrote: > On 12/10/19 12:14 PM, Denis Efremov wrote: >> Hi, >> >> On 10.12.2019 21:57, Paul Burton wrote: >>> Hi Denis, >>> >>> On Tue, Dec 10, 2019 at 08:27:39PM +0300, Denis Efremov wrote: >>>> The patch adds KSEG0ADDR, KSEG1ADDR, KSEG2ADDR, KSEG3ADDR >>>> definitions to CONFIG_64BIT ifdef. This fixes broken compilation: >>>> CC drivers/watchdog/mtx-1_wdt.o >>>> In file included from drivers/watchdog/mtx-1_wdt.c:44: >>>> ./arch/mips/include/asm/mach-au1x00/au1000.h: In function ‘alchemy_rdsys’: >>>> ./arch/mips/include/asm/mach-au1x00/au1000.h:603:36: error: implicit >>>> declaration of function ‘KSEG1ADDR’; did you mean ‘CKSEG1ADDR’? >>>> [-Werror=implicit-function-declaration] >>> >>> Since this driver is meant to run on a system that only supports 32 bit >>> kernels, I think it would be better to correct its dependencies in >>> Kconfig like so: >>> >>> diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig >>> index 58e7c100b6ad..509cbb6d2cea 100644 >>> --- a/drivers/watchdog/Kconfig >>> +++ b/drivers/watchdog/Kconfig >>> @@ -1648,7 +1648,7 @@ config JZ4740_WDT >>> >>> config WDT_MTX1 >>> tristate "MTX-1 Hardware Watchdog" >>> - depends on MIPS_MTX1 || (MIPS && COMPILE_TEST) >>> + depends on MIPS_MTX1 || (MIPS && 32BIT && COMPILE_TEST) >>> help >>> Hardware driver for the MTX-1 boards. This is a watchdog timer that >>> will reboot the machine after a 100 seconds timer expired. >>> >>> And mark this with the appropriate fixes tag: >>> >>> Fixes: da2a68b3eb47 ("watchdog: Enable COMPILE_TEST where possible") >>> >>> What do you think? >>> >>> Alternatively the driver could just use the existing & equivalent >>> CKSEG1ADDR() macro as the compiler suggested, but in that case it'd be >>> good to check that's the only change needed to build cleanly with >>> CONFIG_64BIT=y. >>> >> >> Thank you for the suggestion. I will prepare V2 and fix the same way other >> drivers that break the compilation with CONFIG_64BIT and missing KSEG1ADDR. > > There is a much simpler solution actually: Well, I think you know better how to fix this. I think it will be better if you prepare the patch. Your solution seems more elegant, at least to me. > > diff --git a/drivers/watchdog/mtx-1_wdt.c b/drivers/watchdog/mtx-1_wdt.c > index 8aa1cb4a295f..ea1bbf5ee528 100644 > --- a/drivers/watchdog/mtx-1_wdt.c > +++ b/drivers/watchdog/mtx-1_wdt.c > @@ -41,8 +41,6 @@ > #include <linux/uaccess.h> > #include <linux/gpio/consumer.h> > > -#include <asm/mach-au1x00/au1000.h> > - > #define MTX1_WDT_INTERVAL (5 * HZ) > > static int ticks = 100 * HZ; > > and then you can even push this further with: > > diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig > index 1679e0dc869b..982897ff074e 100644 > --- a/drivers/watchdog/Kconfig > +++ b/drivers/watchdog/Kconfig > @@ -1651,7 +1651,7 @@ config JZ4740_WDT > > config WDT_MTX1 > tristate "MTX-1 Hardware Watchdog" > - depends on MIPS_MTX1 || (MIPS && COMPILE_TEST) > + depends on MIPS_MTX1 || COMPILE_TEST > help > Hardware driver for the MTX-1 boards. This is a watchdog timer > that > will reboot the machine after a 100 seconds timer expired. > > I checked both an alchemy, non-alchemy MIPS build as well as a x86_64 > build with the two patches applied. > > In fact, this entire driver is just an older version of > drivers/watchdog/gpio_wdt.c and should be converted to it, if only I had > that box available. Thanks, Denis ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2019-12-11 10:27 UTC | newest] Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2019-12-10 17:27 [PATCH] MIPS: Add KSEG*ADDR definitions to CONFIG_64BIT Denis Efremov 2019-12-10 18:57 ` Paul Burton 2019-12-10 20:14 ` Denis Efremov 2019-12-10 23:04 ` Florian Fainelli 2019-12-11 10:27 ` Denis Efremov
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).