X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=include%2Flinux%2Fvs_network.h;h=27abab48d31266f3897b8b1a268519d80b1f101e;hb=6a77f38946aaee1cd85eeec6cf4229b204c15071;hp=0a3349c09b2e553be3b2f2eef32f13b63f6f65da;hpb=c449269f45c2cdf53af08c8d0af37472f66539d9;p=linux-2.6.git diff --git a/include/linux/vs_network.h b/include/linux/vs_network.h index 0a3349c09..27abab48d 100644 --- a/include/linux/vs_network.h +++ b/include/linux/vs_network.h @@ -2,22 +2,8 @@ #define _NX_VS_NETWORK_H -// #define NX_DEBUG - -#include -#include -#include - #include "vserver/network.h" - -#if defined(NX_DEBUG) -#define nxdprintk(x...) printk("nxd: " x) -#else -#define nxdprintk(x...) -#endif - - -extern int proc_pid_nx_info(struct task_struct *, char *); +#include "vserver/debug.h" #define get_nx_info(i) __get_nx_info(i,__FILE__,__LINE__) @@ -27,7 +13,7 @@ static inline struct nx_info *__get_nx_info(struct nx_info *nxi, { if (!nxi) return NULL; - nxdprintk("get_nx_info(%p[#%d.%d])\t%s:%d\n", + vxlprintk(VXD_CBIT(nid, 2), "get_nx_info(%p[#%d.%d])", nxi, nxi?nxi->nx_id:0, nxi?atomic_read(&nxi->nx_usecnt):0, _file, _line); atomic_inc(&nxi->nx_usecnt); @@ -35,8 +21,7 @@ static inline struct nx_info *__get_nx_info(struct nx_info *nxi, } -#define free_nx_info(nxi) \ - call_rcu(&nxi->nx_rcu, rcu_free_nx_info, nxi); +extern void free_nx_info(struct nx_info *); #define put_nx_info(i) __put_nx_info(i,__FILE__,__LINE__) @@ -44,50 +29,55 @@ static inline void __put_nx_info(struct nx_info *nxi, const char *_file, int _li { if (!nxi) return; - nxdprintk("put_nx_info(%p[#%d.%d])\t%s:%d\n", + vxlprintk(VXD_CBIT(nid, 2), "put_nx_info(%p[#%d.%d])", nxi, nxi?nxi->nx_id:0, nxi?atomic_read(&nxi->nx_usecnt):0, _file, _line); if (atomic_dec_and_test(&nxi->nx_usecnt)) free_nx_info(nxi); } - #define set_nx_info(p,i) __set_nx_info(p,i,__FILE__,__LINE__) static inline void __set_nx_info(struct nx_info **nxp, struct nx_info *nxi, const char *_file, int _line) { - BUG_ON(*nxp); + struct nx_info *nxo; + if (!nxi) return; - nxdprintk("set_nx_info(%p[#%d.%d.%d])\t%s:%d\n", + + vxlprintk(VXD_CBIT(nid, 3), "set_nx_info(%p[#%d.%d.%d])", nxi, nxi?nxi->nx_id:0, nxi?atomic_read(&nxi->nx_usecnt):0, nxi?atomic_read(&nxi->nx_refcnt):0, _file, _line); + atomic_inc(&nxi->nx_refcnt); - *nxp = __get_nx_info(nxi, _file, _line); + // nxo = xchg(nxp, __get_nx_info(nxi, _file, _line)); + nxo = xchg(nxp, nxi); + BUG_ON(nxo); } -#define clr_nx_info(p) __clr_nx_info(p,__FILE__,__LINE__) +#define clr_nx_info(p) __clr_nx_info(p,__FILE__,__LINE__) static inline void __clr_nx_info(struct nx_info **nxp, const char *_file, int _line) { - struct nx_info *nxo = *nxp; + struct nx_info *nxo; + nxo = xchg(nxp, NULL); if (!nxo) return; - nxdprintk("clr_nx_info(%p[#%d.%d.%d])\t%s:%d\n", + + vxlprintk(VXD_CBIT(nid, 3), "clr_nx_info(%p[#%d.%d.%d])", nxo, nxo?nxo->nx_id:0, nxo?atomic_read(&nxo->nx_usecnt):0, nxo?atomic_read(&nxo->nx_refcnt):0, _file, _line); - *nxp = NULL; - wmb(); - if (nxo && atomic_dec_and_test(&nxo->nx_refcnt)) + + if (atomic_dec_and_test(&nxo->nx_refcnt)) unhash_nx_info(nxo); - __put_nx_info(nxo, _file, _line); + // __put_nx_info(nxo, _file, _line); } @@ -97,26 +87,15 @@ static __inline__ struct nx_info *__task_get_nx_info(struct task_struct *p, const char *_file, int _line) { struct nx_info *nxi; - + task_lock(p); nxi = __get_nx_info(p->nx_info, _file, _line); + vxlprintk(VXD_CBIT(nid, 5), "task_get_nx_info(%p)", + p, _file, _line); task_unlock(p); return nxi; } -#define nx_verify_info(p,i) \ - __nx_verify_info((p)->nx_info,i,__FILE__,__LINE__) - -static __inline__ void __nx_verify_info( - struct nx_info *ipa, struct nx_info *ipb, - const char *_file, int _line) -{ - if (ipa == ipb) - return; - printk(KERN_ERR "ip bad assumption (%p==%p) at %s:%d\n", - ipa, ipb, _file, _line); -} - #define nx_task_nid(t) ((t)->nid) @@ -126,13 +105,10 @@ static __inline__ void __nx_verify_info( #define nx_weak_check(c,m) ((m) ? nx_check(c,m) : 1) -#undef nxdprintk -#define nxdprintk(x...) - #define __nx_flags(v,m,f) (((v) & (m)) ^ (f)) -#define __nx_task_flags(t,m,f) \ +#define __nx_task_flags(t,m,f) \ (((t) && ((t)->nx_info)) ? \ __nx_flags((t)->nx_info->nx_flags,(m),(f)) : 0) @@ -148,6 +124,21 @@ static __inline__ void __nx_verify_info( #define nx_ncaps(c) (nx_current_ncaps() & (c)) +static inline int addr_in_nx_info(struct nx_info *nxi, uint32_t addr) +{ + int n,i; + + if (!nxi) + return 1; + + n = nxi->nbipv4; + for (i=0; iipv4[i] == addr) + return 1; + } + return 0; +} + #else #warning duplicate inclusion