Merge tag 'for-4.18-rc2-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave...
[platform/kernel/linux-rpi.git] / tools / bpf / bpf_exp.l
1 /*
2  * BPF asm code lexer
3  *
4  * This program is free software; you can distribute it and/or modify
5  * it under the terms of the GNU General Public License as published
6  * by the Free Software Foundation; either version 2 of the License,
7  * or (at your option) any later version.
8  *
9  * Syntax kept close to:
10  *
11  * Steven McCanne and Van Jacobson. 1993. The BSD packet filter: a new
12  * architecture for user-level packet capture. In Proceedings of the
13  * USENIX Winter 1993 Conference Proceedings on USENIX Winter 1993
14  * Conference Proceedings (USENIX'93). USENIX Association, Berkeley,
15  * CA, USA, 2-2.
16  *
17  * Copyright 2013 Daniel Borkmann <borkmann@redhat.com>
18  * Licensed under the GNU General Public License, version 2.0 (GPLv2)
19  */
20
21 %{
22
23 #include <stdio.h>
24 #include <stdint.h>
25 #include <stdlib.h>
26 #include <string.h>
27
28 #include <linux/filter.h>
29
30 #include "bpf_exp.yacc.h"
31
32 extern void yyerror(const char *str);
33
34 %}
35
36 %option align
37 %option ecs
38
39 %option nounput
40 %option noreject
41 %option noinput
42 %option noyywrap
43
44 %option 8bit
45 %option caseless
46 %option yylineno
47
48 %%
49
50 "ldb"           { return OP_LDB; }
51 "ldh"           { return OP_LDH; }
52 "ld"            { return OP_LD; }
53 "ldi"           { return OP_LDI; }
54 "ldx"           { return OP_LDX; }
55 "ldxi"          { return OP_LDXI; }
56 "ldxb"          { return OP_LDXB; }
57 "st"            { return OP_ST; }
58 "stx"           { return OP_STX; }
59 "jmp"           { return OP_JMP; }
60 "ja"            { return OP_JMP; }
61 "jeq"           { return OP_JEQ; }
62 "jneq"          { return OP_JNEQ; }
63 "jne"           { return OP_JNEQ; }
64 "jlt"           { return OP_JLT; }
65 "jle"           { return OP_JLE; }
66 "jgt"           { return OP_JGT; }
67 "jge"           { return OP_JGE; }
68 "jset"          { return OP_JSET; }
69 "add"           { return OP_ADD; }
70 "sub"           { return OP_SUB; }
71 "mul"           { return OP_MUL; }
72 "div"           { return OP_DIV; }
73 "mod"           { return OP_MOD; }
74 "neg"           { return OP_NEG; }
75 "and"           { return OP_AND; }
76 "xor"           { return OP_XOR; }
77 "or"            { return OP_OR; }
78 "lsh"           { return OP_LSH; }
79 "rsh"           { return OP_RSH; }
80 "ret"           { return OP_RET; }
81 "tax"           { return OP_TAX; }
82 "txa"           { return OP_TXA; }
83
84 "#"?("len")     { return K_PKT_LEN; }
85
86 "#"?("proto")   {
87                 yylval.number = SKF_AD_PROTOCOL;
88                 return extension;
89         }
90 "#"?("type")    {
91                 yylval.number = SKF_AD_PKTTYPE;
92                 return extension;
93         }
94 "#"?("poff")    {
95                 yylval.number = SKF_AD_PAY_OFFSET;
96                 return extension;
97         }
98 "#"?("ifidx")   {
99                 yylval.number = SKF_AD_IFINDEX;
100                 return extension;
101         }
102 "#"?("nla")     {
103                 yylval.number = SKF_AD_NLATTR;
104                 return extension;
105         }
106 "#"?("nlan")    {
107                 yylval.number = SKF_AD_NLATTR_NEST;
108                 return extension;
109         }
110 "#"?("mark")    {
111                 yylval.number = SKF_AD_MARK;
112                 return extension;
113         }
114 "#"?("queue")   {
115                 yylval.number = SKF_AD_QUEUE;
116                 return extension;
117         }
118 "#"?("hatype")  {
119                 yylval.number = SKF_AD_HATYPE;
120                 return extension;
121         }
122 "#"?("rxhash")  {
123                 yylval.number = SKF_AD_RXHASH;
124                 return extension;
125         }
126 "#"?("cpu")     {
127                 yylval.number = SKF_AD_CPU;
128                 return extension;
129         }
130 "#"?("vlan_tci") {
131                 yylval.number = SKF_AD_VLAN_TAG;
132                 return extension;
133         }
134 "#"?("vlan_pr") {
135                 yylval.number = SKF_AD_VLAN_TAG_PRESENT;
136                 return extension;
137         }
138 "#"?("vlan_avail") {
139                 yylval.number = SKF_AD_VLAN_TAG_PRESENT;
140                 return extension;
141         }
142 "#"?("vlan_tpid") {
143                 yylval.number = SKF_AD_VLAN_TPID;
144                 return extension;
145         }
146 "#"?("rand")    {
147                 yylval.number = SKF_AD_RANDOM;
148                 return extension;
149         }
150
151 ":"             { return ':'; }
152 ","             { return ','; }
153 "#"             { return '#'; }
154 "%"             { return '%'; }
155 "["             { return '['; }
156 "]"             { return ']'; }
157 "("             { return '('; }
158 ")"             { return ')'; }
159 "x"             { return 'x'; }
160 "a"             { return 'a'; }
161 "+"             { return '+'; }
162 "M"             { return 'M'; }
163 "*"             { return '*'; }
164 "&"             { return '&'; }
165
166 ([0][x][a-fA-F0-9]+) {
167                         yylval.number = strtoul(yytext, NULL, 16);
168                         return number;
169                 }
170 ([0][b][0-1]+)  {
171                         yylval.number = strtol(yytext + 2, NULL, 2);
172                         return number;
173                 }
174 (([0])|([-+]?[1-9][0-9]*)) {
175                         yylval.number = strtol(yytext, NULL, 10);
176                         return number;
177                 }
178 ([0][0-7]+)     {
179                         yylval.number = strtol(yytext + 1, NULL, 8);
180                         return number;
181                 }
182 [a-zA-Z_][a-zA-Z0-9_]+ {
183                         yylval.label = strdup(yytext);
184                         return label;
185                 }
186
187 "/*"([^\*]|\*[^/])*"*/"         { /* NOP */ }
188 ";"[^\n]*                       { /* NOP */ }
189 ^#.*                            { /* NOP */ }
190 [ \t]+                          { /* NOP */ }
191 [ \n]+                          { /* NOP */ }
192
193 .               {
194                         printf("unknown character \'%s\'", yytext);
195                         yyerror("lex unknown character");
196                 }
197
198 %%