|
|
1.1 root 1: /*
2: * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
3: *
4: * @APPLE_LICENSE_HEADER_START@
5: *
6: * The contents of this file constitute Original Code as defined in and
7: * are subject to the Apple Public Source License Version 1.1 (the
8: * "License"). You may not use this file except in compliance with the
9: * License. Please obtain a copy of the License at
10: * http://www.apple.com/publicsource and read it before using this file.
11: *
12: * This Original Code and all software distributed under the License are
13: * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14: * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15: * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16: * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17: * License for the specific language governing rights and limitations
18: * under the License.
19: *
20: * @APPLE_LICENSE_HEADER_END@
21: */
22:
23: /*
24: * Copyright (c) 1988, 1989 Apple Computer, Inc.
25: *
26: * Modified, March 17, 1997 by Tuyen Nguyen for MacOSX.
27: */
28:
29: #ifndef lint
30: /* static char sccsid[] = "@(#)sip.c: 2.0, 1.3; 10/18/93; Copyright 1988-89, Apple Computer, Inc."; */
31: #endif /* lint */
32:
33: /****************************************************************/
34: /* */
35: /* */
36: /* S I P */
37: /* System Information Protocol */
38: /* */
39: /* */
40: /****************************************************************/
41:
42: /* System Information Protocol -- implemented to handle Responder
43: * Queries. The queries are ATP requests, but the ATP responses are faked
44: * here in a DDP level handler routine. The responder socket is always
45: * the 1st socket in the dynamic socket range (128) and it is assumed
46: * that the node will be registered on that socket.
47: *
48: * In A/UX implementation, this implies that /etc/appletalk program will
49: * register the node name on socket DDP_SOCKET_1st_DYNAMIC (128).
50: */
51:
52: #include <sys/errno.h>
53: #include <sys/types.h>
54: #include <sys/param.h>
55: #include <machine/spl.h>
56: #include <sys/systm.h>
57: #include <sys/kernel.h>
58: #include <sys/proc.h>
59: #include <sys/filedesc.h>
60: #include <sys/fcntl.h>
61: #include <sys/mbuf.h>
62: #include <sys/ioctl.h>
63: #include <sys/malloc.h>
64: #include <sys/socket.h>
65: #include <sys/socketvar.h>
66:
67: #include <net/if.h>
68:
69: #include <netat/appletalk.h>
70: #include <netat/ddp.h>
71: #include <netat/sysglue.h> /* nbp.h needs the gbuf definiton */
72: #include <netat/nbp.h>
73: #include <netat/at_pcb.h>
74: #include <netat/at_var.h>
75: #include <netat/atp.h>
76:
77: #define SIP_SYSINFO_CMD 1
78: #define SIP_DATALINK_CMD 6
79:
80: #define SIP_GOOD_RESPONSE 0x1
81: #define SIP_BAD_RESPONSE 0xff
82:
83: #define SIP_DRIVER_VERSION 0x0001
84: #define SIP_RESPONDER_VERSION 0x0001
85:
86: typedef struct {
87: u_char response;
88: u_char unused;
89: u_short responder_version;
90: } sip_userbytes_t;
91:
92: void sip_input(mp, ifID)
93: gbuf_t *mp;
94: int *ifID; /* not used */
95: {
96: /* Packets arriving here are actually ATP packets, but since
97: * A/UX only send dummy responses, we're implementing responder as
98: * a DDP handler
99: */
100: register at_ddp_t *ddp;
101: register at_atp_t *atp;
102: register gbuf_t *tmp;
103: u_char *resp;
104: sip_userbytes_t ubytes;
105:
106: ddp = (at_ddp_t *)gbuf_rptr(mp);
107:
108: /* Make sure the packet we got is an ATP packet */
109: if (ddp->type != DDP_ATP) {
110: gbuf_freem(mp);
111: return;
112: }
113:
114: /* assuming that the whole packet is in one contiguous buffer */
115: atp = (at_atp_t *)ddp->data;
116:
117: switch(UAL_VALUE(atp->user_bytes)) {
118: case SIP_SYSINFO_CMD :
119: /* Sending a response with "AppleTalk driver version" (u_short)
120: * followed by 14 zeros will pacify the interpoll.
121: * What? You don't understand what it means to send 14 zeroes?
122: * Tsk, tsk, look up SIP protocol specs for details!!
123: */
124: if ((tmp = (gbuf_t *)ddp_growmsg(mp, 16)) == NULL) {
125: /* dont have buffers */
126: gbuf_freem(mp);
127: return;
128: }
129: if (tmp == mp)
130: /* extra space allocated on the same buffer block */
131: resp = atp->data;
132: else
133: resp = (u_char *)gbuf_rptr(tmp);
134: bzero(resp, 16);
135: *(u_short *)resp = SIP_DRIVER_VERSION;
136:
137: ubytes.response = SIP_GOOD_RESPONSE;
138: ubytes.unused = 0;
139: ubytes.responder_version = SIP_RESPONDER_VERSION;
140: break;
141: case SIP_DATALINK_CMD :
142: /* In this case, the magic spell is to send 2 zeroes after
143: * the "AppleTalk driver version".
144: */
145: if ((tmp = (gbuf_t *)ddp_growmsg(mp, 4)) == NULL) {
146: /* dont have buffers */
147: gbuf_freem(mp);
148: return;
149: }
150: if (tmp == mp)
151: /* extra space allocated on the same buffer block */
152: resp = atp->data;
153: else
154: resp = (u_char *)gbuf_rptr(tmp);
155: bzero(resp, 16);
156: *(u_short *)resp = SIP_DRIVER_VERSION;
157:
158: ubytes.response = SIP_GOOD_RESPONSE;
159: ubytes.unused = 0;
160: ubytes.responder_version = SIP_RESPONDER_VERSION;
161: break;
162: default :
163: /* bad request, send a bad command response back */
164: ubytes.response = SIP_BAD_RESPONSE;
165: ubytes.unused = 0;
166: ubytes.responder_version = SIP_RESPONDER_VERSION;
167: }
168:
169: NET_NET(ddp->dst_net, ddp->src_net);
170: ddp->dst_node = ddp->src_node;
171: ddp->dst_socket = ddp->src_socket;
172: bcopy((caddr_t) &ubytes, (caddr_t) atp->user_bytes, sizeof(ubytes));
173: atp->cmd = ATP_CMD_TRESP;
174: atp->eom = 1;
175: atp->sts = 0;
176: atp->bitmap = 0;
177:
178: (void)ddp_output(&mp, DDP_SOCKET_1st_DYNAMIC, FALSE);
179: return;
180: } /* sip_input */
181:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.