]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/netat/at_pcb.h
xnu-792.2.4.tar.gz
[apple/xnu.git] / bsd / netat / at_pcb.h
index 489d359613f32e90178d4e127651ad202a8a53e6..6d9dfb28ba1541608d486a68d96a8fac77f3ac6d 100644 (file)
  */
 
 /* at_pcb.h */
+#include <sys/appleapiopts.h>
 
+#ifdef __APPLE_API_OBSOLETE
+#ifdef KERNEL_PRIVATE
 /*
  * Common structure pcb for internet protocol implementation.
  * Here are stored pointers to local and foreign host table
@@ -66,6 +69,8 @@
  * up (to a socket structure) and down (to a protocol-specific)
  * control block.
  */
+struct atpcb;
+typedef struct atpcb gref_t;
 struct atpcb {
        struct atpcb    *atpcb_next,    /* pointers to other pcb's */
                        *atpcb_prev,
@@ -94,8 +99,8 @@ struct atpcb {
        atlock_t lock;
        atevent_t event;
        atevent_t iocevent;
-       int (*writeable)();
-       int (*readable)();
+       int (*writeable)(gref_t *gref);
+       int (*readable)(gref_t *gref);
        struct selinfo si;      /* BSD 4.4 selinfo structure for 
                                   selrecord/selwakeup */
 };
@@ -109,10 +114,13 @@ struct atpcb {
 #define DDPFLG_HDRINCL          0x08   /* user supplies entire DDP header */
 #define DDPFLG_STRIPHDR        0x200   /* drop DDP header on receive (raw) */
 
-#ifdef KERNEL
-typedef struct atpcb gref_t;
+int    at_pcballoc(struct socket *, struct atpcb *);
+int    at_pcbdetach(struct atpcb *);
+int    at_pcbbind(struct atpcb *, struct sockaddr *);
+
+int atalk_getref(struct fileproc *, int , gref_t ** , struct proc *, int);
+int atalk_getref_locked(struct fileproc *, int , gref_t ** , struct proc *, int);
+
 
-int    at_pcballoc __P((struct socket *, struct atpcb *));
-int    at_pcbdetach __P((struct atpcb *));
-int    at_pcbbind __P((struct atpcb *, struct sockaddr *));
-#endif 
+#endif /* KERNEL_PRIVATE */
+#endif /* __APPLE_API_OBSOLETE */