iscontrol.h revision 171568
1/*- 2 * Copyright (c) 2005 Daniel Braniss <danny@cs.huji.ac.il> 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 * 26 * $FreeBSD: head/sbin/iscontrol/iscontrol.h 171568 2007-07-24 15:35:02Z scottl $ 27 */ 28/* 29 | $Id: iscontrol.h,v 2.3 2007/04/27 08:36:49 danny Exp danny $ 30 */ 31#ifdef DEBUG 32int vflag; 33 34# define debug(level, fmt, args...) do {if (level <= vflag) printf("%s: " fmt "\n", __func__ , ##args);} while(0) 35# define debug_called(level) do {if (level <= vflag) printf("%s: called\n", __func__);} while(0) 36#else 37# define debug(level, fmt, args...) 38# define debug_called(level) 39#endif // DEBUG 40#define xdebug(fmt, args...) printf("%s: " fmt "\n", __func__ , ##args) 41 42#define BIT(n) (1 <<(n)) 43 44#define MAXREDIRECTS 2 45 46typedef int auth_t(void *sess); 47 48typedef struct isess { 49 int flags; 50#define SESS_CONNECTED BIT(0) 51#define SESS_DISCONNECT BIT(1) 52#define SESS_LOGGEDIN BIT(2) 53#define SESS_RECONNECT BIT(3) 54#define SESS_REDIRECT BIT(4) 55 56#define SESS_NEGODONE BIT(10) // XXX: kludge 57 58#define SESS_FULLFEATURE BIT(29) 59#define SESS_INITIALLOGIN1 BIT(30) 60#define SESS_INITIALLOGIN BIT(31) 61 62 63 isc_opt_t *op; // operational values 64 int fd; // the session fd 65 int soc; // the socket 66 iscsi_cam_t cam; 67 struct cam_device *camdev; 68 69 time_t open_time; 70 int redirect_cnt; 71 time_t redirect_time; 72 int reconnect_cnt; 73 int reconnect_cnt1; 74 time_t reconnect_time; 75 char isid[6+1]; 76 int csg; // current stage 77 int nsg; // next stage 78 // Phases/Stages 79#define SN_PHASE 0 // Security Negotiation 80#define LON_PHASE 1 // Login Operational Negotiation 81#define FF_PHASE 3 // FuLL-Feature 82 uint tsih; 83 sn_t sn; 84} isess_t; 85 86typedef struct token { 87 char *name; 88 int val; 89} token_t; 90 91typedef enum { 92 NONE = 0, 93 KRB5, 94 SPKM1, 95 SPKM2, 96 SRP, 97 CHAP 98} authm_t; 99 100extern token_t AuthMethods[]; 101extern token_t DigestMethods[]; 102 103typedef enum { 104 SET, 105 GET 106} oper_t; 107 108typedef enum { 109 U_PR, // private 110 U_IO, // Initialize Only -- during login 111 U_LO, // Leading Only -- when TSIH is zero 112 U_FFPO, // Full Feature Phase Only 113 U_ALL // in any phase 114} usage_t; 115 116typedef enum { 117 S_PR, 118 S_CO, // Connect only 119 S_SW // Session Wide 120} scope_t; 121 122typedef void keyfun_t(isess_t *, oper_t); 123 124typedef struct { 125 usage_t usage; 126 scope_t scope; 127 char *name; 128 int tokenID; 129} textkey_t; 130 131typedef int handler_t(isess_t *sess, pdu_t *pp); 132 133int authenticateLogin(isess_t *sess); 134int fsm(isc_opt_t *op); 135int sendPDU(isess_t *sess, pdu_t *pp, handler_t *hdlr); 136int addText(pdu_t *pp, char *fmt, ...); 137void freePDU(pdu_t *pp); 138int xmitpdu(isess_t *sess, pdu_t *pp); 139int recvpdu(isess_t *sess, pdu_t *pp); 140void pukeText(char *it, pdu_t *pp); 141 142int lookup(token_t *tbl, char *m); 143 144int vflag; 145char *iscsidev; 146 147void parseArgs(int nargs, char **args, isc_opt_t *op); 148void parseConfig(FILE *fd, char *key, isc_opt_t *op); 149 150char *chapDigest(char *ap, char id, char *cp, char *chapSecret); 151char *genChapChallenge(char *encoding, int len); 152 153int str2bin(char *str, char **rsp); 154char *bin2str(char *fmt, unsigned char *md, int blen); 155 156int negotiateOPV(isess_t *sess); 157int setOptions(isess_t *sess, int flag); 158 159int loginPhase(isess_t *sess); 160