2018-12-18 21:13:35 +09:00
// SPDX-License-Identifier: GPL-2.0
2005-04-16 15:20:36 -07:00
/*
* Copyright ( C ) 2002 - 2005 Roman Zippel < zippel @ linux - m68k . org >
* Copyright ( C ) 2002 - 2005 Sam Ravnborg < sam @ ravnborg . org >
*/
2011-06-01 16:00:46 -04:00
# include <stdarg.h>
2011-06-01 16:08:14 -04:00
# include <stdlib.h>
2005-04-16 15:20:36 -07:00
# include <string.h>
2024-02-03 00:58:23 +09:00
# include "hashtable.h"
2005-04-16 15:20:36 -07:00
# include "lkc.h"
2024-02-03 00:58:22 +09:00
unsigned int strhash ( const char * s )
{
/* fnv32 hash */
unsigned int hash = 2166136261U ;
for ( ; * s ; s + + )
hash = ( hash ^ * s ) * 0x01000193 ;
return hash ;
}
2024-02-03 00:58:23 +09:00
/* hash table of all parsed Kconfig files */
static HASHTABLE_DEFINE ( file_hashtable , 1U < < 11 ) ;
2024-02-03 00:58:16 +09:00
struct file {
2024-02-03 00:58:23 +09:00
struct hlist_node node ;
2024-02-03 00:58:16 +09:00
char name [ ] ;
} ;
2005-04-16 15:20:36 -07:00
/* file already present in list? If not add it */
2024-02-03 00:58:16 +09:00
const char * file_lookup ( const char * name )
2005-04-16 15:20:36 -07:00
{
struct file * file ;
2024-02-03 00:58:15 +09:00
size_t len ;
2024-02-03 00:58:23 +09:00
int hash = strhash ( name ) ;
2005-04-16 15:20:36 -07:00
2024-02-03 00:58:23 +09:00
hash_for_each_possible ( file_hashtable , file , node , hash )
if ( ! strcmp ( name , file - > name ) )
2024-02-03 00:58:16 +09:00
return file - > name ;
2005-04-16 15:20:36 -07:00
2024-02-03 00:58:15 +09:00
len = strlen ( name ) ;
file = xmalloc ( sizeof ( * file ) + len + 1 ) ;
2005-04-16 15:20:36 -07:00
memset ( file , 0 , sizeof ( * file ) ) ;
2024-02-03 00:58:15 +09:00
memcpy ( file - > name , name , len ) ;
file - > name [ len ] = ' \0 ' ;
2024-02-03 00:58:23 +09:00
hash_add ( file_hashtable , & file - > node , hash ) ;
2024-02-03 00:58:04 +09:00
str_printf ( & autoconf_cmd , " \t %s \\ \n " , name ) ;
2024-02-03 00:58:16 +09:00
return file - > name ;
2005-04-16 15:20:36 -07:00
}
2010-02-19 12:43:44 +01:00
/* Allocate initial growable string */
2005-04-16 15:20:36 -07:00
struct gstr str_new ( void )
{
struct gstr gs ;
2012-11-06 14:32:08 +00:00
gs . s = xmalloc ( sizeof ( char ) * 64 ) ;
2008-05-18 23:10:24 +02:00
gs . len = 64 ;
2009-12-20 00:29:49 -08:00
gs . max_width = 0 ;
2005-04-16 15:20:36 -07:00
strcpy ( gs . s , " \0 " ) ;
return gs ;
}
/* Free storage for growable string */
void str_free ( struct gstr * gs )
{
2023-12-03 19:25:28 +09:00
free ( gs - > s ) ;
2005-04-16 15:20:36 -07:00
gs - > s = NULL ;
gs - > len = 0 ;
}
/* Append to growable string */
void str_append ( struct gstr * gs , const char * s )
{
2007-09-19 21:23:09 +02:00
size_t l ;
if ( s ) {
l = strlen ( gs - > s ) + strlen ( s ) + 1 ;
if ( l > gs - > len ) {
2018-02-09 01:19:07 +09:00
gs - > s = xrealloc ( gs - > s , l ) ;
2007-09-19 21:23:09 +02:00
gs - > len = l ;
}
strcat ( gs - > s , s ) ;
2005-04-16 15:20:36 -07:00
}
}
/* Append printf formatted string to growable string */
void str_printf ( struct gstr * gs , const char * fmt , . . . )
{
va_list ap ;
char s [ 10000 ] ; /* big enough... */
va_start ( ap , fmt ) ;
vsnprintf ( s , sizeof ( s ) , fmt , ap ) ;
str_append ( gs , s ) ;
va_end ( ap ) ;
}
2006-01-03 13:27:11 +01:00
/* Retrieve value of growable string */
2022-11-13 19:59:42 +09:00
char * str_get ( struct gstr * gs )
2005-04-16 15:20:36 -07:00
{
return gs - > s ;
}
2012-11-06 14:32:08 +00:00
void * xmalloc ( size_t size )
{
void * p = malloc ( size ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}
void * xcalloc ( size_t nmemb , size_t size )
{
void * p = calloc ( nmemb , size ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}
2018-02-09 01:19:07 +09:00
void * xrealloc ( void * p , size_t size )
{
p = realloc ( p , size ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}
2018-02-17 03:38:31 +09:00
char * xstrdup ( const char * s )
{
char * p ;
p = strdup ( s ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}
kconfig: reference environment variables directly and remove 'option env='
To get access to environment variables, Kconfig needs to define a
symbol using "option env=" syntax. It is tedious to add a symbol entry
for each environment variable given that we need to define much more
such as 'CC', 'AS', 'srctree' etc. to evaluate the compiler capability
in Kconfig.
Adding '$' for symbol references is grammatically inconsistent.
Looking at the code, the symbols prefixed with 'S' are expanded by:
- conf_expand_value()
This is used to expand 'arch/$ARCH/defconfig' and 'defconfig_list'
- sym_expand_string_value()
This is used to expand strings in 'source' and 'mainmenu'
All of them are fixed values independent of user configuration. So,
they can be changed into the direct expansion instead of symbols.
This change makes the code much cleaner. The bounce symbols 'SRCARCH',
'ARCH', 'SUBARCH', 'KERNELVERSION' are gone.
sym_init() hard-coding 'UNAME_RELEASE' is also gone. 'UNAME_RELEASE'
should be replaced with an environment variable.
ARCH_DEFCONFIG is a normal symbol, so it should be simply referenced
without '$' prefix.
The new syntax is addicted by Make. The variable reference needs
parentheses, like $(FOO), but you can omit them for single-letter
variables, like $F. Yet, in Makefiles, people tend to use the
parenthetical form for consistency / clarification.
At this moment, only the environment variable is supported, but I will
extend the concept of 'variable' later on.
The variables are expanded in the lexer so we can simplify the token
handling on the parser side.
For example, the following code works.
[Example code]
config MY_TOOLCHAIN_LIST
string
default "My tools: CC=$(CC), AS=$(AS), CPP=$(CPP)"
[Result]
$ make -s alldefconfig && tail -n 1 .config
CONFIG_MY_TOOLCHAIN_LIST="My tools: CC=gcc, AS=as, CPP=gcc -E"
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
Reviewed-by: Kees Cook <keescook@chromium.org>
2018-05-28 18:21:40 +09:00
char * xstrndup ( const char * s , size_t n )
{
char * p ;
p = strndup ( s , n ) ;
if ( p )
return p ;
fprintf ( stderr , " Out of memory. \n " ) ;
exit ( 1 ) ;
}