blob: 24b078e83bed23041559c2903f791fa5a760f19b [file] [log] [blame]
Kevin O'Connorf076a3e2008-02-25 22:25:15 -05001// Basic type definitions for X86 cpus.
2//
Kevin O'Connord1b4f962010-09-15 21:38:16 -04003// Copyright (C) 2008-2010 Kevin O'Connor <kevin@koconnor.net>
Kevin O'Connorf076a3e2008-02-25 22:25:15 -05004//
Kevin O'Connorb1b7c2a2009-01-15 20:52:58 -05005// This file may be distributed under the terms of the GNU LGPLv3 license.
Kevin O'Connorf076a3e2008-02-25 22:25:15 -05006#ifndef __TYPES_H
7#define __TYPES_H
8
9typedef unsigned char u8;
10typedef signed char s8;
11typedef unsigned short u16;
12typedef signed short s16;
13typedef unsigned int u32;
14typedef signed int s32;
Kevin O'Connore51313d2008-03-12 21:19:34 -040015typedef unsigned long long u64;
Kevin O'Connor595fb462008-04-05 10:47:13 -040016typedef signed long long s64;
17typedef u32 size_t;
Kevin O'Connorf076a3e2008-02-25 22:25:15 -050018
Kevin O'Connor1bb3b5c2008-05-14 00:43:13 -040019union u64_u32_u {
Kevin O'Connor30e6af02012-09-15 12:17:37 -040020 struct { u32 lo, hi; };
Kevin O'Connor1bb3b5c2008-05-14 00:43:13 -040021 u64 val;
22};
23
Kevin O'Connor942d4952009-06-10 22:44:06 -040024#ifdef MANUAL_NO_JUMP_TABLE
25# define default case 775324556: asm(""); default
26#endif
27
28#ifdef WHOLE_PROGRAM
29# define __VISIBLE __attribute__((externally_visible))
30#else
31# define __VISIBLE
32#endif
Kevin O'Connor4a754b32008-12-28 21:37:27 -050033
Kevin O'Connorc0693942009-06-10 21:56:01 -040034#define UNIQSEC __FILE__ "." __stringify(__LINE__)
35
Kevin O'Connordad41d92010-01-01 03:04:19 -050036#define __noreturn __attribute__((noreturn))
Kevin O'Connor1ca05b02010-01-03 17:43:37 -050037extern void __force_link_error__only_in_32bit_flat(void) __noreturn;
38extern void __force_link_error__only_in_32bit_segmented(void) __noreturn;
39extern void __force_link_error__only_in_16bit(void) __noreturn;
Kevin O'Connor871e0a02009-12-30 12:14:53 -050040
Kevin O'Connorc0693942009-06-10 21:56:01 -040041#define __ASM(code) asm(".section .text.asm." UNIQSEC "\n\t" code)
42
Kevin O'Connor7ab798f2008-07-13 11:08:36 -040043#if MODE16 == 1
Kevin O'Connor19786762008-03-05 21:09:59 -050044// Notes a function as externally visible in the 16bit code chunk.
Kevin O'Connor4a754b32008-12-28 21:37:27 -050045# define VISIBLE16 __VISIBLE
Kevin O'Connor52a300f2009-12-26 23:32:57 -050046// Notes a function as externally visible in the 32bit flat code chunk.
Kevin O'Connord3e43672012-05-28 11:37:53 -040047# define VISIBLE32FLAT
Kevin O'Connord1b4f962010-09-15 21:38:16 -040048// Notes a 32bit flat function that will only be called during init.
Kevin O'Connord3e43672012-05-28 11:37:53 -040049# define VISIBLE32INIT
Kevin O'Connor871e0a02009-12-30 12:14:53 -050050// Notes a function as externally visible in the 32bit segmented code chunk.
Kevin O'Connord3e43672012-05-28 11:37:53 -040051# define VISIBLE32SEG
Kevin O'Connor92f95b02008-12-29 20:42:40 -050052// Designate a variable as (only) visible to 16bit code.
Kevin O'Connorc0693942009-06-10 21:56:01 -040053# define VAR16 __section(".data16." UNIQSEC)
Kevin O'Connor372e0712009-09-09 09:51:31 -040054// Designate a variable as visible to 16bit, 32bit, and assembler code.
55# define VAR16VISIBLE VAR16 __VISIBLE
56// Designate a variable as externally visible (in addition to all internal code).
Kevin O'Connorc0693942009-06-10 21:56:01 -040057# define VAR16EXPORT __section(".data16.export." UNIQSEC) __VISIBLE
Kevin O'Connor30853762009-01-17 18:49:20 -050058// Designate a variable at a specific 16bit address
Kevin O'Connorc0693942009-06-10 21:56:01 -040059# define VAR16FIXED(addr) __aligned(1) __VISIBLE __section(".fixedaddr." __stringify(addr))
Kevin O'Connor871e0a02009-12-30 12:14:53 -050060// Designate a variable as (only) visible to 32bit segmented code.
61# define VAR32SEG __section(".discard.var32seg." UNIQSEC)
Kevin O'Connor0bf92702009-08-01 11:45:37 -040062// Designate a 32bit variable also available in 16bit "big real" mode.
Kevin O'Connor52a300f2009-12-26 23:32:57 -050063# define VAR32FLATVISIBLE __section(".discard.var32flat." UNIQSEC) __VISIBLE __weak
Kevin O'Connor46b82622012-05-13 12:10:30 -040064// Designate a variable as visible and located in the e-segment.
65# define VARLOW __section(".discard.varlow." UNIQSEC) __VISIBLE __weak
Kevin O'Connor4a754b32008-12-28 21:37:27 -050066// Designate top-level assembler as 16bit only.
Kevin O'Connorc0693942009-06-10 21:56:01 -040067# define ASM16(code) __ASM(code)
Kevin O'Connor52a300f2009-12-26 23:32:57 -050068// Designate top-level assembler as 32bit flat only.
69# define ASM32FLAT(code)
70// Compile time check for a given mode.
Kevin O'Connorfdca4182010-01-01 12:46:54 -050071# define ASSERT16() do { } while (0)
72# define ASSERT32SEG() __force_link_error__only_in_32bit_segmented()
73# define ASSERT32FLAT() __force_link_error__only_in_32bit_flat()
Kevin O'Connor871e0a02009-12-30 12:14:53 -050074#elif MODESEGMENT == 1
Kevin O'Connord3e43672012-05-28 11:37:53 -040075# define VISIBLE16
76# define VISIBLE32FLAT
77# define VISIBLE32INIT
Kevin O'Connor871e0a02009-12-30 12:14:53 -050078# define VISIBLE32SEG __VISIBLE
Kevin O'Connorc0693942009-06-10 21:56:01 -040079# define VAR16 __section(".discard.var16." UNIQSEC)
Kevin O'Connor372e0712009-09-09 09:51:31 -040080# define VAR16VISIBLE VAR16 __VISIBLE __weak
81# define VAR16EXPORT VAR16VISIBLE
82# define VAR16FIXED(addr) VAR16VISIBLE
Kevin O'Connor871e0a02009-12-30 12:14:53 -050083# define VAR32SEG __section(".data32seg." UNIQSEC)
84# define VAR32FLATVISIBLE __section(".discard.var32flat." UNIQSEC) __VISIBLE __weak
Kevin O'Connor46b82622012-05-13 12:10:30 -040085# define VARLOW __section(".discard.varlow." UNIQSEC) __VISIBLE __weak
Kevin O'Connor871e0a02009-12-30 12:14:53 -050086# define ASM16(code)
87# define ASM32FLAT(code)
Kevin O'Connorfdca4182010-01-01 12:46:54 -050088# define ASSERT16() __force_link_error__only_in_16bit()
89# define ASSERT32SEG() do { } while (0)
90# define ASSERT32FLAT() __force_link_error__only_in_32bit_flat()
Kevin O'Connor871e0a02009-12-30 12:14:53 -050091#else
Kevin O'Connord3e43672012-05-28 11:37:53 -040092# define VISIBLE16
Kevin O'Connord1b4f962010-09-15 21:38:16 -040093# define VISIBLE32FLAT __section(".text.runtime." UNIQSEC) __VISIBLE
94# define VISIBLE32INIT __section(".text.init." UNIQSEC) __VISIBLE
Kevin O'Connord3e43672012-05-28 11:37:53 -040095# define VISIBLE32SEG
Kevin O'Connor871e0a02009-12-30 12:14:53 -050096# define VAR16 __section(".discard.var16." UNIQSEC)
97# define VAR16VISIBLE VAR16 __VISIBLE __weak
98# define VAR16EXPORT VAR16VISIBLE
99# define VAR16FIXED(addr) VAR16VISIBLE
100# define VAR32SEG __section(".discard.var32seg." UNIQSEC)
Kevin O'Connord1b4f962010-09-15 21:38:16 -0400101# define VAR32FLATVISIBLE __section(".data.runtime." UNIQSEC) __VISIBLE
Kevin O'Connor46b82622012-05-13 12:10:30 -0400102# define VARLOW __section(".datalow." UNIQSEC) __VISIBLE
Kevin O'Connor4a754b32008-12-28 21:37:27 -0500103# define ASM16(code)
Kevin O'Connor52a300f2009-12-26 23:32:57 -0500104# define ASM32FLAT(code) __ASM(code)
Kevin O'Connorfdca4182010-01-01 12:46:54 -0500105# define ASSERT16() __force_link_error__only_in_16bit()
106# define ASSERT32SEG() __force_link_error__only_in_32bit_segmented()
107# define ASSERT32FLAT() do { } while (0)
Kevin O'Connor19786762008-03-05 21:09:59 -0500108#endif
Kevin O'Connorf076a3e2008-02-25 22:25:15 -0500109
110#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER)
Kevin O'Connor38fcbfe2008-02-25 22:30:47 -0500111#define ARRAY_SIZE(a) (sizeof(a) / sizeof(a[0]))
Kevin O'Connor28fe1bd2008-03-11 22:14:15 -0400112#define FIELD_SIZEOF(t, f) (sizeof(((t*)0)->f))
Kevin O'Connor9dd0dd12008-05-18 00:03:32 -0400113#define DIV_ROUND_UP(n,d) (((n) + (d) - 1) / (d))
Kevin O'Connor6aee52d2009-09-27 20:07:40 -0400114#define DIV_ROUND_CLOSEST(x, divisor)({ \
115 typeof(divisor) __divisor = divisor; \
116 (((x) + ((__divisor) / 2)) / (__divisor)); \
117 })
Kevin O'Connor276d4a92008-06-11 22:47:01 -0400118#define ALIGN(x,a) __ALIGN_MASK(x,(typeof(x))(a)-1)
119#define __ALIGN_MASK(x,mask) (((x)+(mask))&~(mask))
Kevin O'Connor415d4292009-08-30 19:19:31 -0400120#define ALIGN_DOWN(x,a) ((x) & ~((typeof(x))(a)-1))
Kevin O'Connor0bf92702009-08-01 11:45:37 -0400121#define container_of(ptr, type, member) ({ \
122 const typeof( ((type *)0)->member ) *__mptr = (ptr); \
123 (type *)( (char *)__mptr - offsetof(type,member) );})
Kevin O'Connor38fcbfe2008-02-25 22:30:47 -0500124
Kevin O'Connord7eb27e2010-03-20 18:17:19 -0400125#define likely(x) __builtin_expect(!!(x), 1)
126#define unlikely(x) __builtin_expect(!!(x), 0)
127
Kevin O'Connor415d4292009-08-30 19:19:31 -0400128#define NULL ((void*)0)
Kevin O'Connorf076a3e2008-02-25 22:25:15 -0500129
Kevin O'Connorc0693942009-06-10 21:56:01 -0400130#define __weak __attribute__((weak))
131#define __section(S) __attribute__((section(S)))
132
Kevin O'Connor6eee8ca2008-03-03 20:14:12 -0500133#define PACKED __attribute__((packed))
Kevin O'Connor18e38b22008-12-10 20:40:13 -0500134#define __aligned(x) __attribute__((aligned(x)))
Kevin O'Connor6eee8ca2008-03-03 20:14:12 -0500135
Kevin O'Connora4d35762008-03-08 15:43:03 -0500136#define barrier() __asm__ __volatile__("": : :"memory")
137
Kevin O'Connoree55c762008-05-13 00:18:20 -0400138#define noinline __attribute__((noinline))
Kevin O'Connor74f9c082008-04-13 16:57:16 -0400139#define __always_inline inline __attribute__((always_inline))
Kevin O'Connorf9a774c2010-04-17 16:58:32 -0400140#define __malloc __attribute__((__malloc__))
Kevin O'Connor871e0a02009-12-30 12:14:53 -0500141#define __attribute_const __attribute__((__const__))
Kevin O'Connorbc28a2b2008-03-11 19:32:38 -0400142
Kevin O'Connora4d35762008-03-08 15:43:03 -0500143#define __stringify_1(x) #x
144#define __stringify(x) __stringify_1(x)
145
Kevin O'Connorf076a3e2008-02-25 22:25:15 -0500146#endif // types.h