Contributors: 7
Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
Jiri Olsa |
82 |
57.34% |
1 |
10.00% |
Arnaldo Carvalho de Melo |
29 |
20.28% |
1 |
10.00% |
Namhyung Kim |
14 |
9.79% |
1 |
10.00% |
Tzvetomir Stoyanov (VMware) |
9 |
6.29% |
4 |
40.00% |
Mark Rutland |
4 |
2.80% |
1 |
10.00% |
Tzvetomir Stoyanov |
4 |
2.80% |
1 |
10.00% |
Greg Kroah-Hartman |
1 |
0.70% |
1 |
10.00% |
Total |
143 |
|
10 |
|
// SPDX-License-Identifier: GPL-2.0
#include <stdio.h>
#include <string.h>
#include <inttypes.h>
#include <endian.h>
#include "event-parse.h"
/*
* From glibc endian.h, for older systems where it is not present, e.g.: RHEL5,
* Fedora6.
*/
#ifndef le16toh
# if __BYTE_ORDER == __LITTLE_ENDIAN
# define le16toh(x) (x)
# else
# define le16toh(x) __bswap_16 (x)
# endif
#endif
static unsigned long long
process___le16_to_cpup(struct trace_seq *s, unsigned long long *args)
{
uint16_t *val = (uint16_t *) (unsigned long) args[0];
return val ? (long long) le16toh(*val) : 0;
}
int TEP_PLUGIN_LOADER(struct tep_handle *tep)
{
tep_register_print_function(tep,
process___le16_to_cpup,
TEP_FUNC_ARG_INT,
"__le16_to_cpup",
TEP_FUNC_ARG_PTR,
TEP_FUNC_ARG_VOID);
return 0;
}
void TEP_PLUGIN_UNLOADER(struct tep_handle *tep)
{
tep_unregister_print_function(tep, process___le16_to_cpup,
"__le16_to_cpup");
}