Re: [PATCH] char: nvram: disable on ARM

From: Alexandre Belloni
Date: Tue Feb 06 2018 - 20:55:19 EST


On 06/02/2018 at 23:55:02 +0100, Arnd Bergmann wrote:
> * arch/arm/kernel/time.c has this code
>
> #if defined(CONFIG_RTC_DRV_CMOS) || defined(CONFIG_RTC_DRV_CMOS_MODULE) || \
> defined(CONFIG_NVRAM) || defined(CONFIG_NVRAM_MODULE)
> /* this needs a better home */
> DEFINE_SPINLOCK(rtc_lock);
> EXPORT_SYMBOL(rtc_lock);
> #endif /* pc-style 'CMOS' RTC support */
>
> That can be adapted now, or maybe we could move all definitions into
> a common place (that needs some more planning).
>

Yes, on arm, the rtc_lock is mostly there to please
drivers/rtc/rtc-cmos.c. Maybe we could make the locking in this driver
x86 and PPC specific.

If we can get rid of arch/powerpc/platforms/chrp/time.c and
arch/powerpc/platforms/maple/time.c (so much duplicated code), then it
is x86 only.

> * similarly, this line in nvram.c can be simplified:
> #if defined(CONFIG_ATARI)
> # define MACH ATARI
> #elif defined(__i386__) || defined(__x86_64__) || defined(__arm__) /* and ?? */
> # define MACH PC
> #else
> # error Cannot build nvram driver for this machine configuration.
> #endif
>
> * GENERIC_NVRAM is not really generic, instead this seems to be the
> chardev that is used for 32-bit powerpc (powermac, 85xx, 86xx), while
> 64-bit powerpc (cell, maple, opal, pseries) use code from
> arch/powerpc/kernel/nvram_64.c, with the same underlying arch hooks.
> The nvram_64 code appears to be mostly a superset of the 32-bit
> generic_nvram one.
>
> * The code in drivers/char/nvram is not used at all when
> GENERIC_NVRAM is set, and half the code in there is different
> between x86 and atari.
>
> * most of the external interface in include/linux/nvram.h is
> unused, the rest tends to be architecture specific
>
> * The procfs file appears to be completely useless on any 64-bit
> x86 machine, this is what I see:
>
> $ cat /proc/driver/nvram
> Checksum status: valid
> # floppies : 0
> Floppy 0 type : none
> Floppy 1 type : none
> HD 0 type : none
> HD 1 type : none
> HD type 48 data: 0/0/0 C/H/S, precomp 0, lz 0
> HD type 49 data: 156/0/0 C/H/S, precomp 0, lz 0
> DOS base memory: 635 kB
> Extended memory: 65535 kB (configured), 65535 kB (tested)
> Gfx adapter : EGA, VGA, ... (with BIOS)
> FPU : not installed
>

I really don't think anyone is using that but I don't really know much
about x86 and the specification this may be part of.

I see the info may be used in drivers/video/fbdev/ and
drivers/platform/x86/thinkpad_acpi.c

--
Alexandre Belloni, Bootlin (formerly Free Electrons)
Embedded Linux and Kernel engineering
http://bootlin.com