realmode _WAKEUP
Alexander Kuleshov
kuleshovmail at gmail.com
Wed Jan 7 12:59:26 EST 2015
Hello Paul, thank you for answer.
Yes i saw video-*.c files, but i can't understand how compilation of
these video-*.c files depends on _WAKEUP macro...
For example if'd remove -D_WAKEUP, i get errors during realmode.elf linking:
arch/x86/realmode/rm/video-vga.o: In function `vga_probe':
/home/alex/dev/linux/arch/x86/realmode/rm/../../boot/video-vga.c:259:
undefined reference to `boot_params'
As you wrote there are many #ifndef/#endif directives, but why there
_WAKEUP is undefined everytime, but we pass it from command line with
-D_WAKEUP?
Thank you.
2015-01-07 22:54 GMT+06:00 Paul Bolle <pebolle at tiscali.nl>:
> On Wed, 2015-01-07 at 20:12 +0600, Alexander Kuleshov wrote:
>> There is following definition at arch/x86/realmode/rm/Makefile:
>>
>> KBUILD_CFLAGS := $(LINUXINCLUDE) $(REALMODE_CFLAGS) -D_SETUP -D_WAKEUP \
>> -I$(srctree)/arch/x86/boot
>>
>> Is it used now? I'm asking because _WAKEUP definition everywhere
>> undefined in the code.
>
> git grep tells me:
> $ git grep -n "_WAKEUP\b" arch/x86
> arch/x86/boot/video-bios.c:51:#ifndef _WAKEUP
> arch/x86/boot/video-bios.c:66:#ifdef _WAKEUP
> arch/x86/boot/video-mode.c:169:#ifndef _WAKEUP
> arch/x86/boot/video-vesa.c:27:#ifndef _WAKEUP
> arch/x86/boot/video-vesa.c:29:#else /* _WAKEUP */
> arch/x86/boot/video-vesa.c:31:#endif /* _WAKEUP */
> arch/x86/boot/video-vesa.c:160:#ifndef _WAKEUP
> arch/x86/boot/video-vesa.c:272:#endif /* not _WAKEUP */
> arch/x86/boot/video-vga.c:257:#ifndef _WAKEUP
> arch/x86/boot/video-vga.c:269:#ifndef _WAKEUP
>
> And in that Makefile we also see, a few lines up:
> wakeup-objs := [...] video-mode.o
> [...]
> wakeup-objs += video-vga.o
> wakeup-objs += video-vesa.o
> wakeup-objs += video-bios.o
>
> So this Makefile line defines a _WAKEUP macro that is, it seems, used
> for the build of those four object files. (It's bit more complicated
> than that. But I think KBUILD_CFLAGS is explained in Documentation/,
> isn't it?)
>
> Hope this helps,
>
>
> Paul Bolle
>
--
_________________________
0xAX
More information about the Kernelnewbies
mailing list