diff --git a/lib.py b/lib.py index 3aa245e6..f7d20f88 100755 --- a/lib.py +++ b/lib.py @@ -169,6 +169,196 @@ def decode(byte_object): b'x' ) +# list of tokens, that are indexed as references even if no definitions are known + +always_indexed_tokens = set([ +# gcc/c-family/c-common.cc + b'_Alignas', + b'_Alignof', + b'_Atomic', + b'_BitInt', + b'_Bool', + b'_Complex', + b'_Imaginary', + b'_Float16', + b'_Float32', + b'_Float64', + b'_Float128', + b'_Float32x', + b'_Float64x', + b'_Float128x', + b'_Decimal32', + b'_Decimal64', + b'_Decimal128', + b'_Fract', + b'_Accum', + b'_Sat', + b'_Static_assert', + b'_Noreturn', + b'_Generic', + b'_Thread_local', + b'__FUNCTION__', + b'__PRETTY_FUNCTION__', + b'__alignof', + b'__alignof__', + b'__asm', + b'__asm__', + b'__attribute', + b'__attribute__', + b'__auto_type', + b'__complex', + b'__complex__', + b'__const', + b'__const__', + b'__constinit', + b'__decltype', + b'__extension__', + b'__func__', + b'__imag', + b'__imag__', + b'__inline', + b'__inline__', + b'__label__', + b'__null', + b'__real', + b'__real__', + b'__restrict', + b'__restrict__', + b'__signed', + b'__signed__', + b'__thread', + b'__transaction_atomic', + b'__transaction_relaxed', + b'__transaction_cancel', + b'__typeof', + b'__typeof__', + b'__typeof_unqual', + b'__typeof_unqual__', + b'__volatile', + b'__volatile__', + b'__GIMPLE', + b'__PHI', + b'__RTL', + b'alignas', + b'alignof', + b'asm', + b'auto', + b'thread_local', + b'sizeof', + +# https://gcc.gnu.org/onlinedocs/gcc/_005f_005fint128.html + b'__int128', + +# https://gcc.gnu.org/onlinedocs/gcc/Floating-Types.html + b'__float80', + b'__ibm128', + +# https://gcc.gnu.org/onlinedocs/gcc/Half-Precision.html + b'__fp16', + +# https://gcc.gnu.org/onlinedocs/gcc/Named-Address-Spaces.html + b'__flash', + b'__flash1', + b'__flash2', + b'__flash3', + b'__flash4', + b'__flash5', + b'__memx', + b'__far', + b'__regio_symbol', + b'__seg_fs', + b'__seg_gs', + +# https://clang.llvm.org/docs/LanguageExtensions.html#feature-checking-macros + b'__is_identifier', + +# https://clang.llvm.org/docs/LanguageExtensions.html#include-file-checking-macros + b'__BASE_FILE__', + b'__FILE_NAME__', + b'__COUNTER__', + b'__INCLUDE_LEVEL__', + b'__TIMESTAMP__', + b'__clang__', + b'__clang_major__', + b'__clang_minor__', + b'__clang_patchlevel__', + b'__clang_version__', + b'__clang_literal_encoding__', + b'__clang_wide_literal_encoding__', + +# https://clang.llvm.org/docs/LanguageExtensions.html#include-file-checking-macros + b'__datasizeof', + +# https://clang.llvm.org/docs/LanguageExtensions.html#vectors-and-extended-vectors + b'__bf16', + +# https://clang.llvm.org/docs/LanguageExtensions.html#type-trait-primitives + b'__array_rank', + b'__array_extent', + b'__can_pass_in_regs', + b'__reference_binds_to_temporary', + b'__reference_constructs_from_temporary', + b'__reference_converts_from_temporary', + b'__underlying_type', + +# https://clang.llvm.org/docs/LanguageExtensions.html#opencl-features + b'__remove_address_space', + +# https://clang.llvm.org/docs/LanguageExtensions.html#source-location-builtins + b'__LINE__', + b'__FUNCSIG__', + b'__FILE__', + +# https://clang.llvm.org/docs/LanguageExtensions.html#arm-aarch64-language-extensions + b'__dmb', + b'__dsb', + b'__isb', + +# https://en.cppreference.com/w/c/language/attributes + b'deprecated', + b'fallthrough', + b'maybe_unused', + b'nodiscard', + b'noreturn', + b'_Noreturn', + b'unsequenced', + b'reproducible' + +# https://en.cppreference.com/w/cpp/language/attributes + b'noreturn', + b'carries_dependency', + b'likely', + b'unlikely', + b'no_unique_address', + b'assume', + b'indeterminate', + b'optimize_for_synchronized', +]) + +always_indexed_prefixes = ( + b'__builtin', + +# https://gcc.gnu.org/onlinedocs/gcc/_005f_005fsync-Builtins.html + b'__sync', + +# https://gcc.gnu.org/onlinedocs/gcc/_005f_005fatomic-Builtins.html + b'__atomic', + b'__ATOMIC', + +# https://clang.llvm.org/docs/LanguageExtensions.html#feature-checking-macros +# https://clang.llvm.org/docs/LanguageExtensions.html#include-file-checking-macros + b'__has', + +# https://clang.llvm.org/docs/LanguageExtensions.html#language-extensions-back-ported-to-previous-standards + b'__cpp', + +# https://clang.llvm.org/docs/LanguageExtensions.html#type-trait-primitives + b'__is', + +# https://clang.llvm.org/docs/LanguageExtensions.html#opencl-features + b'__cl', +) + def isIdent(bstr): if (len(bstr) < 2 or bstr in blacklist or diff --git a/update.py b/update.py index ae662f93..d19f0b68 100755 --- a/update.py +++ b/update.py @@ -26,7 +26,7 @@ from threading import Thread, Lock, Event, Condition import lib -from lib import script, scriptLines +from lib import script, scriptLines, always_indexed_tokens, always_indexed_prefixes import data from data import PathList from find_compatible_dts import FindCompatibleDTS @@ -315,11 +315,16 @@ def update_references(self, idxes): if even: tok = prefix + tok - if (db.defs.exists(tok) and - not ( (idx*idx_key_mod + line_num) in defs_idxes and - defs_idxes[idx*idx_key_mod + line_num] == tok ) and - (family != 'M' or tok.startswith(b'CONFIG_'))): - # We only index CONFIG_??? in makefiles + ref_allowed = \ + db.defs.exists(tok) or \ + (tok in always_indexed_tokens) or \ + any(tok.startswith(pref) for pref in always_indexed_prefixes) + + # We only index CONFIG_??? in makefiles + config_or_not_makefile = family != 'M' or tok.startswith(b'CONFIG_') + i = idx*idx_key_mod + line_num + + if ref_allowed and defs_idxes.get(i) != tok and config_or_not_makefile: if tok in idents: idents[tok] += ',' + str(line_num) else: