blob: 7ff6064b187b7b914f27ac8f5e7004a014037130 [file] [log] [blame]
Wolfgang Denk932394a2005-08-17 12:55:25 +02001#ifndef _LINUX_COMPAT_H_
2#define _LINUX_COMPAT_H_
3
Heiko Schocher0c06db52014-06-24 10:10:03 +02004#include <malloc.h>
5#include <linux/types.h>
6#include <linux/err.h>
7
8struct unused {};
9typedef struct unused unused_t;
10
11struct p_current{
12 int pid;
13};
14
15extern struct p_current *current;
16
Wolfgang Denk932394a2005-08-17 12:55:25 +020017#define ndelay(x) udelay(1)
18
Wu, Josh2f96b062013-07-03 11:11:47 +080019#define dev_dbg(dev, fmt, args...) \
20 debug(fmt, ##args)
21#define dev_vdbg(dev, fmt, args...) \
22 debug(fmt, ##args)
23#define dev_info(dev, fmt, args...) \
24 printf(fmt, ##args)
25#define dev_err(dev, fmt, args...) \
26 printf(fmt, ##args)
Wolfgang Denk932394a2005-08-17 12:55:25 +020027#define printk printf
Heiko Schocher0c06db52014-06-24 10:10:03 +020028#define printk_once printf
Wolfgang Denk932394a2005-08-17 12:55:25 +020029
30#define KERN_EMERG
31#define KERN_ALERT
32#define KERN_CRIT
33#define KERN_ERR
34#define KERN_WARNING
35#define KERN_NOTICE
36#define KERN_INFO
37#define KERN_DEBUG
38
Heiko Schocher0c06db52014-06-24 10:10:03 +020039void *kmalloc(size_t size, int flags);
40void *kzalloc(size_t size, int flags);
41#define vmalloc(size) kmalloc(size, 0)
42#define __vmalloc(size, flags, pgsz) kmalloc(size, flags)
43#define kfree(ptr) free(ptr)
44#define vfree(ptr) free(ptr)
45
46struct kmem_cache { int sz; };
47
48struct kmem_cache *get_mem(int element_sz);
49#define kmem_cache_create(a, sz, c, d, e) get_mem(sz)
50void *kmem_cache_alloc(struct kmem_cache *obj, int flag);
51#define kmem_cache_free(obj, size) free(size)
52#define kmem_cache_destroy(obj) free(obj)
William Juulcfa460a2007-10-31 13:53:06 +010053
Stefan Roese0a572652009-05-12 14:29:39 +020054#define DECLARE_WAITQUEUE(...) do { } while (0)
55#define add_wait_queue(...) do { } while (0)
56#define remove_wait_queue(...) do { } while (0)
57
58#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))
Wolfgang Denk932394a2005-08-17 12:55:25 +020059
60/*
61 * ..and if you can't take the strict
62 * types, you can specify one yourself.
63 *
64 * Or not use min/max at all, of course.
65 */
66#define min_t(type,x,y) \
67 ({ type __x = (x); type __y = (y); __x < __y ? __x: __y; })
68#define max_t(type,x,y) \
69 ({ type __x = (x); type __y = (y); __x > __y ? __x: __y; })
70
Stefan Roese887e2ec2006-09-07 11:51:23 +020071#ifndef BUG
Wolfgang Denk932394a2005-08-17 12:55:25 +020072#define BUG() do { \
73 printf("U-Boot BUG at %s:%d!\n", __FILE__, __LINE__); \
74} while (0)
75
76#define BUG_ON(condition) do { if (condition) BUG(); } while(0)
Stefan Roese887e2ec2006-09-07 11:51:23 +020077#endif /* BUG */
Wolfgang Denk932394a2005-08-17 12:55:25 +020078
Mike Frysinger6777a3c2012-04-26 02:34:44 +000079#define WARN_ON(x) if (x) {printf("WARNING in %s line %d\n" \
80 , __FILE__, __LINE__); }
81
Wolfgang Denk932394a2005-08-17 12:55:25 +020082#define PAGE_SIZE 4096
Lijun Pan8f2df5d2014-06-20 12:17:29 -050083
84/**
85 * upper_32_bits - return MSB bits 32-63 of a number if little endian, or
86 * return MSB bits 0-31 of a number if big endian.
87 * @n: the number we're accessing
88 *
89 * A basic shift-right of a 64- or 32-bit quantity. Use this to suppress
90 * the "right shift count >= width of type" warning when that quantity is
91 * 32-bits.
92 */
93#define upper_32_bits(n) ((u32)(((n) >> 16) >> 16))
94
95/**
96 * lower_32_bits - return LSB bits 0-31 of a number if little endian, or
97 * return LSB bits 32-63 of a number if big endian.
98 * @n: the number we're accessing
99 */
100#define lower_32_bits(n) ((u32)(n))
101
Heiko Schocher0c06db52014-06-24 10:10:03 +0200102/* drivers/char/random.c */
103#define get_random_bytes(...)
104
105/* idr.c */
106#define GFP_ATOMIC ((gfp_t) 0)
107#define GFP_KERNEL ((gfp_t) 0)
108#define GFP_NOFS ((gfp_t) 0)
109#define GFP_USER ((gfp_t) 0)
110#define __GFP_NOWARN ((gfp_t) 0)
111
112/* include/linux/leds.h */
113struct led_trigger {};
114
115#define DEFINE_LED_TRIGGER(x) static struct led_trigger *x;
116enum led_brightness {
117 LED_OFF = 0,
118 LED_HALF = 127,
119 LED_FULL = 255,
120};
121
122static inline void led_trigger_register_simple(const char *name,
123 struct led_trigger **trigger) {}
124static inline void led_trigger_unregister_simple(struct led_trigger *trigger) {}
125static inline void led_trigger_event(struct led_trigger *trigger,
126 enum led_brightness event) {}
127
128/* include/linux/log2.h */
129static inline int is_power_of_2(unsigned long n)
130{
131 return (n != 0 && ((n & (n - 1)) == 0));
132}
133
134/* uapi/linux/limits.h */
135#define XATTR_LIST_MAX 65536 /* size of extended attribute namelist (64k) */
136
137/**
138 * The type used for indexing onto a disc or disc partition.
139 *
140 * Linux always considers sectors to be 512 bytes long independently
141 * of the devices real block size.
142 *
143 * blkcnt_t is the type of the inode's block count.
144 */
145#ifdef CONFIG_LBDAF
146typedef u64 sector_t;
147typedef u64 blkcnt_t;
148#else
149typedef unsigned long sector_t;
150typedef unsigned long blkcnt_t;
151#endif
152
153#define ENOTSUPP 524 /* Operation is not supported */
154
155/* from include/linux/kernel.h */
156/*
157 * This looks more complex than it should be. But we need to
158 * get the type for the ~ right in round_down (it needs to be
159 * as wide as the result!), and we want to evaluate the macro
160 * arguments just once each.
161 */
162#define __round_mask(x, y) ((__typeof__(x))((y)-1))
163#define round_up(x, y) ((((x)-1) | __round_mask(x, y))+1)
164#define round_down(x, y) ((x) & ~__round_mask(x, y))
165
166/* module */
167#define THIS_MODULE 0
168#define try_module_get(...) 1
169#define module_put(...) do { } while (0)
170#define module_init(...)
171#define module_exit(...)
172#define EXPORT_SYMBOL(...)
173#define EXPORT_SYMBOL_GPL(...)
174#define module_param(...)
175#define module_param_call(...)
176#define MODULE_PARM_DESC(...)
177#define MODULE_VERSION(...)
178#define MODULE_DESCRIPTION(...)
179#define MODULE_AUTHOR(...)
180#define MODULE_LICENSE(...)
181#define MODULE_ALIAS(...)
182#define __module_get(...)
183
184/* character device */
185#define MKDEV(...) 0
186#define MAJOR(dev) 0
187#define MINOR(dev) 0
188
189#define alloc_chrdev_region(...) 0
190#define unregister_chrdev_region(...)
191
192#define class_create(...) __builtin_return_address(0)
193#define class_create_file(...) 0
194#define class_remove_file(...)
195#define class_destroy(...)
196#define misc_register(...) 0
197#define misc_deregister(...)
198
199#define blocking_notifier_call_chain(...) 0
200
201/*
202 * Multiplies an integer by a fraction, while avoiding unnecessary
203 * overflow or loss of precision.
204 */
205#define mult_frac(x, numer, denom)( \
206{ \
207 typeof(x) quot = (x) / (denom); \
208 typeof(x) rem = (x) % (denom); \
209 (quot * (numer)) + ((rem * (numer)) / (denom)); \
210} \
211)
212
213#define __initdata
214#define late_initcall(...)
215
216#define dev_set_name(...) do { } while (0)
217#define device_register(...) 0
218#define volume_sysfs_init(...) 0
219#define volume_sysfs_close(...) do { } while (0)
220
221#define init_waitqueue_head(...) do { } while (0)
222#define wait_event_interruptible(...) 0
223#define wake_up_interruptible(...) do { } while (0)
224#define print_hex_dump(...) do { } while (0)
225#define dump_stack(...) do { } while (0)
226
227#define task_pid_nr(x) 0
228#define set_freezable(...) do { } while (0)
229#define try_to_freeze(...) 0
230#define set_current_state(...) do { } while (0)
231#define kthread_should_stop(...) 0
232#define schedule() do { } while (0)
233
234#define setup_timer(timer, func, data) do {} while (0)
235#define del_timer_sync(timer) do {} while (0)
236#define schedule_work(work) do {} while (0)
237#define INIT_WORK(work, fun) do {} while (0)
238
239struct work_struct {};
240
241unsigned long copy_from_user(void *dest, const void *src,
242 unsigned long count);
243
244void *vzalloc(unsigned long size);
245
246typedef unused_t spinlock_t;
247typedef int wait_queue_head_t;
248
249#define spin_lock_init(lock) do {} while (0)
250#define spin_lock(lock) do {} while (0)
251#define spin_unlock(lock) do {} while (0)
252#define spin_lock_irqsave(lock, flags) do { debug("%lu\n", flags); } while (0)
253#define spin_unlock_irqrestore(lock, flags) do { flags = 0; } while (0)
254
255#define DEFINE_MUTEX(...)
256#define mutex_init(...)
257#define mutex_lock(...)
258#define mutex_unlock(...)
259
260#define init_rwsem(...) do { } while (0)
261#define down_read(...) do { } while (0)
262#define down_write(...) do { } while (0)
263#define down_write_trylock(...) 1
264#define up_read(...) do { } while (0)
265#define up_write(...) do { } while (0)
266
267#define cond_resched() do { } while (0)
268#define yield() do { } while (0)
269
270#define INT_MAX ((int)(~0U>>1))
271
272#define __user
273#define __init
274#define __exit
275#define __devinit
276#define __devinitdata
277#define __devinitconst
278#define __iomem
279
280#define kthread_create(...) __builtin_return_address(0)
281#define kthread_stop(...) do { } while (0)
282#define wake_up_process(...) do { } while (0)
283
284struct rw_semaphore { int i; };
285#define down_write(...) do { } while (0)
286#define up_write(...) do { } while (0)
287#define down_read(...) do { } while (0)
288#define up_read(...) do { } while (0)
289struct device {
290 struct device *parent;
291 struct class *class;
292 dev_t devt; /* dev_t, creates the sysfs "dev" */
293 void (*release)(struct device *dev);
294 /* This is used from drivers/usb/musb-new subsystem only */
295 void *driver_data; /* data private to the driver */
296 void *device_data; /* data private to the device */
297};
298struct mutex { int i; };
299struct kernel_param { int i; };
300
301struct cdev {
302 int owner;
303 dev_t dev;
304};
305#define cdev_init(...) do { } while (0)
306#define cdev_add(...) 0
307#define cdev_del(...) do { } while (0)
308
309#define MAX_ERRNO 4095
310
311#define prandom_u32(...) 0
312
313typedef struct {
314 uid_t val;
315} kuid_t;
316
317typedef struct {
318 gid_t val;
319} kgid_t;
320
321/* from include/linux/types.h */
322
323typedef int atomic_t;
324/**
325 * struct callback_head - callback structure for use with RCU and task_work
326 * @next: next update requests in a list
327 * @func: actual update function to call after the grace period.
328 */
329struct callback_head {
330 struct callback_head *next;
331 void (*func)(struct callback_head *head);
332};
333#define rcu_head callback_head
334enum writeback_sync_modes {
335 WB_SYNC_NONE, /* Don't wait on anything */
336 WB_SYNC_ALL, /* Wait on every mapping */
337};
338
339/* from include/linux/writeback.h */
340/*
341 * A control structure which tells the writeback code what to do. These are
342 * always on the stack, and hence need no locking. They are always initialised
343 * in a manner such that unspecified fields are set to zero.
344 */
345struct writeback_control {
346 long nr_to_write; /* Write this many pages, and decrement
347 this for each page written */
348 long pages_skipped; /* Pages which were not written */
349
350 /*
351 * For a_ops->writepages(): if start or end are non-zero then this is
352 * a hint that the filesystem need only write out the pages inside that
353 * byterange. The byte at `end' is included in the writeout request.
354 */
355 loff_t range_start;
356 loff_t range_end;
357
358 enum writeback_sync_modes sync_mode;
359
360 unsigned for_kupdate:1; /* A kupdate writeback */
361 unsigned for_background:1; /* A background writeback */
362 unsigned tagged_writepages:1; /* tag-and-write to avoid livelock */
363 unsigned for_reclaim:1; /* Invoked from the page allocator */
364 unsigned range_cyclic:1; /* range_start is cyclic */
365 unsigned for_sync:1; /* sync(2) WB_SYNC_ALL writeback */
366};
367
368void *kmemdup(const void *src, size_t len, gfp_t gfp);
369
370typedef int irqreturn_t;
371
372struct timer_list {};
373struct notifier_block {};
374
375typedef unsigned long dmaaddr_t;
376
377#define cpu_relax() do {} while (0)
378
379#define pm_runtime_get_sync(dev) do {} while (0)
380#define pm_runtime_put(dev) do {} while (0)
381#define pm_runtime_put_sync(dev) do {} while (0)
382#define pm_runtime_use_autosuspend(dev) do {} while (0)
383#define pm_runtime_set_autosuspend_delay(dev, delay) do {} while (0)
384#define pm_runtime_enable(dev) do {} while (0)
385
386#define IRQ_NONE 0
387#define IRQ_HANDLED 1
388
389#define dev_set_drvdata(dev, data) do {} while (0)
390
391#define enable_irq(...)
392#define disable_irq(...)
393#define disable_irq_wake(irq) do {} while (0)
394#define enable_irq_wake(irq) -EINVAL
395#define free_irq(irq, data) do {} while (0)
396#define request_irq(nr, f, flags, nm, data) 0
397
Wolfgang Denk932394a2005-08-17 12:55:25 +0200398#endif