Peter Oberparleiter | 2521f2c | 2009-06-17 16:28:08 -0700 | [diff] [blame^] | 1 | /* |
| 2 | * Profiling infrastructure declarations. |
| 3 | * |
| 4 | * This file is based on gcc-internal definitions. Data structures are |
| 5 | * defined to be compatible with gcc counterparts. For a better |
| 6 | * understanding, refer to gcc source: gcc/gcov-io.h. |
| 7 | * |
| 8 | * Copyright IBM Corp. 2009 |
| 9 | * Author(s): Peter Oberparleiter <oberpar@linux.vnet.ibm.com> |
| 10 | * |
| 11 | * Uses gcc-internal data definitions. |
| 12 | */ |
| 13 | |
| 14 | #ifndef GCOV_H |
| 15 | #define GCOV_H GCOV_H |
| 16 | |
| 17 | #include <linux/types.h> |
| 18 | |
| 19 | /* |
| 20 | * Profiling data types used for gcc 3.4 and above - these are defined by |
| 21 | * gcc and need to be kept as close to the original definition as possible to |
| 22 | * remain compatible. |
| 23 | */ |
| 24 | #define GCOV_COUNTERS 5 |
| 25 | #define GCOV_DATA_MAGIC ((unsigned int) 0x67636461) |
| 26 | #define GCOV_TAG_FUNCTION ((unsigned int) 0x01000000) |
| 27 | #define GCOV_TAG_COUNTER_BASE ((unsigned int) 0x01a10000) |
| 28 | #define GCOV_TAG_FOR_COUNTER(count) \ |
| 29 | (GCOV_TAG_COUNTER_BASE + ((unsigned int) (count) << 17)) |
| 30 | |
| 31 | #if BITS_PER_LONG >= 64 |
| 32 | typedef long gcov_type; |
| 33 | #else |
| 34 | typedef long long gcov_type; |
| 35 | #endif |
| 36 | |
| 37 | /** |
| 38 | * struct gcov_fn_info - profiling meta data per function |
| 39 | * @ident: object file-unique function identifier |
| 40 | * @checksum: function checksum |
| 41 | * @n_ctrs: number of values per counter type belonging to this function |
| 42 | * |
| 43 | * This data is generated by gcc during compilation and doesn't change |
| 44 | * at run-time. |
| 45 | */ |
| 46 | struct gcov_fn_info { |
| 47 | unsigned int ident; |
| 48 | unsigned int checksum; |
| 49 | unsigned int n_ctrs[0]; |
| 50 | }; |
| 51 | |
| 52 | /** |
| 53 | * struct gcov_ctr_info - profiling data per counter type |
| 54 | * @num: number of counter values for this type |
| 55 | * @values: array of counter values for this type |
| 56 | * @merge: merge function for counter values of this type (unused) |
| 57 | * |
| 58 | * This data is generated by gcc during compilation and doesn't change |
| 59 | * at run-time with the exception of the values array. |
| 60 | */ |
| 61 | struct gcov_ctr_info { |
| 62 | unsigned int num; |
| 63 | gcov_type *values; |
| 64 | void (*merge)(gcov_type *, unsigned int); |
| 65 | }; |
| 66 | |
| 67 | /** |
| 68 | * struct gcov_info - profiling data per object file |
| 69 | * @version: gcov version magic indicating the gcc version used for compilation |
| 70 | * @next: list head for a singly-linked list |
| 71 | * @stamp: time stamp |
| 72 | * @filename: name of the associated gcov data file |
| 73 | * @n_functions: number of instrumented functions |
| 74 | * @functions: function data |
| 75 | * @ctr_mask: mask specifying which counter types are active |
| 76 | * @counts: counter data per counter type |
| 77 | * |
| 78 | * This data is generated by gcc during compilation and doesn't change |
| 79 | * at run-time with the exception of the next pointer. |
| 80 | */ |
| 81 | struct gcov_info { |
| 82 | unsigned int version; |
| 83 | struct gcov_info *next; |
| 84 | unsigned int stamp; |
| 85 | const char *filename; |
| 86 | unsigned int n_functions; |
| 87 | const struct gcov_fn_info *functions; |
| 88 | unsigned int ctr_mask; |
| 89 | struct gcov_ctr_info counts[0]; |
| 90 | }; |
| 91 | |
| 92 | /* Base interface. */ |
| 93 | enum gcov_action { |
| 94 | GCOV_ADD, |
| 95 | GCOV_REMOVE, |
| 96 | }; |
| 97 | |
| 98 | void gcov_event(enum gcov_action action, struct gcov_info *info); |
| 99 | void gcov_enable_events(void); |
| 100 | |
| 101 | /* Iterator control. */ |
| 102 | struct seq_file; |
| 103 | struct gcov_iterator; |
| 104 | |
| 105 | struct gcov_iterator *gcov_iter_new(struct gcov_info *info); |
| 106 | void gcov_iter_free(struct gcov_iterator *iter); |
| 107 | void gcov_iter_start(struct gcov_iterator *iter); |
| 108 | int gcov_iter_next(struct gcov_iterator *iter); |
| 109 | int gcov_iter_write(struct gcov_iterator *iter, struct seq_file *seq); |
| 110 | struct gcov_info *gcov_iter_get_info(struct gcov_iterator *iter); |
| 111 | |
| 112 | /* gcov_info control. */ |
| 113 | void gcov_info_reset(struct gcov_info *info); |
| 114 | int gcov_info_is_compatible(struct gcov_info *info1, struct gcov_info *info2); |
| 115 | void gcov_info_add(struct gcov_info *dest, struct gcov_info *source); |
| 116 | struct gcov_info *gcov_info_dup(struct gcov_info *info); |
| 117 | void gcov_info_free(struct gcov_info *info); |
| 118 | |
| 119 | struct gcov_link { |
| 120 | enum { |
| 121 | OBJ_TREE, |
| 122 | SRC_TREE, |
| 123 | } dir; |
| 124 | const char *ext; |
| 125 | }; |
| 126 | extern const struct gcov_link gcov_link[]; |
| 127 | |
| 128 | #endif /* GCOV_H */ |