1*05b00f60SXin Li /* 2*05b00f60SXin Li * Copyright (C) Andrew Tridgell 1995-1999 3*05b00f60SXin Li * 4*05b00f60SXin Li * This software may be distributed either under the terms of the 5*05b00f60SXin Li * BSD-style license that accompanies tcpdump or the GNU GPL version 2 6*05b00f60SXin Li * or later 7*05b00f60SXin Li */ 8*05b00f60SXin Li 9*05b00f60SXin Li /* for netdissect_options */ 10*05b00f60SXin Li #include "netdissect.h" 11*05b00f60SXin Li 12*05b00f60SXin Li /* the complete */ 13*05b00f60SXin Li #define SMBmkdir 0x00 /* create directory */ 14*05b00f60SXin Li #define SMBrmdir 0x01 /* delete directory */ 15*05b00f60SXin Li #define SMBopen 0x02 /* open file */ 16*05b00f60SXin Li #define SMBcreate 0x03 /* create file */ 17*05b00f60SXin Li #define SMBclose 0x04 /* close file */ 18*05b00f60SXin Li #define SMBflush 0x05 /* flush file */ 19*05b00f60SXin Li #define SMBunlink 0x06 /* delete file */ 20*05b00f60SXin Li #define SMBmv 0x07 /* rename file */ 21*05b00f60SXin Li #define SMBgetatr 0x08 /* get file attributes */ 22*05b00f60SXin Li #define SMBsetatr 0x09 /* set file attributes */ 23*05b00f60SXin Li #define SMBread 0x0A /* read from file */ 24*05b00f60SXin Li #define SMBwrite 0x0B /* write to file */ 25*05b00f60SXin Li #define SMBlock 0x0C /* lock byte range */ 26*05b00f60SXin Li #define SMBunlock 0x0D /* unlock byte range */ 27*05b00f60SXin Li #define SMBctemp 0x0E /* create temporary file */ 28*05b00f60SXin Li #define SMBmknew 0x0F /* make new file */ 29*05b00f60SXin Li #define SMBchkpth 0x10 /* check directory path */ 30*05b00f60SXin Li #define SMBexit 0x11 /* process exit */ 31*05b00f60SXin Li #define SMBlseek 0x12 /* seek */ 32*05b00f60SXin Li #define SMBtcon 0x70 /* tree connect */ 33*05b00f60SXin Li #define SMBtconX 0x75 /* tree connect and X*/ 34*05b00f60SXin Li #define SMBtdis 0x71 /* tree disconnect */ 35*05b00f60SXin Li #define SMBnegprot 0x72 /* negotiate protocol */ 36*05b00f60SXin Li #define SMBdskattr 0x80 /* get disk attributes */ 37*05b00f60SXin Li #define SMBsearch 0x81 /* search directory */ 38*05b00f60SXin Li #define SMBsplopen 0xC0 /* open print spool file */ 39*05b00f60SXin Li #define SMBsplwr 0xC1 /* write to print spool file */ 40*05b00f60SXin Li #define SMBsplclose 0xC2 /* close print spool file */ 41*05b00f60SXin Li #define SMBsplretq 0xC3 /* return print queue */ 42*05b00f60SXin Li #define SMBsends 0xD0 /* send single block message */ 43*05b00f60SXin Li #define SMBsendb 0xD1 /* send broadcast message */ 44*05b00f60SXin Li #define SMBfwdname 0xD2 /* forward user name */ 45*05b00f60SXin Li #define SMBcancelf 0xD3 /* cancel forward */ 46*05b00f60SXin Li #define SMBgetmac 0xD4 /* get machine name */ 47*05b00f60SXin Li #define SMBsendstrt 0xD5 /* send start of multi-block message */ 48*05b00f60SXin Li #define SMBsendend 0xD6 /* send end of multi-block message */ 49*05b00f60SXin Li #define SMBsendtxt 0xD7 /* send text of multi-block message */ 50*05b00f60SXin Li 51*05b00f60SXin Li /* Core+ protocol */ 52*05b00f60SXin Li #define SMBlockread 0x13 /* Lock a range and read */ 53*05b00f60SXin Li #define SMBwriteunlock 0x14 /* Unlock a range then write */ 54*05b00f60SXin Li #define SMBreadbraw 0x1a /* read a block of data with no smb header */ 55*05b00f60SXin Li #define SMBwritebraw 0x1d /* write a block of data with no smb header */ 56*05b00f60SXin Li #define SMBwritec 0x20 /* secondary write request */ 57*05b00f60SXin Li #define SMBwriteclose 0x2c /* write a file then close it */ 58*05b00f60SXin Li 59*05b00f60SXin Li /* dos extended protocol */ 60*05b00f60SXin Li #define SMBreadBraw 0x1A /* read block raw */ 61*05b00f60SXin Li #define SMBreadBmpx 0x1B /* read block multiplexed */ 62*05b00f60SXin Li #define SMBreadBs 0x1C /* read block (secondary response) */ 63*05b00f60SXin Li #define SMBwriteBraw 0x1D /* write block raw */ 64*05b00f60SXin Li #define SMBwriteBmpx 0x1E /* write block multiplexed */ 65*05b00f60SXin Li #define SMBwriteBs 0x1F /* write block (secondary request) */ 66*05b00f60SXin Li #define SMBwriteC 0x20 /* write complete response */ 67*05b00f60SXin Li #define SMBsetattrE 0x22 /* set file attributes expanded */ 68*05b00f60SXin Li #define SMBgetattrE 0x23 /* get file attributes expanded */ 69*05b00f60SXin Li #define SMBlockingX 0x24 /* lock/unlock byte ranges and X */ 70*05b00f60SXin Li #define SMBtrans 0x25 /* transaction - name, bytes in/out */ 71*05b00f60SXin Li #define SMBtranss 0x26 /* transaction (secondary request/response) */ 72*05b00f60SXin Li #define SMBioctl 0x27 /* IOCTL */ 73*05b00f60SXin Li #define SMBioctls 0x28 /* IOCTL (secondary request/response) */ 74*05b00f60SXin Li #define SMBcopy 0x29 /* copy */ 75*05b00f60SXin Li #define SMBmove 0x2A /* move */ 76*05b00f60SXin Li #define SMBecho 0x2B /* echo */ 77*05b00f60SXin Li #define SMBopenX 0x2D /* open and X */ 78*05b00f60SXin Li #define SMBreadX 0x2E /* read and X */ 79*05b00f60SXin Li #define SMBwriteX 0x2F /* write and X */ 80*05b00f60SXin Li #define SMBsesssetupX 0x73 /* Session Set Up & X (including User Logon) */ 81*05b00f60SXin Li #define SMBffirst 0x82 /* find first */ 82*05b00f60SXin Li #define SMBfunique 0x83 /* find unique */ 83*05b00f60SXin Li #define SMBfclose 0x84 /* find close */ 84*05b00f60SXin Li #define SMBinvalid 0xFE /* invalid command */ 85*05b00f60SXin Li 86*05b00f60SXin Li /* Extended 2.0 protocol */ 87*05b00f60SXin Li #define SMBtrans2 0x32 /* TRANS2 protocol set */ 88*05b00f60SXin Li #define SMBtranss2 0x33 /* TRANS2 protocol set, secondary command */ 89*05b00f60SXin Li #define SMBfindclose 0x34 /* Terminate a TRANSACT2_FINDFIRST */ 90*05b00f60SXin Li #define SMBfindnclose 0x35 /* Terminate a TRANSACT2_FINDNOTIFYFIRST */ 91*05b00f60SXin Li #define SMBulogoffX 0x74 /* user logoff */ 92*05b00f60SXin Li 93*05b00f60SXin Li /* NT SMB extensions. */ 94*05b00f60SXin Li #define SMBnttrans 0xA0 /* NT transact */ 95*05b00f60SXin Li #define SMBnttranss 0xA1 /* NT transact secondary */ 96*05b00f60SXin Li #define SMBntcreateX 0xA2 /* NT create and X */ 97*05b00f60SXin Li #define SMBntcancel 0xA4 /* NT cancel */ 98*05b00f60SXin Li 99*05b00f60SXin Li /* pathworks special */ 100*05b00f60SXin Li #define pSETDIR '\377' 101*05b00f60SXin Li 102*05b00f60SXin Li 103*05b00f60SXin Li /* these are the TRANS2 sub commands */ 104*05b00f60SXin Li #define TRANSACT2_OPEN 0 105*05b00f60SXin Li #define TRANSACT2_FINDFIRST 1 106*05b00f60SXin Li #define TRANSACT2_FINDNEXT 2 107*05b00f60SXin Li #define TRANSACT2_QFSINFO 3 108*05b00f60SXin Li #define TRANSACT2_SETFSINFO 4 109*05b00f60SXin Li #define TRANSACT2_QPATHINFO 5 110*05b00f60SXin Li #define TRANSACT2_SETPATHINFO 6 111*05b00f60SXin Li #define TRANSACT2_QFILEINFO 7 112*05b00f60SXin Li #define TRANSACT2_SETFILEINFO 8 113*05b00f60SXin Li #define TRANSACT2_FSCTL 9 114*05b00f60SXin Li #define TRANSACT2_IOCTL 10 115*05b00f60SXin Li #define TRANSACT2_FINDNOTIFYFIRST 11 116*05b00f60SXin Li #define TRANSACT2_FINDNOTIFYNEXT 12 117*05b00f60SXin Li #define TRANSACT2_MKDIR 13 118*05b00f60SXin Li 119*05b00f60SXin Li /* some protos */ 120*05b00f60SXin Li void smb_reset(void); 121*05b00f60SXin Li const u_char *smb_fdata(netdissect_options *, const u_char *, const char *, const u_char *, int); 122*05b00f60SXin Li extern void smb_data_print(netdissect_options *, const u_char *, u_int); 123*05b00f60SXin Li extern const char *smb_errstr(int, int); 124*05b00f60SXin Li extern const char *nt_errstr(uint32_t); 125