Since I can't (yet) get rid of the sanity checks in config.h, I suppose I should at least update the checks.

This commit is contained in:
Gregory Nutt 2016-05-11 11:07:00 -06:00
parent b77672a049
commit 5356e3d747
3 changed files with 92 additions and 67 deletions

10
Kconfig
View File

@ -574,16 +574,6 @@ config DEBUG_INPUT
this debug option is board-specific and may not be available for this debug option is board-specific and may not be available for
some boards. some boards.
config DEBUG_DISCRETE
bool "Discrete I/O Debug Output"
default n
depends on DISCRETE_IO
---help---
Enable low level debug SYSLOG output from the discrete I/O device
drivers such as LEDs and I/O expanders (disabled by default).
Support for this debug option is board-specific and may not be
available for some boards.
config DEBUG_ANALOG config DEBUG_ANALOG
bool "Analog Device Debug Output" bool "Analog Device Debug Output"
default n default n

View File

@ -63,10 +63,10 @@
#ifndef CONFIG_DEBUG #ifndef CONFIG_DEBUG
# undef CONFIG_DEBUG_VERBOSE # undef CONFIG_DEBUG_VERBOSE
# undef CONFIG_DEBUG_DISCRETE # undef CONFIG_DEBUG_LEDS
#endif #endif
#ifdef CONFIG_DEBUG_DISCRETE #ifdef CONFIG_DEBUG_LEDS
# define ddbg lldbg # define ddbg lldbg
# ifdef CONFIG_DEBUG_VERBOSE # ifdef CONFIG_DEBUG_VERBOSE
# define dvdbg lldbg # define dvdbg lldbg

View File

