#include #include #include "tests.h" #include "event.h" #include "evlist.h" #include "header.h" #include "util.h" #include "debug.h" static int process_event(struct perf_evlist **pevlist, union perf_event *event) { struct perf_sample sample; if (event->header.type == PERF_RECORD_HEADER_ATTR) { if (perf_event__process_attr(NULL, event, pevlist)) { pr_debug("perf_event__process_attr failed\n"); return -1; } return 0; } if (event->header.type >= PERF_RECORD_USER_TYPE_START) return -1; if (!*pevlist) return -1; if (perf_evlist__parse_sample(*pevlist, event, &sample)) { pr_debug("perf_evlist__parse_sample failed\n"); return -1; } return 0; } static int process_events(union perf_event **events, size_t count) { struct perf_evlist *evlist = NULL; int err = 0; size_t i; for (i = 0; i < count && !err; i++) err = process_event(&evlist, events[i]); perf_evlist__delete(evlist); return err; } struct test_attr_event { struct attr_event attr; u64 id; }; /** * test__parse_no_sample_id_all - test parsing with no sample_id_all bit set. * * This function tests parsing data produced on kernel's that do not support the * sample_id_all bit. Without the sample_id_all bit, non-sample events (such as * mmap events) do not have an id sample appended, and consequently logic * designed to determine the id will not work. That case happens when there is * more than one selected event, so this test processes three events: 2 * attributes representing the selected events and one mmap event. * * Return: %0 on success, %-1 if the test fails. */ int test__parse_no_sample_id_all(int subtest __maybe_unused) { int err; struct test_attr_event event1 = { .attr = { .header = { .type = PERF_RECORD_HEADER_ATTR, .size = sizeof(struct test_attr_event), }, }, .id = 1, }; struct test_attr_event event2 = { .attr = { .header = { .type = PERF_RECORD_HEADER_ATTR, .size = sizeof(struct test_attr_event), }, }, .id = 2, }; struct mmap_event event3 = { .header = { .type = PERF_RECORD_MMAP, .size = sizeof(struct mmap_event), }, }; union perf_event *events[] = { (union perf_event *)&event1, (union perf_event *)&event2, (union perf_event *)&event3, }; err = process_events(events, ARRAY_SIZE(events)); if (err) return -1; return 0; } itter
diff options
context:
space:
mode:
authorRoger Shimizu <rogershimizu@gmail.com>2017-01-30 20:07:29 +0900
committerGregory CLEMENT <gregory.clement@free-electrons.com>2017-01-31 12:19:32 +0100
commit81917bad86a66f2bdcb12b4c10ab1bf333ed25ec (patch)
tree3d56cb771fc5f0a37412e62f99aacc6d21a646c0 /net/9p/Makefile
parent0c744ea4f77d72b3dcebb7a8f2684633ec79be88 (diff)
ARM: dts: orion5x-lschl: Fix model name
Model name should be consistent with legacy device file, so that user can migrate their system from legacy device support to device-tree safely. Legacy device file is currently removed, but it can be found on 4.8 or previous version of linux: arch/arm/mach-orion5x/ls-chl-setup.c Fixes: f94f268979a2 ("ARM: dts: orion5x: convert ls-chl to FDT") Cc: Ashley Hughes <ashley.hughes@blueyonder.co.uk> Signed-off-by: Roger Shimizu <rogershimizu@gmail.com> Signed-off-by: Gregory CLEMENT <gregory.clement@free-electrons.com>
Diffstat (limited to 'net/9p/Makefile')