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