11188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/*===---- cpuid.h - X86 cpu model detection --------------------------------===
21188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker *
31188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * Permission is hereby granted, free of charge, to any person obtaining a copy
41188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * of this software and associated documentation files (the "Software"), to deal
51188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * in the Software without restriction, including without limitation the rights
61188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
71188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * copies of the Software, and to permit persons to whom the Software is
81188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * furnished to do so, subject to the following conditions:
91188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker *
101188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * The above copyright notice and this permission notice shall be included in
111188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * all copies or substantial portions of the Software.
121188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker *
131188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
141188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
151188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
161188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
171188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
181188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
191188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker * THE SOFTWARE.
201188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker *
211188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker *===-----------------------------------------------------------------------===
221188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker */
231188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
241188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#if !(__x86_64__ || __i386__)
251188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#error this header is for x86 only
261188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#endif
271188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
281188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* Responses identification request with %eax 0 */
291188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* AMD:     "AuthenticAMD" */
301188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_AMD_ebx 0x68747541
311188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_AMD_edx 0x69746e65
321188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_AMD_ecx 0x444d4163
331188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* CENTAUR: "CentaurHauls" */
341188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_CENTAUR_ebx 0x746e6543
351188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_CENTAUR_edx 0x48727561
361188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_CENTAUR_ecx 0x736c7561
371188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* CYRIX:   "CyrixInstead" */
381188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_CYRIX_ebx 0x69727943
391188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_CYRIX_edx 0x736e4978
401188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_CYRIX_ecx 0x64616574
411188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* INTEL:   "GenuineIntel" */
421188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_INTEL_ebx 0x756e6547
431188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_INTEL_edx 0x49656e69
441188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_INTEL_ecx 0x6c65746e
451188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* TM1:     "TransmetaCPU" */
461188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_TM1_ebx 0x6e617254
471188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_TM1_edx 0x74656d73
481188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_TM1_ecx 0x55504361
491188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* TM2:     "GenuineTMx86" */
501188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_TM2_ebx 0x756e6547
511188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_TM2_edx 0x54656e69
521188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_TM2_ecx 0x3638784d
531188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* NSC:     "Geode by NSC" */
541188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_NSC_ebx 0x646f6547
551188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_NSC_edx 0x43534e20
561188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_NSC_ecx 0x79622065
571188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* NEXGEN:  "NexGenDriven" */
581188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_NEXGEN_ebx 0x4778654e
591188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_NEXGEN_edx 0x72446e65
601188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_NEXGEN_ecx 0x6e657669
611188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* RISE:    "RiseRiseRise" */
621188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_RISE_ebx 0x65736952
631188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_RISE_edx 0x65736952
641188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_RISE_ecx 0x65736952
651188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* SIS:     "SiS SiS SiS " */
661188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_SIS_ebx 0x20536953
671188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_SIS_edx 0x20536953
681188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_SIS_ecx 0x20536953
691188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* UMC:     "UMC UMC UMC " */
701188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_UMC_ebx 0x20434d55
711188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_UMC_edx 0x20434d55
721188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_UMC_ecx 0x20434d55
731188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* VIA:     "VIA VIA VIA " */
741188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_VIA_ebx 0x20414956
751188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_VIA_edx 0x20414956
761188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_VIA_ecx 0x20414956
771188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* VORTEX:  "Vortex86 SoC" */
781188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_VORTEX_ebx 0x74726f56
791188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_VORTEX_edx 0x36387865
801188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define signature_VORTEX_ecx 0x436f5320
811188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
821188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* Features in %ecx for level 1 */
831188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SSE3        0x00000001
841188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PCLMULQDQ   0x00000002
851188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_DTES64      0x00000004
861188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_MONITOR     0x00000008
871188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_DSCPL       0x00000010
881188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_VMX         0x00000020
891188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SMX         0x00000040
901188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_EIST        0x00000080
911188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_TM2         0x00000100
921188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SSSE3       0x00000200
931188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_CNXTID      0x00000400
941188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_FMA         0x00001000
951188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_CMPXCHG16B  0x00002000
961188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_xTPR        0x00004000
971188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PDCM        0x00008000
981188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PCID        0x00020000
991188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_DCA         0x00040000
1001188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SSE41       0x00080000
1011188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SSE42       0x00100000
1021188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_x2APIC      0x00200000
1031188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_MOVBE       0x00400000
1041188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_POPCNT      0x00800000
1051188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_TSCDeadline 0x01000000
1061188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_AESNI       0x02000000
1071188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_XSAVE       0x04000000
1081188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_OSXSAVE     0x08000000
1091188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_AVX         0x10000000
1101188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_RDRND       0x40000000
1111188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1121188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* Features in %edx for level 1 */
1131188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_FPU         0x00000001
1141188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_VME         0x00000002
1151188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_DE          0x00000004
1161188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PSE         0x00000008
1171188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_TSC         0x00000010
1181188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_MSR         0x00000020
1191188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PAE         0x00000040
1201188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_MCE         0x00000080
1211188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_CX8         0x00000100
1221188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_APIC        0x00000200
1231188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SEP         0x00000800
1241188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_MTRR        0x00001000
1251188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PGE         0x00002000
1261188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_MCA         0x00004000
1271188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_CMOV        0x00008000
1281188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PAT         0x00010000
1291188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PSE36       0x00020000
1301188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PSN         0x00040000
1311188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_CLFSH       0x00080000
1321188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_DS          0x00200000
1331188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_ACPI        0x00400000
1341188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_MMX         0x00800000
1351188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_FXSR        0x01000000
1361188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_FXSAVE      bit_FXSR    /* for gcc compat */
1371188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SSE         0x02000000
1381188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SSE2        0x04000000
1391188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SS          0x08000000
1401188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_HTT         0x10000000
1411188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_TM          0x20000000
1421188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_PBE         0x80000000
1431188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1441188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* Features in %ebx for level 7 sub-leaf 0 */
1451188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_FSGSBASE    0x00000001
1461188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_SMEP        0x00000080
1471188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define bit_ENH_MOVSB   0x00000200
1481188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1491188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#if __i386__
1501188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define __cpuid(__level, __eax, __ebx, __ecx, __edx) \
1511188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    __asm("cpuid" : "=a"(__eax), "=b" (__ebx), "=c"(__ecx), "=d"(__edx) \
1521188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker                  : "0"(__level))
1531188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1541188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define __cpuid_count(__level, __count, __eax, __ebx, __ecx, __edx) \
1551188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    __asm("cpuid" : "=a"(__eax), "=b" (__ebx), "=c"(__ecx), "=d"(__edx) \
1561188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker                  : "0"(__level), "2"(__count))
1571188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#else
1581188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker/* x86-64 uses %rbx as the base register, so preserve it. */
1591188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define __cpuid(__level, __eax, __ebx, __ecx, __edx) \
1601188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    __asm("  xchgq  %%rbx,%q1\n" \
1611188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  cpuid\n" \
1621188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  xchgq  %%rbx,%q1" \
1631188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker        : "=a"(__eax), "=r" (__ebx), "=c"(__ecx), "=d"(__edx) \
1641188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker        : "0"(__level))
1651188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1661188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#define __cpuid_count(__level, __count, __eax, __ebx, __ecx, __edx) \
1671188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    __asm("  xchgq  %%rbx,%q1\n" \
1681188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  cpuid\n" \
1691188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  xchgq  %%rbx,%q1" \
1701188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker        : "=a"(__eax), "=r" (__ebx), "=c"(__ecx), "=d"(__edx) \
1711188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker        : "0"(__level), "2"(__count))
1721188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#endif
1731188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1741188dcf30923cb444143ffa4b83dc951037e76agitbuildkickerstatic __inline int __get_cpuid (unsigned int __level, unsigned int *__eax,
1751188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker                                 unsigned int *__ebx, unsigned int *__ecx,
1761188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker                                 unsigned int *__edx) {
1771188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    __cpuid(__level, *__eax, *__ebx, *__ecx, *__edx);
1781188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    return 1;
1791188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker}
1801188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1811188dcf30923cb444143ffa4b83dc951037e76agitbuildkickerstatic __inline int __get_cpuid_max (unsigned int __level, unsigned int *__sig)
1821188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker{
1831188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    unsigned int __eax, __ebx, __ecx, __edx;
1841188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#if __i386__
1851188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    int __cpuid_supported;
1861188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
1871188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    __asm("  pushfl\n"
1881188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  popl   %%eax\n"
1891188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  movl   %%eax,%%ecx\n"
1901188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  xorl   $0x00200000,%%eax\n"
1911188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  pushl  %%eax\n"
1921188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  popfl\n"
1931188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  pushfl\n"
1941188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  popl   %%eax\n"
1951188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  movl   $0,%0\n"
1961188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  cmpl   %%eax,%%ecx\n"
1971188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  je     1f\n"
1981188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "  movl   $1,%0\n"
1991188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker          "1:"
2001188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker        : "=r" (__cpuid_supported) : : "eax", "ecx");
2011188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    if (!__cpuid_supported)
2021188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker        return 0;
2031188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker#endif
2041188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker
2051188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    __cpuid(__level, __eax, __ebx, __ecx, __edx);
2061188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    if (__sig)
2071188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker        *__sig = __ebx;
2081188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker    return __eax;
2091188dcf30923cb444143ffa4b83dc951037e76agitbuildkicker}
210