1a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# this module contains all the defaults used by the generation of cleaned-up headers
2a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# for the Bionic C library
3a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project#
4a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
5a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectimport time, os, sys
6a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectfrom utils import *
7a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
8a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# the list of supported architectures
9d1973ca51325393f304e82a4d79874f33e54ac16Colin Crosskernel_archs = [ 'arm', 'arm64', 'mips', 'x86' ]
10a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
11a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# the list of include directories that belong to the kernel
12a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# tree. used when looking for sources...
13a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectkernel_dirs = [ "linux", "asm", "asm-generic", "mtd" ]
14a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
15a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# path to the directory containing the original kernel headers
16fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turnerkernel_original_path = os.path.normpath( find_program_dir() + '/../../../../external/kernel-headers/original' )
17fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner
18fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner# path to the default location of the cleaned-up headers
19fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turnerkernel_cleaned_path = os.path.normpath( find_program_dir() + '/..' )
20a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
21a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# a special value that is used to indicate that a given macro is known to be
22a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# undefined during optimization
23a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source ProjectkCppUndefinedMacro = "<<<undefined>>>"
24a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
25a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# this is the set of known macros we want to totally optimize out from the
26a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# final headers
27a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectkernel_known_macros = {
28a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    "__KERNEL__": kCppUndefinedMacro,
29a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    "__KERNEL_STRICT_NAMES":"1",
30a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    "__CHECKER__": kCppUndefinedMacro,
31a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    "__CHECK_ENDIAN__": kCppUndefinedMacro,
329195a258ee96d6cf31b2fc7db9da16f92f5e7f65Elliott Hughes    "CONFIG_64BIT": "__LP64__",
33d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes    "CONFIG_X86_32": "__i386__",
34460fa7033b17c49e3e6fdaee49eb6d7d666e16d9Ben Cheng    "__EXPORTED_HEADERS__": "1",
35a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    }
36a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
37a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# define to true if you want to remove all defined(CONFIG_FOO) tests
38a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# from the clean headers. testing shows that this is not strictly necessary
39a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# but just generates cleaner results
40a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectkernel_remove_config_macros = True
41a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
424e468ed2eb86a2406e14f1eca82072ee501d05fdThe Android Open Source Project# maps an architecture to a set of default macros that would be provided by
434e468ed2eb86a2406e14f1eca82072ee501d05fdThe Android Open Source Project# toolchain preprocessor
444e468ed2eb86a2406e14f1eca82072ee501d05fdThe Android Open Source Projectkernel_default_arch_macros = {
458ed7a23309cd6f1a73c19a23ade2e11ab31fcb2fElliott Hughes    "arm": {"__ARMEB__": kCppUndefinedMacro, "__ARM_EABI__": "1"},
46d1973ca51325393f304e82a4d79874f33e54ac16Colin Cross    "arm64": {},
47a69eaec4d48e978751356b2e8fd989d5e23a34dbDuane Sand    "mips": {"__MIPSEB__": kCppUndefinedMacro,
48a69eaec4d48e978751356b2e8fd989d5e23a34dbDuane Sand             "__MIPSEL__": "1",
49a69eaec4d48e978751356b2e8fd989d5e23a34dbDuane Sand             "CONFIG_32BIT": "_ABIO32",
50a69eaec4d48e978751356b2e8fd989d5e23a34dbDuane Sand             "CONFIG_CPU_LITTLE_ENDIAN": "1",
51a69eaec4d48e978751356b2e8fd989d5e23a34dbDuane Sand             "__SANE_USERSPACE_TYPES__": "1",},
52d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes    "x86": {},
534e468ed2eb86a2406e14f1eca82072ee501d05fdThe Android Open Source Project    }
544e468ed2eb86a2406e14f1eca82072ee501d05fdThe Android Open Source Project
55a864c2c23486e4ab7235829d8c9574426794298aRaghu Gandhamkernel_arch_token_replacements = {
56a864c2c23486e4ab7235829d8c9574426794298aRaghu Gandham    "arm": {},
57d1973ca51325393f304e82a4d79874f33e54ac16Colin Cross    "arm64": {},
58a864c2c23486e4ab7235829d8c9574426794298aRaghu Gandham    "mips": {"off_t":"__kernel_off_t"},
59d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes    "x86": {},
60a864c2c23486e4ab7235829d8c9574426794298aRaghu Gandham    }
61199346a2abd8b6ba282e1fe291cc3766fa921f40Elliott Hughes
62c9205dba43c45dc5a185aa26e1160c3f62e9b471Martin Storsjo# Replace tokens in the output according to this mapping
63c9205dba43c45dc5a185aa26e1160c3f62e9b471Martin Storsjokernel_token_replacements = {
64b969b5a32a3924412b3584a2ab606ff64a3c4203David 'Digit' Turner    "asm": "__asm__",
65199346a2abd8b6ba282e1fe291cc3766fa921f40Elliott Hughes    # The kernel usage of __unused for unused struct fields conflicts with the macro defined in <sys/cdefs.h>.
66199346a2abd8b6ba282e1fe291cc3766fa921f40Elliott Hughes    "__unused": "__linux_unused",
67199346a2abd8b6ba282e1fe291cc3766fa921f40Elliott Hughes    # The kernel's _NSIG/NSIG are one less than the userspace value, so we need to move them aside.
68199346a2abd8b6ba282e1fe291cc3766fa921f40Elliott Hughes    "_NSIG": "_KERNEL__NSIG",
69199346a2abd8b6ba282e1fe291cc3766fa921f40Elliott Hughes    "NSIG": "_KERNEL_NSIG",
700990d4fda898ada86e557f872f5cb7d16b138e3cElliott Hughes    # The kernel's SIGRTMIN/SIGRTMAX are absolute limits; userspace steals a few.
710990d4fda898ada86e557f872f5cb7d16b138e3cElliott Hughes    "SIGRTMIN": "__SIGRTMIN",
720990d4fda898ada86e557f872f5cb7d16b138e3cElliott Hughes    "SIGRTMAX": "__SIGRTMAX",
73c9205dba43c45dc5a185aa26e1160c3f62e9b471Martin Storsjo    }
74c9205dba43c45dc5a185aa26e1160c3f62e9b471Martin Storsjo
75a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# this is the set of known static inline functions that we want to keep
76a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# in the final ARM headers. this is only used to keep optimized byteswapping
77a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# static functions and stuff like that.
789195a258ee96d6cf31b2fc7db9da16f92f5e7f65Elliott Hughes# TODO: this isn't working!
79d1973ca51325393f304e82a4d79874f33e54ac16Colin Crosskernel_known_arm_statics = set(
80d1973ca51325393f304e82a4d79874f33e54ac16Colin Cross        [ "___arch__swab32",    # asm-arm/byteorder.h
818bea2b6faca554a145bdafc6f3afafec1f3120b6Ben Cheng        ]
828bea2b6faca554a145bdafc6f3afafec1f3120b6Ben Cheng    )
838bea2b6faca554a145bdafc6f3afafec1f3120b6Ben Cheng
84d1973ca51325393f304e82a4d79874f33e54ac16Colin Crosskernel_known_arm64_statics = set(
85d1973ca51325393f304e82a4d79874f33e54ac16Colin Cross        [
86a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project        ]
87a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    )
88a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
8982fa43febc9d679ae6276f6bf992b9b345bb5815Raghu Gandhamkernel_known_mips_statics = set(
9082fa43febc9d679ae6276f6bf992b9b345bb5815Raghu Gandham        [
9182fa43febc9d679ae6276f6bf992b9b345bb5815Raghu Gandham        ]
9282fa43febc9d679ae6276f6bf992b9b345bb5815Raghu Gandham    )
9382fa43febc9d679ae6276f6bf992b9b345bb5815Raghu Gandham
94d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hugheskernel_known_x86_statics = set(
95d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes        [ "___arch__swab32",  # asm-x86/byteorder.h
96d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes          "___arch__swab64",  # asm-x86/byteorder.h
97d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes        ]
98d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes    )
99d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes
100a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectkernel_known_generic_statics = set(
1019195a258ee96d6cf31b2fc7db9da16f92f5e7f65Elliott Hughes        [
1029195a258ee96d6cf31b2fc7db9da16f92f5e7f65Elliott Hughes          "ipt_get_target",  # uapi/linux/netfilter_ipv4/ip_tables.h
1039195a258ee96d6cf31b2fc7db9da16f92f5e7f65Elliott Hughes          "ip6t_get_target", # uapi/linux/netfilter_ipv6/ip6_tables.h
104a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project        ]
105a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    )
106a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
107a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# this maps an architecture to the set of static inline functions that
108a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# we want to keep in the final headers
109a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project#
110a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectkernel_known_statics = {
111a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project        "arm" : kernel_known_arm_statics,
112d1973ca51325393f304e82a4d79874f33e54ac16Colin Cross        "arm64" : kernel_known_arm64_statics,
113d3e64a3f403918abf2cc3f9f0f9a2204a420ec96Elliott Hughes        "mips" : kernel_known_mips_statics,
11437429fff4101f8f75db795048226169ede9e7413Shin-ichiro KAWASAKI        "x86" : kernel_known_x86_statics,
115a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project    }
116a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project
1176d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project# this is a list of macros which we want to specifically exclude from
1186d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project# the generated files.
1196d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project#
1206d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Projectkernel_ignored_macros = set(
1216d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project        [ "MAXHOSTNAMELEN",  # for some reason, Linux defines it to 64
1226d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project                             # while most of the BSD code expects this to be 256
1236d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project                             # so ignore the kernel-provided definition and
1246d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project                             # define it in the Bionic headers instead
1256d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project        ]
1266d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project    )
1276d6c82c7a0a6b9a89f61b61c66f9b90d9c7177dcThe Android Open Source Project
128a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project# this is the standard disclaimer
129a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project#
130a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Projectkernel_disclaimer = """\
131a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project/****************************************************************************
132a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ****************************************************************************
133a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ***
134a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ***   This header was automatically generated from a Linux kernel header
135a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ***   of the same name, to make information necessary for userspace to
136a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ***   call into the kernel available to libc.  It contains only constants,
137a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ***   structures, and macros generated from the original header, and thus,
138a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ***   contains no copyrightable information.
139a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ***
140fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner ***   To edit the content of this header, modify the corresponding
141fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner ***   source file (e.g. under external/kernel-headers/original/) then
142fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner ***   run bionic/libc/kernel/tools/update_all.py
143fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner ***
144fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner ***   Any manual change here will be lost the next time this script will
145fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner ***   be run. You've been warned!
146fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner ***
147a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ****************************************************************************
148a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project ****************************************************************************/
149a27d2baa0c1a2ec70f47ea9199b1dd6762c8a34The Android Open Source Project"""
150fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner
151fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner# This is the warning line that will be inserted every N-th line in the output
152fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turnerkernel_warning = """\
153fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
154fc2693110ee8a2ba22a445ad9855fbe9e118d439David 'Digit' Turner"""
155