75 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *   fs/cifs/rfc1002pdu.h
 | |
|  *
 | |
|  *   Protocol Data Unit definitions for RFC 1001/1002 support
 | |
|  *
 | |
|  *   Copyright (c) International Business Machines  Corp., 2004
 | |
|  *   Author(s): Steve French (sfrench@us.ibm.com)
 | |
|  *
 | |
|  *   This library is free software; you can redistribute it and/or modify
 | |
|  *   it under the terms of the GNU Lesser General Public License as published
 | |
|  *   by the Free Software Foundation; either version 2.1 of the License, or
 | |
|  *   (at your option) any later version.
 | |
|  *
 | |
|  *   This library is distributed in the hope that it will be useful,
 | |
|  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
 | |
|  *   the GNU Lesser General Public License for more details.
 | |
|  *
 | |
|  *   You should have received a copy of the GNU Lesser General Public License
 | |
|  *   along with this library; if not, write to the Free Software
 | |
|  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 | |
|  */
 | |
| 
 | |
| /* NB: unlike smb/cifs packets, the RFC1002 structures are big endian */
 | |
| 
 | |
| 	/* RFC 1002 session packet types */
 | |
| #define RFC1002_SESSION_MESSAGE 0x00
 | |
| #define RFC1002_SESSION_REQUEST  0x81
 | |
| #define RFC1002_POSITIVE_SESSION_RESPONSE 0x82
 | |
| #define RFC1002_NEGATIVE_SESSION_RESPONSE 0x83
 | |
| #define RFC1002_RETARGET_SESSION_RESPONSE 0x84
 | |
| #define RFC1002_SESSION_KEEP_ALIVE 0x85
 | |
| 
 | |
| 	/* RFC 1002 flags (only one defined */
 | |
| #define RFC1002_LENGTH_EXTEND 0x80 /* high order bit of length (ie +64K) */
 | |
| 
 | |
| struct rfc1002_session_packet {
 | |
| 	__u8	type;
 | |
| 	__u8	flags;
 | |
| 	__u16	length;
 | |
| 	union {
 | |
| 		struct {
 | |
| 			__u8 called_len;
 | |
| 			__u8 called_name[32];
 | |
| 			__u8 scope1; /* null */
 | |
| 			__u8 calling_len;
 | |
| 			__u8 calling_name[32];
 | |
| 			__u8 scope2; /* null */
 | |
| 		} __attribute__((packed)) session_req;
 | |
| 		struct {
 | |
| 			__u32 retarget_ip_addr;
 | |
| 			__u16 port;
 | |
| 		} __attribute__((packed)) retarget_resp;
 | |
| 		__u8 neg_ses_resp_error_code;
 | |
| 		/* POSITIVE_SESSION_RESPONSE packet does not include trailer.
 | |
| 		SESSION_KEEP_ALIVE packet also does not include a trailer.
 | |
| 		Trailer for the SESSION_MESSAGE packet is SMB/CIFS header */
 | |
| 	} __attribute__((packed)) trailer;
 | |
| } __attribute__((packed));
 | |
| 
 | |
| /* Negative Session Response error codes */
 | |
| #define RFC1002_NOT_LISTENING_CALLED  0x80 /* not listening on called name */
 | |
| #define RFC1002_NOT_LISTENING_CALLING 0x81 /* not listening on calling name */
 | |
| #define RFC1002_NOT_PRESENT           0x82 /* called name not present */
 | |
| #define RFC1002_INSUFFICIENT_RESOURCE 0x83
 | |
| #define RFC1002_UNSPECIFIED_ERROR     0x8F
 | |
| 
 | |
| /* RFC 1002 Datagram service packets are not defined here as they
 | |
| are not needed for the network filesystem client unless we plan on
 | |
| implementing broadcast resolution of the server ip address (from
 | |
| server netbios name). Currently server names are resolved only via DNS
 | |
| (tcp name) or ip address or an /etc/hosts equivalent mapping to ip address.*/
 | |
| 
 | |
| #define DEFAULT_CIFS_CALLED_NAME  "*SMBSERVER      "
 | 
