File: loc2c-runtime.h

package info (click to toggle)
systemtap 2.6-0.2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 21,220 kB
  • ctags: 10,944
  • sloc: cpp: 53,239; ansic: 50,615; exp: 33,694; sh: 9,906; xml: 7,665; perl: 2,089; python: 1,534; tcl: 1,236; makefile: 797; java: 148; lisp: 104; awk: 94; asm: 91; sed: 16
file content (78 lines) | stat: -rw-r--r-- 2,361 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/* target operations in the Dyninst mode
 * Copyright (C) 2012 Red Hat Inc.
 *
 * This file is part of systemtap, and is free software.  You can
 * redistribute it and/or modify it under the terms of the GNU General
 * Public License (GPL); either version 2, or (at your option) any
 * later version.
 */

#ifndef _STAPDYN_LOC2C_RUNTIME_H_
#define _STAPDYN_LOC2C_RUNTIME_H_

#include "../loc2c-runtime.h"

#define __get_user_asm(x, addr, err, itype, rtype, ltype, errret)	\
        (err) = __get_user((x), (typeof(x)*)(uintptr_t)(addr))

#define __put_user_asm(x, addr, err, itype, rtype, ltype, errret)	\
        (err) = __put_user((x), (typeof(x)*)(uintptr_t)(addr))


#define u_fetch_register(regno) \
  pt_regs_fetch_register(c->uregs, regno)
#define u_store_register(regno, value) \
  pt_regs_store_register(c->uregs, regno, value)

#if defined(__i386__)
// The kernel's way of getting esp doesn't work as an lvalue
#undef pt_dwarf_register_4
#define pt_dwarf_register_4(regs)	regs->esp
#endif


#define uread(ptr) ({ \
	typeof(*(ptr)) _v = 0; \
	if (__copy_from_user((void *)&_v, (void *)(ptr), sizeof(*(ptr)))) \
	    DEREF_FAULT(ptr); \
	_v; \
    })

#define uwrite(ptr, value) ({ \
	typeof(*(ptr)) _v; \
	_v = (typeof(*(ptr)))(value); \
	if (__copy_to_user((void *)(ptr), (void *)&_v, sizeof(*(ptr)))) \
	    STORE_DEREF_FAULT(ptr); \
    })

#define uderef(size, addr) ({ \
    intptr_t _i = 0; \
    switch (size) { \
        case 1: _i = uread((u8 *)(uintptr_t)(addr)); break; \
        case 2: _i = uread((u16 *)(uintptr_t)(addr)); break;    \
        case 4: _i = uread((u32 *)(uintptr_t)(addr)); break;        \
        case 8: _i = uread((u64 *)(uintptr_t)(addr)); break;            \
	default: __get_user_bad(); \
    } \
    _i; \
  })

#define store_uderef(size, addr, value) ({ \
    switch (size) { \
        case 1: uwrite((u8 *)(uintptr_t)(addr), (value)); break;    \
        case 2: uwrite((u16 *)(uintptr_t)(addr), (value)); break;   \
        case 4: uwrite((u32 *)(uintptr_t)(addr), (value)); break;   \
        case 8: uwrite((u64 *)(uintptr_t)(addr), (value)); break;   \
	default: __put_user_bad(); \
    } \
  })


/* We still need to clean the runtime more before these can go away... */
#define kread uread
#define kwrite uwrite
#define kderef uderef
#define store_kderef store_uderef


#endif /* _STAPDYN_LOC2C_RUNTIME_H_ */