Merge branch 'fix-m' into add-P
[blktrace.git] / act_mask.c
CommitLineData
98f8386b
AB
1#include <strings.h>
2#include "blktrace.h"
3
4#define DECLARE_MASK_MAP(mask) { BLK_TC_##mask, #mask, "BLK_TC_"#mask }
5#define COMPARE_MASK_MAP(mmp, str) \
6 (!strcasecmp((mmp)->short_form, (str)) || \
7 !strcasecmp((mmp)->long_form, (str)))
8
9struct mask_map {
10 int mask;
11 char *short_form;
12 char *long_form;
13};
14
15static struct mask_map mask_maps[] = {
16 DECLARE_MASK_MAP(READ),
17 DECLARE_MASK_MAP(WRITE),
18 DECLARE_MASK_MAP(BARRIER),
19 DECLARE_MASK_MAP(SYNC),
20 DECLARE_MASK_MAP(QUEUE),
21 DECLARE_MASK_MAP(REQUEUE),
22 DECLARE_MASK_MAP(ISSUE),
23 DECLARE_MASK_MAP(COMPLETE),
24 DECLARE_MASK_MAP(FS),
25 DECLARE_MASK_MAP(PC),
f86990ed 26 DECLARE_MASK_MAP(AHEAD),
711e4d25 27 DECLARE_MASK_MAP(META),
37081bf5 28 DECLARE_MASK_MAP(DISCARD),
c54b9dd9 29 DECLARE_MASK_MAP(DRV_DATA),
98f8386b
AB
30};
31
32int find_mask_map(char *string)
33{
34 unsigned int i;
35
36 for (i = 0; i < sizeof(mask_maps)/sizeof(mask_maps[0]); i++)
37 if (COMPARE_MASK_MAP(&mask_maps[i], string))
38 return mask_maps[i].mask;
39
40 return -1;
41}
42
43int valid_act_opt(int x)
44{
45 return (1 <= x) && (x < (1 << BLK_TC_SHIFT));
46}