#include #include "event.h" #include "tests.h" #include "stat.h" #include "counts.h" #include "debug.h" static bool has_term(struct stat_config_event *config, u64 tag, u64 val) { unsigned i; for (i = 0; i < config->nr; i++) { if ((config->data[i].tag == tag) && (config->data[i].val == val)) return true; } return false; } static int process_stat_config_event(struct perf_tool *tool __maybe_unused, union perf_event *event, struct perf_sample *sample __maybe_unused, struct machine *machine __maybe_unused) { struct stat_config_event *config = &event->stat_config; struct perf_stat_config stat_config; #define HAS(term, val) \ has_term(config, PERF_STAT_CONFIG_TERM__##term, val) TEST_ASSERT_VAL("wrong nr", config->nr == PERF_STAT_CONFIG_TERM__MAX); TEST_ASSERT_VAL("wrong aggr_mode", HAS(AGGR_MODE, AGGR_CORE)); TEST_ASSERT_VAL("wrong scale", HAS(SCALE, 1)); TEST_ASSERT_VAL("wrong interval", HAS(INTERVAL, 1)); #undef HAS perf_event__read_stat_config(&stat_config, config); TEST_ASSERT_VAL("wrong aggr_mode", stat_config.aggr_mode == AGGR_CORE); TEST_ASSERT_VAL("wrong scale", stat_config.scale == 1); TEST_ASSERT_VAL("wrong interval", stat_config.interval == 1); return 0; } int test__synthesize_stat_config(int subtest __maybe_unused) { struct perf_stat_config stat_config = { .aggr_mode = AGGR_CORE, .scale = 1, .interval = 1, }; TEST_ASSERT_VAL("failed to synthesize stat_config", !perf_event__synthesize_stat_config(NULL, &stat_config, process_stat_config_event, NULL)); return 0; } static int process_stat_event(struct perf_tool *tool __maybe_unused, union perf_event *event, struct perf_sample *sample __maybe_unused, struct machine *machine __maybe_unused) { struct stat_event *st = &event->stat; TEST_ASSERT_VAL("wrong cpu", st->cpu == 1); TEST_ASSERT_VAL("wrong thread", st->thread == 2); TEST_ASSERT_VAL("wrong id", st->id == 3); TEST_ASSERT_VAL("wrong val", st->val == 100); TEST_ASSERT_VAL("wrong run", st->ena == 200); TEST_ASSERT_VAL("wrong ena", st->run == 300); return 0; } int test__synthesize_stat(int subtest __maybe_unused) { struct perf_counts_values count; count.val = 100; count.ena = 200; count.run = 300; TEST_ASSERT_VAL("failed to synthesize stat_config", !perf_event__synthesize_stat(NULL, 1, 2, 3, &count, process_stat_event, NULL)); return 0; } static int process_stat_round_event(struct perf_tool *tool __maybe_unused, union perf_event *event, struct perf_sample *sample __maybe_unused, struct machine *machine __maybe_unused) { struct stat_round_event *stat_round = &event->stat_round; TEST_ASSERT_VAL("wrong time", stat_round->time == 0xdeadbeef); TEST_ASSERT_VAL("wrong type", stat_round->type == PERF_STAT_ROUND_TYPE__INTERVAL); return 0; } int test__synthesize_stat_round(int subtest __maybe_unused) { TEST_ASSERT_VAL("failed to synthesize stat_config", !perf_event__synthesize_stat_round(NULL, 0xdeadbeef, PERF_STAT_ROUND_TYPE__INTERVAL, process_stat_round_event, NULL)); return 0; } move&id=72df5eba704252e54b5b19395cb938f8bb55cab8'>drivers/usb/musb/blackfin.h
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-02-06 14:37:55 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-02-06 14:37:55 -0800
commit72df5eba704252e54b5b19395cb938f8bb55cab8 (patch)
tree9b9dd6aa0cd3b6cda738de32dd05075e6e66bab1 /drivers/usb/musb/blackfin.h
parent396bf4cd835e62d70fad4a03a8963e61f19021f2 (diff)
parentf9f96fc10c09ca16e336854c08bc1563eed97985 (diff)
Merge tag 'media/v4.10-3' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media
Pull media fixes from Mauro Carvalho Chehab: "A few documentation fixes at CEC (with got promoted from staging for 4.10), and one fix on its core." * tag 'media/v4.10-3' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media: [media] cec: fix wrong last_la determination [media] cec-intro.rst: mention the v4l-utils package and CEC utilities [media] cec rst: remove "This API is not yet finalized" notice
Diffstat (limited to 'drivers/usb/musb/blackfin.h')