2011-09-23 12:00:45 +04:00
|
|
|
#ifndef UTIL_H_
|
|
|
|
#define UTIL_H_
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Some bits are stolen from perf and kvm tools
|
|
|
|
*/
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <signal.h>
|
2011-10-24 13:43:21 +04:00
|
|
|
#include <stdio.h>
|
2011-09-23 12:00:45 +04:00
|
|
|
|
|
|
|
#include <sys/types.h>
|
2011-10-24 13:43:21 +04:00
|
|
|
#include <dirent.h>
|
2011-09-23 12:00:45 +04:00
|
|
|
|
|
|
|
#include "compiler.h"
|
|
|
|
#include "types.h"
|
|
|
|
|
|
|
|
extern void printk(const char *format, ...);
|
|
|
|
|
2011-11-24 15:07:03 +04:00
|
|
|
#define PREF_SHIFT_OP(pref, op, size) ((size) op (pref ##BYTES_SHIFT))
|
|
|
|
#define KBYTES_SHIFT 10
|
|
|
|
#define MBYTES_SHIFT 20
|
|
|
|
#define GBYTES_SHIFT 30
|
|
|
|
|
|
|
|
#define KBYTES(size) PREF_SHIFT_OP(K, >>, size)
|
|
|
|
#define MBYTES(size) PREF_SHIFT_OP(M, >>, size)
|
|
|
|
#define GBYTES(size) PREF_SHIFT_OP(G, >>, size)
|
|
|
|
|
|
|
|
#define KILO(size) PREF_SHIFT_OP(K, <<, size)
|
|
|
|
#define MEGA(size) PREF_SHIFT_OP(K, <<, size)
|
|
|
|
#define GIGA(size) PREF_SHIFT_OP(K, <<, size)
|
|
|
|
|
2011-09-23 12:00:45 +04:00
|
|
|
#define pr_info(fmt, ...) printk(fmt, ##__VA_ARGS__)
|
2011-09-30 14:37:12 +04:00
|
|
|
#define pr_err(fmt, ...) printk("Error (%s:%d): " fmt, __FILE__, __LINE__, ##__VA_ARGS__)
|
2011-09-23 12:00:45 +04:00
|
|
|
#define pr_panic(fmt, ...) printk("PANIC (%s:%d): " fmt, __FILE__, __LINE__, ##__VA_ARGS__)
|
2011-12-27 02:13:29 +04:00
|
|
|
#define pr_warning(fmt, ...) printk("Warning (%s:%d): " fmt, __FILE__, __LINE__, ##__VA_ARGS__)
|
2011-09-23 12:00:45 +04:00
|
|
|
|
2011-09-30 14:37:12 +04:00
|
|
|
#define pr_err_jmp(label) \
|
2011-09-23 12:00:45 +04:00
|
|
|
do { \
|
|
|
|
printk("EJMP: %s:%d\n", __FILE__, __LINE__); \
|
|
|
|
goto label; \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define jerr(code, label) \
|
|
|
|
do { \
|
|
|
|
if ((code)) \
|
2011-09-30 14:37:12 +04:00
|
|
|
pr_err_jmp(label); \
|
2011-09-23 12:00:45 +04:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define jerr_cond(code, cond, label) \
|
|
|
|
do { \
|
|
|
|
if ((code) cond) \
|
2011-09-30 14:37:12 +04:00
|
|
|
pr_err_jmp(label); \
|
2011-09-23 12:00:45 +04:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define jerr_rc(code, rc, label) \
|
|
|
|
do { \
|
|
|
|
rc = (code); \
|
|
|
|
if (rc) \
|
2011-09-30 14:37:12 +04:00
|
|
|
pr_err_jmp(label); \
|
2011-09-23 12:00:45 +04:00
|
|
|
} while (0)
|
|
|
|
|
2011-12-27 02:27:20 +04:00
|
|
|
#ifdef CR_DEBUG
|
2011-09-23 12:00:45 +04:00
|
|
|
#define pr_debug(fmt, ...) \
|
|
|
|
do { \
|
2011-12-27 02:27:20 +04:00
|
|
|
printk("%s:%d:%s: " fmt, \
|
|
|
|
__FILE__, __LINE__,__func__, \
|
2011-09-23 12:00:45 +04:00
|
|
|
##__VA_ARGS__); \
|
|
|
|
} while (0)
|
2011-12-27 02:27:20 +04:00
|
|
|
#define dprintk(fmt, ...) printk(fmt, ##__VA_ARGS__)
|
2011-09-23 12:00:45 +04:00
|
|
|
#else
|
|
|
|
#define pr_debug(fmt, ...)
|
2011-12-27 02:27:20 +04:00
|
|
|
#define dprintk(fmt, ...)
|
2011-09-23 12:00:45 +04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define die(fmt, ...) \
|
|
|
|
do { \
|
|
|
|
printk("die (%s:%d): " fmt, __FILE__, \
|
|
|
|
__LINE__, ##__VA_ARGS__); \
|
|
|
|
exit(1); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define pr_perror(fmt, ...) \
|
|
|
|
do { \
|
2011-09-30 14:37:12 +04:00
|
|
|
pr_err("%s: " fmt, strerror(errno), \
|
|
|
|
##__VA_ARGS__); \
|
2011-09-23 12:00:45 +04:00
|
|
|
} while (0)
|
|
|
|
|
2011-12-26 15:31:51 +04:00
|
|
|
#ifndef BUG_ON_HANDLER
|
2012-01-16 13:53:51 +03:00
|
|
|
#ifdef CR_NOGLIBC
|
|
|
|
#define BUG_ON_HANDLER(condition) \
|
|
|
|
do { \
|
2012-01-17 11:27:29 +03:00
|
|
|
if ((condition)) { \
|
|
|
|
write_string("BUG at " __FILE__ ": "); \
|
|
|
|
write_num(__LINE__); \
|
|
|
|
write_string("\n"); \
|
2012-01-16 13:53:51 +03:00
|
|
|
*(unsigned long *)NULL = 0xdead0000 + __LINE__; \
|
2012-01-17 11:27:29 +03:00
|
|
|
} \
|
2012-01-16 13:53:51 +03:00
|
|
|
} while (0)
|
|
|
|
#else
|
2011-12-26 15:31:51 +04:00
|
|
|
# define BUG_ON_HANDLER(condition) \
|
|
|
|
do { \
|
|
|
|
if ((condition)) { \
|
|
|
|
pr_err("BUG at %s:%d", __FILE__, __LINE__); \
|
|
|
|
raise(SIGABRT); \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
#endif
|
2012-01-16 13:53:51 +03:00
|
|
|
#endif
|
2011-12-26 15:31:51 +04:00
|
|
|
|
|
|
|
#define BUG_ON(condition) BUG_ON_HANDLER((condition))
|
|
|
|
|
2011-09-30 14:37:12 +04:00
|
|
|
#define write_ptr(fd, ptr) \
|
2011-09-23 12:00:45 +04:00
|
|
|
write(fd, (ptr), sizeof(*(ptr)))
|
|
|
|
|
|
|
|
#define write_ptr_safe(fd, ptr, err) \
|
|
|
|
jerr(write_ptr(fd, ptr) != sizeof(*(ptr)), err)
|
|
|
|
|
|
|
|
#define write_safe(fd, ptr, size, err) \
|
|
|
|
jerr(write(fd, (ptr), (size)) != (size), err)
|
|
|
|
|
|
|
|
#define write_safe_imm(fd, imm, err) \
|
|
|
|
do { \
|
|
|
|
typeof(imm) x__ = imm; \
|
|
|
|
write_ptr_safe(fd, &x__, err); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define read_safe(fd, ptr, size, err) \
|
|
|
|
jerr(read(fd, ptr, (size)) != (size), err)
|
|
|
|
|
|
|
|
#define read_ptr_safe(fd, ptr, err) \
|
|
|
|
jerr(read(fd, ptr, sizeof(*(ptr))) != sizeof(*(ptr)), err)
|
|
|
|
|
2011-10-22 18:52:18 +04:00
|
|
|
#define read_safe_eof(fd, ptr, size, err) \
|
|
|
|
({ \
|
|
|
|
size_t rc__ = read(fd, ptr, (size)); \
|
2012-01-18 17:46:22 +04:00
|
|
|
if (rc__ && rc__ != (size)) { \
|
|
|
|
pr_err("img corruption %d/%d\n", rc__, (size));\
|
2011-10-22 18:52:18 +04:00
|
|
|
goto err; \
|
2012-01-18 17:46:22 +04:00
|
|
|
} \
|
2011-10-22 18:52:18 +04:00
|
|
|
rc__; \
|
|
|
|
})
|
|
|
|
|
|
|
|
#define read_ptr_safe_eof(fd, ptr, err) \
|
|
|
|
read_safe_eof(fd, ptr, sizeof(*(ptr)), err)
|
2011-09-23 12:00:45 +04:00
|
|
|
|
2011-10-22 20:41:31 +04:00
|
|
|
#define memzero_p(p) memset(p, 0, sizeof(*p))
|
|
|
|
#define memzero(p, size) memset(p, 0, size)
|
2011-09-23 12:00:45 +04:00
|
|
|
|
2011-12-19 21:46:03 +04:00
|
|
|
extern void printk_siginfo(siginfo_t *siginfo);
|
2011-09-23 12:00:45 +04:00
|
|
|
|
|
|
|
struct vma_area;
|
|
|
|
struct list_head;
|
|
|
|
|
2011-12-19 21:46:03 +04:00
|
|
|
extern void printk_vma(struct vma_area *vma_area);
|
2011-09-23 12:00:45 +04:00
|
|
|
|
|
|
|
#define pr_info_vma_list(head) \
|
|
|
|
do { \
|
|
|
|
struct vma_area *vma; \
|
|
|
|
list_for_each_entry(vma, head, list) \
|
|
|
|
pr_info_vma(vma); \
|
|
|
|
} while (0)
|
|
|
|
|
2011-11-15 13:37:17 +04:00
|
|
|
/* Note while VMA_AREA_NONE we rely on xzalloc */
|
2011-09-23 12:00:45 +04:00
|
|
|
#define alloc_vma_area() \
|
|
|
|
({ \
|
|
|
|
struct vma_area *p__ = xzalloc(sizeof(*p__)); \
|
|
|
|
if (p__) { \
|
|
|
|
p__->shmid = -1; \
|
|
|
|
p__->vm_file_fd = -1; \
|
|
|
|
p__->vma.fd = -1; \
|
|
|
|
} \
|
|
|
|
p__; \
|
|
|
|
})
|
|
|
|
|
|
|
|
#define pr_info_vma(vma_area) printk_vma(vma_area)
|
|
|
|
#define pr_info_siginfo(siginfo) printk_siginfo(siginfo)
|
|
|
|
|
2011-12-26 21:48:00 +04:00
|
|
|
extern int move_img_fd(int *img_fd, int want_fd);
|
2011-12-19 21:46:03 +04:00
|
|
|
extern int close_safe(int *fd);
|
2011-09-23 12:00:45 +04:00
|
|
|
|
2012-01-13 13:15:57 +04:00
|
|
|
extern int reopen_fd_as_safe(int new_fd, int old_fd, bool allow_reuse_fd);
|
|
|
|
#define reopen_fd_as(new_fd, old_fd) reopen_fd_as_safe(new_fd, old_fd, false)
|
|
|
|
#define reopen_fd_as_nocheck(new_fd, old_fd) reopen_fd_as_safe(new_fd, old_fd, true)
|
|
|
|
|
2011-12-19 21:46:03 +04:00
|
|
|
extern void hex_dump(void *addr, unsigned long len);
|
2011-10-26 10:10:19 +04:00
|
|
|
|
2012-01-12 23:50:45 +04:00
|
|
|
int open_pid_proc(pid_t pid);
|
|
|
|
int open_proc(int pid_dir_fd, char *fmt, ...);
|
|
|
|
DIR *opendir_proc(int pid_dir_fd, char *fmt, ...);
|
|
|
|
FILE *fopen_proc(int pid_dir_fd, char *fmt, ...);
|
2011-10-24 13:43:21 +04:00
|
|
|
|
2011-09-23 12:00:45 +04:00
|
|
|
#define __xalloc(op, size, ...) \
|
|
|
|
({ \
|
|
|
|
void *___p = op( __VA_ARGS__ ); \
|
|
|
|
if (!___p) \
|
2011-09-30 14:37:12 +04:00
|
|
|
pr_err("%s: Can't allocate %li bytes\n", \
|
|
|
|
__func__, (long)(size)); \
|
2011-09-23 12:00:45 +04:00
|
|
|
___p; \
|
|
|
|
})
|
|
|
|
|
2011-10-20 01:41:02 +04:00
|
|
|
#define xstrdup(str) __xalloc(strdup, strlen(str) + 1, str)
|
2011-09-23 12:00:45 +04:00
|
|
|
#define xmalloc(size) __xalloc(malloc, size, size)
|
|
|
|
#define xzalloc(size) __xalloc(calloc, size, 1, size)
|
|
|
|
#define xrealloc(p, size) __xalloc(realloc, size, p, size)
|
|
|
|
|
|
|
|
#define xfree(p) if (p) free(p)
|
|
|
|
|
|
|
|
#define xrealloc_safe(pptr, size) \
|
|
|
|
({ \
|
|
|
|
int __ret = -1; \
|
|
|
|
void *new = xrealloc(*pptr, size); \
|
|
|
|
if (new) { \
|
|
|
|
*pptr = new; \
|
|
|
|
__ret = 0; \
|
|
|
|
} \
|
|
|
|
__ret; \
|
|
|
|
})
|
|
|
|
|
2012-01-12 15:16:33 +04:00
|
|
|
#define pr_img_head(type, ...) pr_info("\n"#type __VA_ARGS__ "\n----------------\n")
|
2012-01-14 15:03:38 +04:00
|
|
|
#define pr_img_tail(type) pr_info("----------------\n")
|
2012-01-12 15:16:33 +04:00
|
|
|
|
2011-09-23 12:00:45 +04:00
|
|
|
#endif /* UTIL_H_ */
|