1 %{ 2 /*- 3 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 4 * 5 * Copyright (c) 2012 The FreeBSD Foundation 6 * 7 * This software was developed by Edward Tomasz Napierala under sponsorship 8 * from the FreeBSD Foundation. 9 * 10 * Redistribution and use in source and binary forms, with or without 11 * modification, are permitted provided that the following conditions 12 * are met: 13 * 1. Redistributions of source code must retain the above copyright 14 * notice, this list of conditions and the following disclaimer. 15 * 2. Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in the 17 * documentation and/or other materials provided with the distribution. 18 * 19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 * SUCH DAMAGE. 30 * 31 * $FreeBSD$ 32 */ 33 34 #include <stdio.h> 35 #include <stdint.h> 36 #include <string.h> 37 38 #include "iscsictl.h" 39 #include "y.tab.h" 40 41 int lineno; 42 43 #define YY_DECL int yylex(void) 44 extern int yylex(void); 45 46 %} 47 48 %option noinput 49 %option nounput 50 %option noyywrap 51 52 %% 53 HeaderDigest { return HEADER_DIGEST; } 54 DataDigest { return DATA_DIGEST; } 55 TargetName { return TARGET_NAME; } 56 TargetAddress { return TARGET_ADDRESS; } 57 InitiatorName { return INITIATOR_NAME; } 58 InitiatorAddress { return INITIATOR_ADDRESS; } 59 InitiatorAlias { return INITIATOR_ALIAS; } 60 chapIName { return USER; } 61 chapSecret { return SECRET; } 62 tgtChapName { return MUTUAL_USER; } 63 tgtChapSecret { return MUTUAL_SECRET; } 64 AuthMethod { return AUTH_METHOD; } 65 SessionType { return SESSION_TYPE; } 66 enable { return ENABLE; } 67 protocol { return PROTOCOL; } 68 offload { return OFFLOAD; } 69 port { return IGNORED; } 70 dscp { return DSCP; } 71 pcp { return PCP; } 72 PingTimeout { return PINGTIMEOUT; } 73 LoginTimeout { return LOGINTIMEOUT; } 74 MaxConnections { return IGNORED; } 75 TargetAlias { return IGNORED; } 76 TargetPortalGroupTag { return IGNORED; } 77 InitialR2T { return IGNORED; } 78 ImmediateData { return IGNORED; } 79 MaxRecvDataSegmentLength { return IGNORED; } 80 MaxBurstLength { return IGNORED; } 81 FirstBurstLength { return IGNORED; } 82 DefaultTime2Wait { return IGNORED; } 83 DefaultTime2Retain { return IGNORED; } 84 MaxOutstandingR2T { return IGNORED; } 85 DataPDUInOrder { return IGNORED; } 86 DataSequenceInOrder { return IGNORED; } 87 ErrorRecoveryLevel { return IGNORED; } 88 tags { return IGNORED; } 89 maxluns { return IGNORED; } 90 sockbufsize { return IGNORED; } 91 chapDigest { return IGNORED; } 92 af11 { return AF11; } 93 af12 { return AF12; } 94 af13 { return AF13; } 95 af21 { return AF21; } 96 af22 { return AF22; } 97 af23 { return AF23; } 98 af31 { return AF31; } 99 af32 { return AF32; } 100 af33 { return AF33; } 101 af41 { return AF41; } 102 af42 { return AF42; } 103 af43 { return AF43; } 104 be { return CS0; } 105 ef { return EF; } 106 cs0 { return CS0; } 107 cs1 { return CS1; } 108 cs2 { return CS2; } 109 cs3 { return CS3; } 110 cs4 { return CS4; } 111 cs5 { return CS5; } 112 cs6 { return CS6; } 113 cs7 { return CS7; } 114 \"[^"]+\" { yylval.str = strndup(yytext + 1, 115 strlen(yytext) - 2); return STR; } 116 [a-zA-Z0-9\.\-_/\:\[\]]+ { yylval.str = strdup(yytext); return STR; } 117 \{ { return OPENING_BRACKET; } 118 \} { return CLOSING_BRACKET; } 119 = { return EQUALS; } 120 ; { return SEMICOLON; } 121 #.*$ /* ignore comments */; 122 \r\n { lineno++; } 123 \n { lineno++; } 124 [ \t]+ /* ignore whitespace */; 125 . { yylval.str = strdup(yytext); return STR; } 126 %% 127