int d1_len; // extra header data 1 length
int d2_len; // extra header data 2 length (future)
int nn_sock; // our general listen socket
+ int rtable_ready; // set to true when rt is received or loaded
route_table_t* rtable; // the active route table
route_table_t* old_rtable; // the previously used rt, sits here to allow for draining
route_table_t* new_rtable; // route table under construction
int max_ibm; // max size of an inbound message (river accum alloc size)
void* zcb_mring; // zero copy buffer mbuf ring
void* fd2ep; // the symtab mapping file des to endpoints for cleanup on disconnect
+ void* ephash; // hash host:port or ip:port to endpoint struct
+
pthread_mutex_t *fd2ep_gate; // we must gate add/deletes to the fd2 symtab
+ pthread_mutex_t *rtgate; // master gate for accessing/moving route tables
};
typedef uta_ctx_t uta_ctx;