kconfig/expr.h
author Zhenqiang Chen <zhenqiang.chen@linaro.org>
Fri Nov 18 16:22:52 2011 +0800 (2011-11-18)
changeset 2856 7723b8457efa
parent 1236 aba08231fe27
permissions -rw-r--r--
debug/gdb: --disable-sim for CT_GDB_CROSS.

sim was already disabled for CT_GDB_NATIVE.

Reviewed-by: Michael Hope
Signed-off-by: Zhenqiang Chen <zhenqiang.chen@linaro.org>
[yann.morin.1998@anciens.enib.fr: make it a config option]
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
yann@1
     1
/*
yann@1
     2
 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
yann@1
     3
 * Released under the terms of the GNU GPL v2.0.
yann@1
     4
 */
yann@1
     5
yann@1
     6
#ifndef EXPR_H
yann@1
     7
#define EXPR_H
yann@1
     8
yann@1
     9
#ifdef __cplusplus
yann@1
    10
extern "C" {
yann@1
    11
#endif
yann@1
    12
yann@1
    13
#include <stdio.h>
yann@1
    14
#ifndef __cplusplus
yann@1
    15
#include <stdbool.h>
yann@1
    16
#endif
yann@1
    17
yann@1
    18
struct file {
yann@1
    19
	struct file *next;
yann@1
    20
	struct file *parent;
yann@2448
    21
	const char *name;
yann@1
    22
	int lineno;
yann@1
    23
};
yann@1
    24
yann@1
    25
typedef enum tristate {
yann@1
    26
	no, mod, yes
yann@1
    27
} tristate;
yann@1
    28
yann@1
    29
enum expr_type {
yann@943
    30
	E_NONE, E_OR, E_AND, E_NOT, E_EQUAL, E_UNEQUAL, E_LIST, E_SYMBOL, E_RANGE
yann@1
    31
};
yann@1
    32
yann@1
    33
union expr_data {
yann@1
    34
	struct expr *expr;
yann@1
    35
	struct symbol *sym;
yann@1
    36
};
yann@1
    37
yann@1
    38
struct expr {
yann@1
    39
	enum expr_type type;
yann@1
    40
	union expr_data left, right;
yann@1
    41
};
yann@1
    42
yann@943
    43
#define EXPR_OR(dep1, dep2)	(((dep1)>(dep2))?(dep1):(dep2))
yann@943
    44
#define EXPR_AND(dep1, dep2)	(((dep1)<(dep2))?(dep1):(dep2))
yann@943
    45
#define EXPR_NOT(dep)		(2-(dep))
yann@943
    46
yann@943
    47
#define expr_list_for_each_sym(l, e, s) \
yann@943
    48
	for (e = (l); e && (s = e->right.sym); e = e->left.expr)
yann@1
    49
yann@1
    50
struct expr_value {
yann@1
    51
	struct expr *expr;
yann@1
    52
	tristate tri;
yann@1
    53
};
yann@1
    54
yann@1
    55
struct symbol_value {
yann@1
    56
	void *val;
yann@1
    57
	tristate tri;
yann@1
    58
};
yann@1
    59
yann@1
    60
enum symbol_type {
yann@1
    61
	S_UNKNOWN, S_BOOLEAN, S_TRISTATE, S_INT, S_HEX, S_STRING, S_OTHER
yann@1
    62
};
yann@1
    63
yann@1234
    64
/* enum values are used as index to symbol.def[] */
yann@1
    65
enum {
yann@1
    66
	S_DEF_USER,		/* main user value */
yann@1234
    67
	S_DEF_AUTO,		/* values read from auto.conf */
yann@1234
    68
	S_DEF_DEF3,		/* Reserved for UI usage */
yann@1234
    69
	S_DEF_DEF4,		/* Reserved for UI usage */
yann@1234
    70
	S_DEF_COUNT
yann@1
    71
};
yann@1
    72
yann@1
    73
struct symbol {
yann@1
    74
	struct symbol *next;
yann@1
    75
	char *name;
yann@1
    76
	enum symbol_type type;
yann@1
    77
	struct symbol_value curr;
yann@1234
    78
	struct symbol_value def[S_DEF_COUNT];
yann@1
    79
	tristate visible;
yann@1
    80
	int flags;
yann@1
    81
	struct property *prop;
yann@2448
    82
	struct expr_value dir_dep;
yann@1
    83
	struct expr_value rev_dep;
yann@1
    84
};
yann@1
    85
yann@2448
    86
#define for_all_symbols(i, sym) for (i = 0; i < SYMBOL_HASHSIZE; i++) for (sym = symbol_hash[i]; sym; sym = sym->next) if (sym->type != S_OTHER)
yann@1
    87
yann@1235
    88
#define SYMBOL_CONST      0x0001  /* symbol is const */
yann@1235
    89
#define SYMBOL_CHECK      0x0008  /* used during dependency checking */
yann@1235
    90
#define SYMBOL_CHOICE     0x0010  /* start of a choice block (null name) */
yann@1235
    91
#define SYMBOL_CHOICEVAL  0x0020  /* used as a value in a choice block */
yann@1235
    92
#define SYMBOL_VALID      0x0080  /* set when symbol.curr is calculated */
yann@1235
    93
#define SYMBOL_OPTIONAL   0x0100  /* choice is optional - values can be 'n' */
yann@1235
    94
#define SYMBOL_WRITE      0x0200  /* ? */
yann@1235
    95
#define SYMBOL_CHANGED    0x0400  /* ? */
yann@1235
    96
#define SYMBOL_AUTO       0x1000  /* value from environment variable */
yann@1235
    97
#define SYMBOL_CHECKED    0x2000  /* used during dependency checking */
yann@1235
    98
#define SYMBOL_WARNED     0x8000  /* warning has been issued */
yann@1235
    99
yann@1235
   100
/* Set when symbol.def[] is used */
yann@1235
   101
#define SYMBOL_DEF        0x10000  /* First bit of SYMBOL_DEF */
yann@1235
   102
#define SYMBOL_DEF_USER   0x10000  /* symbol.def[S_DEF_USER] is valid */
yann@1235
   103
#define SYMBOL_DEF_AUTO   0x20000  /* symbol.def[S_DEF_AUTO] is valid */
yann@1235
   104
#define SYMBOL_DEF3       0x40000  /* symbol.def[S_DEF_3] is valid */
yann@1235
   105
#define SYMBOL_DEF4       0x80000  /* symbol.def[S_DEF_4] is valid */
yann@1
   106
yann@1
   107
#define SYMBOL_MAXLENGTH	256
yann@2448
   108
#define SYMBOL_HASHSIZE		9973
yann@1
   109
yann@1236
   110
/* A property represent the config options that can be associated
yann@1236
   111
 * with a config "symbol".
yann@1236
   112
 * Sample:
yann@1236
   113
 * config FOO
yann@1236
   114
 *         default y
yann@1236
   115
 *         prompt "foo prompt"
yann@1236
   116
 *         select BAR
yann@1236
   117
 * config BAZ
yann@1236
   118
 *         int "BAZ Value"
yann@1236
   119
 *         range 1..255
yann@1236
   120
 */
yann@1
   121
enum prop_type {
yann@1236
   122
	P_UNKNOWN,
yann@1236
   123
	P_PROMPT,   /* prompt "foo prompt" or "BAZ Value" */
yann@1236
   124
	P_COMMENT,  /* text associated with a comment */
yann@1236
   125
	P_MENU,     /* prompt associated with a menuconfig option */
yann@1236
   126
	P_DEFAULT,  /* default y */
yann@1236
   127
	P_CHOICE,   /* choice value */
yann@1236
   128
	P_SELECT,   /* select BAR */
yann@1236
   129
	P_RANGE,    /* range 7..100 (for a symbol) */
yann@1236
   130
	P_ENV,      /* value from environment variable */
yann@2448
   131
	P_SYMBOL,   /* where a symbol is defined */
yann@1
   132
};
yann@1
   133
yann@1
   134
struct property {
yann@1236
   135
	struct property *next;     /* next property - null if last */
yann@1236
   136
	struct symbol *sym;        /* the symbol for which the property is associated */
yann@1236
   137
	enum prop_type type;       /* type of property */
yann@1236
   138
	const char *text;          /* the prompt value - P_PROMPT, P_MENU, P_COMMENT */
yann@1
   139
	struct expr_value visible;
yann@1236
   140
	struct expr *expr;         /* the optional conditional part of the property */
yann@1236
   141
	struct menu *menu;         /* the menu the property are associated with
yann@1236
   142
	                            * valid for: P_SELECT, P_RANGE, P_CHOICE,
yann@1236
   143
	                            * P_PROMPT, P_DEFAULT, P_MENU, P_COMMENT */
yann@1236
   144
	struct file *file;         /* what file was this property defined */
yann@1236
   145
	int lineno;                /* what lineno was this property defined */
yann@1
   146
};
yann@1
   147
yann@1
   148
#define for_all_properties(sym, st, tok) \
yann@1
   149
	for (st = sym->prop; st; st = st->next) \
yann@1
   150
		if (st->type == (tok))
yann@1
   151
#define for_all_defaults(sym, st) for_all_properties(sym, st, P_DEFAULT)
yann@1
   152
#define for_all_choices(sym, st) for_all_properties(sym, st, P_CHOICE)
yann@1
   153
#define for_all_prompts(sym, st) \
yann@1
   154
	for (st = sym->prop; st; st = st->next) \
yann@1
   155
		if (st->text)
yann@1
   156
yann@1
   157
struct menu {
yann@1
   158
	struct menu *next;
yann@1
   159
	struct menu *parent;
yann@1
   160
	struct menu *list;
yann@1
   161
	struct symbol *sym;
yann@1
   162
	struct property *prompt;
yann@2448
   163
	struct expr *visibility;
yann@1
   164
	struct expr *dep;
yann@1
   165
	unsigned int flags;
yann@943
   166
	char *help;
yann@1
   167
	struct file *file;
yann@1
   168
	int lineno;
yann@1
   169
	void *data;
yann@1
   170
};
yann@1
   171
yann@1
   172
#define MENU_CHANGED		0x0001
yann@1
   173
#define MENU_ROOT		0x0002
yann@1
   174
yann@1
   175
#ifndef SWIG
yann@1
   176
yann@1
   177
extern struct file *file_list;
yann@1
   178
extern struct file *current_file;
yann@1
   179
struct file *lookup_file(const char *name);
yann@1
   180
yann@1
   181
extern struct symbol symbol_yes, symbol_no, symbol_mod;
yann@1
   182
extern struct symbol *modules_sym;
yann@1
   183
extern struct symbol *sym_defconfig_list;
yann@1
   184
extern int cdebug;
yann@1
   185
struct expr *expr_alloc_symbol(struct symbol *sym);
yann@1
   186
struct expr *expr_alloc_one(enum expr_type type, struct expr *ce);
yann@1
   187
struct expr *expr_alloc_two(enum expr_type type, struct expr *e1, struct expr *e2);
yann@1
   188
struct expr *expr_alloc_comp(enum expr_type type, struct symbol *s1, struct symbol *s2);
yann@1
   189
struct expr *expr_alloc_and(struct expr *e1, struct expr *e2);
yann@1
   190
struct expr *expr_alloc_or(struct expr *e1, struct expr *e2);
yann@2448
   191
struct expr *expr_copy(const struct expr *org);
yann@1
   192
void expr_free(struct expr *e);
yann@1
   193
int expr_eq(struct expr *e1, struct expr *e2);
yann@1
   194
void expr_eliminate_eq(struct expr **ep1, struct expr **ep2);
yann@1
   195
tristate expr_calc_value(struct expr *e);
yann@1
   196
struct expr *expr_eliminate_yn(struct expr *e);
yann@1
   197
struct expr *expr_trans_bool(struct expr *e);
yann@1
   198
struct expr *expr_eliminate_dups(struct expr *e);
yann@1
   199
struct expr *expr_transform(struct expr *e);
yann@1
   200
int expr_contains_symbol(struct expr *dep, struct symbol *sym);
yann@1
   201
bool expr_depends_symbol(struct expr *dep, struct symbol *sym);
yann@1
   202
struct expr *expr_extract_eq_and(struct expr **ep1, struct expr **ep2);
yann@1
   203
struct expr *expr_extract_eq_or(struct expr **ep1, struct expr **ep2);
yann@1
   204
void expr_extract_eq(enum expr_type type, struct expr **ep, struct expr **ep1, struct expr **ep2);
yann@1
   205
struct expr *expr_trans_compare(struct expr *e, enum expr_type type, struct symbol *sym);
yann@2448
   206
struct expr *expr_simplify_unmet_dep(struct expr *e1, struct expr *e2);
yann@1
   207
yann@1
   208
void expr_fprint(struct expr *e, FILE *out);
yann@1
   209
struct gstr; /* forward */
yann@1
   210
void expr_gstr_print(struct expr *e, struct gstr *gs);
yann@1
   211
yann@1
   212
static inline int expr_is_yes(struct expr *e)
yann@1
   213
{
yann@1
   214
	return !e || (e->type == E_SYMBOL && e->left.sym == &symbol_yes);
yann@1
   215
}
yann@1
   216
yann@1
   217
static inline int expr_is_no(struct expr *e)
yann@1
   218
{
yann@1
   219
	return e && (e->type == E_SYMBOL && e->left.sym == &symbol_no);
yann@1
   220
}
yann@1
   221
#endif
yann@1
   222
yann@1
   223
#ifdef __cplusplus
yann@1
   224
}
yann@1
   225
#endif
yann@1
   226
yann@1
   227
#endif /* EXPR_H */