@ -109,31 +109,36 @@ int main(int argc, char **argv, char **envp)
printf("#if defined(__NXFLAT__) && !defined(CONFIG_NXFLAT)\n"); printf("#if defined(__NXFLAT__) && !defined(CONFIG_NXFLAT)\n");
printf("# error \"NXFLAT support not enabled in this configuration\"\n"); printf("# error \"NXFLAT support not enabled in this configuration\"\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* NXFLAT requires PIC support in the TCBs. */\n\n"); printf("/* NXFLAT requires PIC support in the TCBs. */\n\n");
printf("#if defined(CONFIG_NXFLAT)\n"); printf("#if defined(CONFIG_NXFLAT)\n");
printf("# undef CONFIG_PIC\n"); printf("# undef CONFIG_PIC\n");
printf("# define CONFIG_PIC 1\n"); printf("# define CONFIG_PIC 1\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* Binary format support is disabled if no binary formats are\n"); printf("/* Binary format support is disabled if no binary formats are\n");
printf(" * configured (at present, NXFLAT is the only supported binary.\n"); printf(" * configured (at present, NXFLAT is the only supported binary.\n");
printf(" * format).\n"); printf(" * format).\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#if !defined(CONFIG_NXFLAT) && !defined(CONFIG_ELF) && !defined(CONFIG_BUILTIN)\n"); printf("#if !defined(CONFIG_NXFLAT) && !defined(CONFIG_ELF) && !defined(CONFIG_BUILTIN)\n");
printf("# undef CONFIG_BINFMT_DISABLE\n"); printf("# undef CONFIG_BINFMT_DISABLE\n");
printf("# define CONFIG_BINFMT_DISABLE 1\n"); printf("# define CONFIG_BINFMT_DISABLE 1\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* The correct way to disable RR scheduling is to set the\n"); printf("/* The correct way to disable RR scheduling is to set the\n");
printf(" * timeslice to zero.\n"); printf(" * timeslice to zero.\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#ifndef CONFIG_RR_INTERVAL\n"); printf("#ifndef CONFIG_RR_INTERVAL\n");
printf("# define CONFIG_RR_INTERVAL 0\n"); printf("# define CONFIG_RR_INTERVAL 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* The correct way to disable filesystem supuport is to set the number of\n"); printf("/* The correct way to disable filesystem supuport is to set the number of\n");
printf(" * file descriptors to zero.\n"); printf(" * file descriptors to zero.\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#ifndef CONFIG_NFILE_DESCRIPTORS\n"); printf("#ifndef CONFIG_NFILE_DESCRIPTORS\n");
printf("# define CONFIG_NFILE_DESCRIPTORS 0\n"); printf("# define CONFIG_NFILE_DESCRIPTORS 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If a console is selected, then make sure that there are resources for\n"); printf("/* If a console is selected, then make sure that there are resources for\n");
printf(" * three file descriptors and, if any streams are selected, also for three\n"); printf(" * three file descriptors and, if any streams are selected, also for three\n");
printf(" * file streams.\n"); printf(" * file streams.\n");
@ -158,119 +163,149 @@ int main(int argc, char **argv, char **envp)
printf("# undef CONFIG_DEV_LOWCONSOLE\n"); printf("# undef CONFIG_DEV_LOWCONSOLE\n");
printf("# undef CONFIG_RAMLOG_CONSOLE\n"); printf("# undef CONFIG_RAMLOG_CONSOLE\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If priority inheritance is disabled, then do not allocate any\n"); printf("/* If priority inheritance is disabled, then do not allocate any\n");
printf(" * associated resources.\n"); printf(" * associated resources.\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#if !defined(CONFIG_PRIORITY_INHERITANCE) || !defined(CONFIG_SEM_PREALLOCHOLDERS)\n"); printf("#if !defined(CONFIG_PRIORITY_INHERITANCE) || !defined(CONFIG_SEM_PREALLOCHOLDERS)\n");
printf("# undef CONFIG_SEM_PREALLOCHOLDERS\n"); printf("# undef CONFIG_SEM_PREALLOCHOLDERS\n");
printf("# define CONFIG_SEM_PREALLOCHOLDERS 0\n"); printf("# define CONFIG_SEM_PREALLOCHOLDERS 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("#if !defined(CONFIG_PRIORITY_INHERITANCE) || !defined(CONFIG_SEM_NNESTPRIO)\n"); printf("#if !defined(CONFIG_PRIORITY_INHERITANCE) || !defined(CONFIG_SEM_NNESTPRIO)\n");
printf("# undef CONFIG_SEM_NNESTPRIO\n"); printf("# undef CONFIG_SEM_NNESTPRIO\n");
printf("# define CONFIG_SEM_NNESTPRIO 0\n"); printf("# define CONFIG_SEM_NNESTPRIO 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If no file descriptors are configured, then make certain no\n"); printf("/* If no file descriptors are configured, then make certain no\n");
printf(" * streams are configured either.\n"); printf(" * streams are configured either.\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#if CONFIG_NFILE_DESCRIPTORS == 0\n"); printf("#if CONFIG_NFILE_DESCRIPTORS == 0\n");
printf("# undef CONFIG_NFILE_STREAMS\n"); printf("# undef CONFIG_NFILE_STREAMS\n");
printf("# define CONFIG_NFILE_STREAMS 0\n"); printf("# define CONFIG_NFILE_STREAMS 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* There must be at least one memory region. */\n\n"); printf("/* There must be at least one memory region. */\n\n");
printf("#ifndef CONFIG_MM_REGIONS\n"); printf("#ifndef CONFIG_MM_REGIONS\n");
printf("# define CONFIG_MM_REGIONS 1\n"); printf("# define CONFIG_MM_REGIONS 1\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If the end of RAM is not specified then it is assumed to be the beginning\n"); printf("/* If the end of RAM is not specified then it is assumed to be the beginning\n");
printf(" * of RAM plus the RAM size.\n"); printf(" * of RAM plus the RAM size.\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#ifndef CONFIG_RAM_END\n"); printf("#ifndef CONFIG_RAM_END\n");
printf("# define CONFIG_RAM_END (CONFIG_RAM_START+CONFIG_RAM_SIZE)\n"); printf("# define CONFIG_RAM_END (CONFIG_RAM_START+CONFIG_RAM_SIZE)\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("#ifndef CONFIG_RAM_VEND\n"); printf("#ifndef CONFIG_RAM_VEND\n");
printf("# define CONFIG_RAM_VEND (CONFIG_RAM_VSTART+CONFIG_RAM_SIZE)\n"); printf("# define CONFIG_RAM_VEND (CONFIG_RAM_VSTART+CONFIG_RAM_SIZE)\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If the end of FLASH is not specified then it is assumed to be the beginning\n"); printf("/* If the end of FLASH is not specified then it is assumed to be the beginning\n");
printf(" * of FLASH plus the FLASH size.\n"); printf(" * of FLASH plus the FLASH size.\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#ifndef CONFIG_FLASH_END\n"); printf("#ifndef CONFIG_FLASH_END\n");
printf("# define CONFIG_FLASH_END (CONFIG_FLASH_START+CONFIG_FLASH_SIZE)\n"); printf("# define CONFIG_FLASH_END (CONFIG_FLASH_START+CONFIG_FLASH_SIZE)\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If no file streams are configured, then make certain that buffered I/O\n"); printf("/* If no file streams are configured, then make certain that buffered I/O\n");
printf(" * support is disabled\n"); printf(" * support is disabled\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#if CONFIG_NFILE_STREAMS == 0\n"); printf("#if CONFIG_NFILE_STREAMS == 0\n");
printf("# undef CONFIG_STDIO_BUFFER_SIZE\n"); printf("# undef CONFIG_STDIO_BUFFER_SIZE\n");
printf("# define CONFIG_STDIO_BUFFER_SIZE 0\n"); printf("# define CONFIG_STDIO_BUFFER_SIZE 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If no standard C buffered I/O is not supported, then line-oriented buffering\n"); printf("/* If no standard C buffered I/O is not supported, then line-oriented buffering\n");
printf(" * cannot be supported.\n"); printf(" * cannot be supported.\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#if CONFIG_STDIO_BUFFER_SIZE == 0\n"); printf("#if CONFIG_STDIO_BUFFER_SIZE == 0\n");
printf("# undef CONFIG_STDIO_LINEBUFFER\n"); printf("# undef CONFIG_STDIO_LINEBUFFER\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If the maximum message size is zero, then we assume that message queues\n"); printf("/* If the maximum message size is zero, then we assume that message queues\n");
printf(" * support should be disabled\n"); printf(" * support should be disabled\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#if !defined(CONFIG_MQ_MAXMSGSIZE) || defined(CONFIG_DISABLE_MQUEUE)\n"); printf("#if !defined(CONFIG_MQ_MAXMSGSIZE) || defined(CONFIG_DISABLE_MQUEUE)\n");
printf("# undef CONFIG_MQ_MAXMSGSIZE\n"); printf("# undef CONFIG_MQ_MAXMSGSIZE\n");
printf("# define CONFIG_MQ_MAXMSGSIZE 0\n"); printf("# define CONFIG_MQ_MAXMSGSIZE 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("#if CONFIG_MQ_MAXMSGSIZE <= 0 && !defined(CONFIG_DISABLE_MQUEUE)\n"); printf("#if CONFIG_MQ_MAXMSGSIZE <= 0 && !defined(CONFIG_DISABLE_MQUEUE)\n");
printf("# define CONFIG_DISABLE_MQUEUE 1\n"); printf("# define CONFIG_DISABLE_MQUEUE 1\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* If mountpoint support in not included, then no filesystem can be supported */\n\n"); printf("/* If mountpoint support in not included, then no filesystem can be supported */\n\n");
printf("#ifdef CONFIG_DISABLE_MOUNTPOINT\n"); printf("#ifdef CONFIG_DISABLE_MOUNTPOINT\n");
printf("# undef CONFIG_FS_FAT\n"); printf("# undef CONFIG_FS_BINFS\n");
printf("# undef CONFIG_FS_ROMFS\n"); printf("# undef CONFIG_FS_FAT\n");
printf("# undef CONFIG_FS_NXFFS\n"); printf("# undef CONFIG_FS_HOSTFS\n");
printf("# undef CONFIG_FS_SMARTFS\n"); printf("# undef CONFIG_NFS\n");
printf("# undef CONFIG_FS_BINFS\n"); printf("# undef CONFIG_FS_NXFFS\n");
printf("# undef CONFIG_NFS\n"); printf("# undef CONFIG_FS_PROCFS\n");
printf("# undef CONFIG_FS_ROMFS\n");
printf("# undef CONFIG_FS_SMARTFS\n");
printf("# undef CONFIG_FS_TMPFS\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* There can be no network support with no socket descriptors */\n\n"); printf("/* There can be no network support with no socket descriptors */\n\n");
printf("#if CONFIG_NSOCKET_DESCRIPTORS <= 0\n"); printf("#if CONFIG_NSOCKET_DESCRIPTORS <= 0\n");
printf("# undef CONFIG_NET\n"); printf("# undef CONFIG_NET\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* Conversely, if there is no network support, there is no need for\n"); printf("/* Conversely, if there is no network support, there is no need for\n");
printf(" * socket descriptors\n"); printf(" * socket descriptors\n");
printf(" */\n\n"); printf(" */\n\n");
printf("#ifndef CONFIG_NET\n"); printf("#ifndef CONFIG_NET\n");
printf("# undef CONFIG_NSOCKET_DESCRIPTORS\n"); printf("# undef CONFIG_NSOCKET_DESCRIPTORS\n");
printf("# define CONFIG_NSOCKET_DESCRIPTORS 0\n"); printf("# define CONFIG_NSOCKET_DESCRIPTORS 0\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* Protocol support can only be provided on top of basic network support */\n\n"); printf("/* Protocol support can only be provided on top of basic network support */\n\n");
printf("#ifndef CONFIG_NET\n"); printf("#ifndef CONFIG_NET\n");
printf("# undef CONFIG_NET_TCP\n"); printf("# undef CONFIG_NET_TCP\n");
printf("# undef CONFIG_NET_UDP\n"); printf("# undef CONFIG_NET_UDP\n");
printf("# undef CONFIG_NET_ICMP\n"); printf("# undef CONFIG_NET_ICMP\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* NFS client can only be provided on top of UDP network support */\n\n"); printf("/* NFS client can only be provided on top of UDP network support */\n\n");
printf("#if !defined(CONFIG_NET) || !defined(CONFIG_NET_UDP)\n"); printf("#if !defined(CONFIG_NET) || !defined(CONFIG_NET_UDP)\n");
printf("# undef CONFIG_NFS\n"); printf("# undef CONFIG_NFS\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("/* Verbose debug and sub-system debug only make sense if debug is enabled */\n\n"); printf("/* Verbose debug and sub-system debug only make sense if debug is enabled */\n\n");
printf("#ifndef CONFIG_DEBUG\n"); printf("#ifndef CONFIG_DEBUG\n");
printf("# undef CONFIG_DEBUG_VERBOSE\n"); printf("# undef CONFIG_DEBUG_VERBOSE\n");
printf("# undef CONFIG_DEBUG_SCHED\n"); printf("# undef CONFIG_DEBUG_ANALOG\n");
printf("# undef CONFIG_DEBUG_MM\n"); printf("# undef CONFIG_DEBUG_AUDIO\n");
printf("# undef CONFIG_DEBUG_PAGING\n"); printf("# undef CONFIG_DEBUG_BINFMT\n");
printf("# undef CONFIG_DEBUG_DMA\n"); printf("# undef CONFIG_DEBUG_CRYPTO\n");
printf("# undef CONFIG_DEBUG_FS\n"); printf("# undef CONFIG_DEBUG_CAN\n");
printf("# undef CONFIG_DEBUG_LIB\n"); printf("# undef CONFIG_DEBUG_DMA\n");
printf("# undef CONFIG_DEBUG_BINFMT\n"); printf("# undef CONFIG_DEBUG_FS\n");
printf("# undef CONFIG_DEBUG_NET\n"); printf("# undef CONFIG_DEBUG_GPIO\n");
printf("# undef CONFIG_DEBUG_USB\n"); printf("# undef CONFIG_DEBUG_GRAPHICS\n");
printf("# undef CONFIG_DEBUG_GRAPHICS\n"); printf("# undef CONFIG_DEBUG_HEAP\n");
printf("# undef CONFIG_DEBUG_GPIO\n"); printf("# undef CONFIG_DEBUG_I2C\n");
printf("# undef CONFIG_DEBUG_SPI\n"); printf("# undef CONFIG_DEBUG_I2S\n");
printf("# undef CONFIG_DEBUG_HEAP\n"); printf("# undef CONFIG_DEBUG_INPUT\n");
printf("#endif\n\n"); printf("# undef CONFIG_DEBUG_IRQ\n");
printf("/* User entry point. This is provided as a fall-back to keep compatibility\n"); printf("# undef CONFIG_DEBUG_LCD\n");
printf(" * with existing code, for builds which do not define CONFIG_USER_ENTRYPOINT.\n"); printf("# undef CONFIG_DEBUG_LEDS\n");
printf(" */\n\n"); printf("# undef CONFIG_DEBUG_LIB\n");
printf("#ifndef CONFIG_USER_ENTRYPOINT\n"); printf("# undef CONFIG_DEBUG_MM\n");
printf("# define CONFIG_USER_ENTRYPOINT main\n"); printf("# undef CONFIG_DEBUG_NET\n");
printf("# undef CONFIG_DEBUG_PAGING\n");
printf("# undef CONFIG_DEBUG_PWM\n");
printf("# undef CONFIG_DEBUG_RTC\n");
printf("# undef CONFIG_DEBUG_SCHED\n");
printf("# undef CONFIG_DEBUG_SDIO\n");
printf("# undef CONFIG_DEBUG_SENSORS\n");
printf("# undef CONFIG_DEBUG_SHM\n");
printf("# undef CONFIG_DEBUG_SPI\n");
printf("# undef CONFIG_DEBUG_SYSCALL\n");
printf("# undef CONFIG_DEBUG_TIMER\n");
printf("# undef CONFIG_DEBUG_USB\n");
printf("# undef CONFIG_DEBUG_WATCHDOG\n");
printf("# undef CONFIG_DEBUG_WIRELESS\n");
printf("#endif\n\n"); printf("#endif\n\n");
printf("#endif /* __INCLUDE_NUTTX_CONFIG_H */\n"); printf("#endif /* __INCLUDE_NUTTX_CONFIG_H */\n");
fclose(stream); fclose(stream);