/* * netsniff-ng - the packet sniffing beast * By Daniel Borkmann * Copyright 2012 Daniel Borkmann , * Swiss federal institute of technology (ETH Zurich) * Subject to the GPL, version 2. */ /* lex-func-prefix: yy */ %{ #include #include #include #include #include #include "trafgen_parser.tab.h" #include "xmalloc.h" #include "built_in.h" extern void yyerror(const char *); static char *try_convert_shellcode(char *sstr) { bool found_any = false; char *bstr, *ostr = sstr, *hay, *orig = sstr; size_t j = 0, blen, slen = strlen(sstr), tot = 0; const char *needle = "\\x"; sstr++; slen -= 2; if (slen % 4 != 0) return orig; blen = slen / 4; hay = sstr; while ((hay = strstr(hay, needle)) != NULL ) { hay += strlen(needle) + 2; found_any = true; tot++; } if (blen != tot || !found_any) return orig; blen += 2; bstr = xzmalloc(blen); bstr[j++] = '\"'; while (j < blen - 1) bstr[j++] = (uint8_t) strtoul(sstr + 2, &sstr, 16); bstr[j++] = '\"'; xfree(ostr); return bstr; } %} %option align %option nounput %option noyywrap %option noreject %option 8bit %option caseless %option noinput %option nodefault number_oct ([0][0-9]+) number_hex ([0]?[x][a-fA-F0-9]+) number_bin ([0]?[b][0-1]+) number_dec (([0])|([1-9][0-9]*)) number_ascii ([a-zA-Z]) %% "cpu" { return K_CPU; } "fill" { return K_FILL; } "rnd" { return K_RND; } "csum16" { return K_CSUMIP; } "csumip" { return K_CSUMIP; } "csumip4" { return K_CSUMIP; } "csumicmp" { return K_CSUMIP; } "csumicmp4" { return K_CSUMIP; } "csumudp" { return K_CSUMUDP; } "csumtcp" { return K_CSUMTCP; } "drnd" { return K_DRND; } "dinc" { return K_DINC; } "ddec" { return K_DDEC; } "seqinc" { return K_SEQINC; } "seqdec" { return K_SEQDEC; } "const8"|"c8" { return K_CONST8; } "const16"|"c16" { return K_CONST16; } "const32"|"c32" { return K_CONST32; } "const64"|"c64" { return K_CONST64; } [ ]*"-"[ ]* { return '-'; } [ ]*"+"[ ]* { return '+'; } [ ]*"*"[ ]* { return '*'; } [ ]*"/"[ ]* { return '/'; } [ ]*"%"[ ]* { return '%'; } [ ]*"&"[ ]* { return '&'; } [ ]*"|"[ ]* { return '|'; } [ ]*"<"[ ]* { return '<'; } [ ]*">"[ ]* { return '>'; } [ ]*"^"[ ]* { return '^'; } "{" { return '{'; } "}" { return '}'; } "(" { return '('; } ")" { return ')'; } "[" { return '['; } "]" { return ']'; } "," { return ','; } ":" { return ':'; } "\n" { yylineno++; } "\""[^\"]+"\"" { yylval.str = try_convert_shellcode(xstrdup(yytext)); return string; } ([ \t\n]+)? { return K_WHITE; } "/*"([^\*]|\*[^/])*"*/" { return K_COMMENT; } "#"[^\n]* { return K_COMMENT; } {number_hex} { yylval.number = strtoul(yytext + (yytext[0] == 'x' ? 1 : 0), NULL, 16); return number; } {number_dec} { yylval.number = strtol(yytext, NULL, 10); return number; } {number_oct} { yylval.number = strtol(yytext + 1, NULL, 8); return number; } {number_bin} { yylval.number = strtol(yytext + (yytext[0] == 'b' ? 1 : 2), NULL, 2); return number; } {number_ascii} { yylval.number = (uint8_t) (*yytext); return number; } "'\\x"[a-fA-F0-9]{2}"'" { yylval.number = strtol(yytext + 3, NULL, 16); return number; } "'"."'" { yylval.number = (uint8_t) (*(yytext + 1)); return number; } ";"[^\n]* {/* NOP */} . { printf("Unknown character '%s'", yytext); yyerror("lex Unknown character"); } %% on value='0' selected='selected'>includemode:
authorImre Deak <imre.deak@intel.com>2016-06-28 13:37:30 +0300
committerJani Nikula <jani.nikula@intel.com>2016-06-29 11:17:31 +0300
commitea12e2a0cad62f6d634da62e7bf50ffe077de13b (patch)
treee7a5ef59911c10436774859fe75f7b9cd050654b
parent664a84d2c77cbff2945ed7f96d08afbba42b6293 (diff)
drm/i915/bxt: Avoid early timeout during PLL enable
Since wait_for_atomic doesn't re-check the wait-for condition after expiry of the timeout it can fail when called from non-atomic context even if the condition is set correctly before the expiry. Fix this by using the non-atomic wait_for instead. I noticed this via the PLL locking timing out incorrectly, with this fix I couldn't reproduce the problem. Fixes: 0351b93992aa ("drm/i915: Do not lie about atomic timeout granularity") CC: Chris Wilson <chris@chris-wilson.co.uk> CC: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Signed-off-by: Imre Deak <imre.deak@intel.com> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> CC: drm-intel-fixes@lists.freedesktop.org Link: http://patchwork.freedesktop.org/patch/msgid/1467110253-16046-2-git-send-email-imre.deak@intel.com (cherry picked from commit 0b786e41c73956126f6297764459021deef8aba7) Signed-off-by: Jani Nikula <jani.nikula@intel.com>