sockadd2str is c90 compliant

FossilOrigin-Name: 6336ae782e53db768fb7edb6b784c2c2abed4f45b0b1da98a24ac34f7360187f
This commit is contained in:
7u83@mail.ru 2018-03-05 11:23:16 +00:00
parent aa8932b770
commit fdbfe8af32
18 changed files with 107 additions and 77 deletions

View File

@ -1,11 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<CodeLite_Workspace Name="actube" Database=""> <CodeLite_Workspace Name="actube" Database="">
<Project Name="ac" Path="ac.project" Active="No"/> <Project Name="ac" Path="ac.project" Active="Yes"/>
<Project Name="wtp" Path="wtp.project" Active="No"/> <Project Name="wtp" Path="wtp.project" Active="No"/>
<Project Name="mod_cipwap" Path="mod_cipwap.project" Active="No"/> <Project Name="mod_cipwap" Path="mod_cipwap.project" Active="No"/>
<Project Name="mod_capwap" Path="mod_capwap.project" Active="No"/> <Project Name="mod_capwap" Path="mod_capwap.project" Active="No"/>
<Project Name="mod_cisco" Path="mod_cisco.project" Active="No"/> <Project Name="mod_cisco" Path="mod_cisco.project" Active="No"/>
<Project Name="libcw" Path="libcw.project" Active="Yes"/> <Project Name="libcw" Path="libcw.project" Active="No"/>
<Project Name="mod_capwap80211" Path="mod_capwap80211.project" Active="No"/> <Project Name="mod_capwap80211" Path="mod_capwap80211.project" Active="No"/>
<Project Name="mod_fortinet" Path="mod_fortinet.project" Active="No"/> <Project Name="mod_fortinet" Path="mod_fortinet.project" Active="No"/>
<BuildMatrix> <BuildMatrix>

View File

@ -365,6 +365,7 @@ int ac_run()
void process_cw_data_packet(int index, struct sockaddr *addr, uint8_t * buffer, int len) void process_cw_data_packet(int index, struct sockaddr *addr, uint8_t * buffer, int len)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
cw_dbg(DBG_X, "There is a data packet now"); cw_dbg(DBG_X, "There is a data packet now");
dataman_list_lock(); dataman_list_lock();
@ -372,12 +373,12 @@ void process_cw_data_packet(int index, struct sockaddr *addr, uint8_t * buffer,
struct dataman * dm = dataman_list_get(socklist[index].data_sockfd,addr); struct dataman * dm = dataman_list_get(socklist[index].data_sockfd,addr);
cw_dbg(DBG_X, "Dataman list locked, now gotted"); cw_dbg(DBG_X, "Dataman list locked, now gotted");
cw_dbg(DBG_INFO,"Packet for dataman %s,%d",sock_addr2str_p(addr),socklist[index].data_sockfd); cw_dbg(DBG_INFO,"Packet for dataman %s,%d",sock_addr2str_p(addr,sock_buf),socklist[index].data_sockfd);
if (!dm) { if (!dm) {
cw_dbg(DBG_INFO,"No dataman %s,%d",sock_addr2str_p(addr),socklist[index].data_sockfd); cw_dbg(DBG_INFO,"No dataman %s,%d",sock_addr2str_p(addr,sock_buf),socklist[index].data_sockfd);
dm = dataman_create(socklist[index].data_sockfd,addr); dm = dataman_create(socklist[index].data_sockfd,addr);
if (!dm){ if (!dm){
cw_log(LOG_ERR,"Can't create dataman for packet from %s",sock_addr2str_p(addr)); cw_log(LOG_ERR,"Can't create dataman for packet from %s",sock_addr2str_p(addr,sock_buf));
return; return;
} }
dataman_list_add(dm); dataman_list_add(dm);
@ -401,7 +402,7 @@ void process_cw_data_packet(int index, struct sockaddr *addr, uint8_t * buffer,
exit(0); exit(0);
struct wtpman *wtpman = wtplist_get(addr); struct wtpman *wtpman = wtplist_get(addr);
if (!wtpman){ if (!wtpman){
cw_dbg(DBG_PKT_ERR,"Discarding packet on data channel from %s - No wtpman found.",sock_addr2str(addr)); cw_dbg(DBG_PKT_ERR,"Discarding packet on data channel from %s - No wtpman found.",sock_addr2str(addr,sock_buf));
return; return;
} }
@ -412,7 +413,7 @@ void process_cw_data_packet(int index, struct sockaddr *addr, uint8_t * buffer,
void process_cw_ctrl_packet(int index, struct sockaddr *addr, uint8_t * buffer, int len) void process_cw_ctrl_packet(int index, struct sockaddr *addr, uint8_t * buffer, int len)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
/* first of all check preamble */ /* first of all check preamble */
int preamble = cw_get_hdr_preamble(buffer); int preamble = cw_get_hdr_preamble(buffer);
@ -420,7 +421,7 @@ void process_cw_ctrl_packet(int index, struct sockaddr *addr, uint8_t * buffer,
if (preamble != CAPWAP_PACKET_PREAMBLE && preamble != CAPWAP_DTLS_PACKET_PREAMBLE) { if (preamble != CAPWAP_PACKET_PREAMBLE && preamble != CAPWAP_DTLS_PACKET_PREAMBLE) {
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, wrong preamble, preamble = 0x%01X", "Discarding packet from %s, wrong preamble, preamble = 0x%01X",
sock_addr2str(addr), preamble); sock_addr2str(addr,sock_buf), preamble);
return; return;
} }

View File

@ -332,7 +332,7 @@ static int socklist_check_size()
int socklist_add_unicast(const char *addr, const char *port, int ac_proto) int socklist_add_unicast(const char *addr, const char *port, int ac_proto)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
if (!socklist_check_size()) if (!socklist_check_size())
return 0; return 0;
@ -402,7 +402,7 @@ int socklist_add_unicast(const char *addr, const char *port, int ac_proto)
sock_addrlen(res->ai_addr)); sock_addrlen(res->ai_addr));
cw_log(LOG_INFO, cw_log(LOG_INFO,
"Bound to: %s:%s (%i) on interface %s, netmask %s", addr, "Bound to: %s:%s (%i) on interface %s, netmask %s", addr,
port, sockfd, ifname, sock_addr2str(&netmask)); port, sockfd, ifname, sock_addr2str(&netmask,sock_buf));
} else { } else {
cw_log(LOG_INFO, "Bound to: [%s]:%s (%i) on interface %s", addr, cw_log(LOG_INFO, "Bound to: [%s]:%s (%i) on interface %s", addr,
port, sockfd, ifname); port, sockfd, ifname);

View File

@ -45,6 +45,7 @@
static void reset_echointerval_timer(struct wtpman *wtpman) static void reset_echointerval_timer(struct wtpman *wtpman)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
uint16_t ct = mbag_get_word(wtpman->conn->local, CW_ITEM_CAPWAP_TIMERS, uint16_t ct = mbag_get_word(wtpman->conn->local, CW_ITEM_CAPWAP_TIMERS,
CW_MAX_DISCOVERY_INTERVAL << 8 | CW_MAX_DISCOVERY_INTERVAL << 8 |
CAPWAP_ECHO_INTERVAL); CAPWAP_ECHO_INTERVAL);
@ -52,7 +53,7 @@ static void reset_echointerval_timer(struct wtpman *wtpman)
/* start echinterval timer and put 2 seconds for "safety" on it */ /* start echinterval timer and put 2 seconds for "safety" on it */
wtpman->echointerval_timer = cw_timer_start(2+ (ct & 0xff)); wtpman->echointerval_timer = cw_timer_start(2+ (ct & 0xff));
db_ping_wtp(sock_addr2str_p(&wtpman->conn->addr), conf_acname); db_ping_wtp(sock_addr2str_p(&wtpman->conn->addr,sock_buf), conf_acname);
// cw_dbg(DBG_X, "Starting capwap timer: %d", wtpman->echointerval_timer); // cw_dbg(DBG_X, "Starting capwap timer: %d", wtpman->echointerval_timer);
} }
@ -130,6 +131,7 @@ int xprocess_message(struct conn *conn, uint8_t * rawmsg, int rawlen,
static int wtpman_establish_dtls(void *arg) static int wtpman_establish_dtls(void *arg)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct wtpman *wtpman = (struct wtpman *) arg; struct wtpman *wtpman = (struct wtpman *) arg;
/* setup cipher */ /* setup cipher */
@ -165,18 +167,19 @@ static int wtpman_establish_dtls(void *arg)
/* try to accept the connection */ /* try to accept the connection */
if (!dtls_accept(wtpman->conn)) { if (!dtls_accept(wtpman->conn)) {
cw_dbg(DBG_DTLS, "Error establishing DTLS session with %s", cw_dbg(DBG_DTLS, "Error establishing DTLS session with %s",
sock_addr2str_p(&wtpman->conn->addr)); sock_addr2str_p(&wtpman->conn->addr,sock_buf));
return 0; return 0;
} }
cw_dbg(DBG_DTLS, "DTLS session established with %s, cipher=%s", cw_dbg(DBG_DTLS, "DTLS session established with %s, cipher=%s",
sock_addr2str_p(&wtpman->conn->addr), dtls_get_cipher(wtpman->conn)); sock_addr2str_p(&wtpman->conn->addr,sock_buf), dtls_get_cipher(wtpman->conn));
return 1; return 1;
} }
static int wtpman_join(void *arg, time_t timer) static int wtpman_join(void *arg, time_t timer)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct wtpman *wtpman = (struct wtpman *) arg; struct wtpman *wtpman = (struct wtpman *) arg;
struct conn *conn = wtpman->conn; struct conn *conn = wtpman->conn;
@ -195,7 +198,7 @@ static int wtpman_join(void *arg, time_t timer)
// wtpman->conn->itemstore = mbag_create(); // wtpman->conn->itemstore = mbag_create();
cw_dbg(DBG_INFO, "Join State - %s", sock_addr2str(&conn->addr)); cw_dbg(DBG_INFO, "Join State - %s", sock_addr2str(&conn->addr,sock_buf));
int rc; int rc;
while (!cw_timer_timeout(timer) && wtpman->conn->capwap_state == CAPWAP_STATE_JOIN) { while (!cw_timer_timeout(timer) && wtpman->conn->capwap_state == CAPWAP_STATE_JOIN) {
@ -214,7 +217,7 @@ static int wtpman_join(void *arg, time_t timer)
if (wtpman->conn->capwap_state == CAPWAP_STATE_JOIN) { if (wtpman->conn->capwap_state == CAPWAP_STATE_JOIN) {
cw_dbg(DBG_MSG_ERR, "No join request from %s after %d seconds, WTP died.", cw_dbg(DBG_MSG_ERR, "No join request from %s after %d seconds, WTP died.",
sock_addr2str(&wtpman->conn->addr), wtpman->conn->wait_dtls); sock_addr2str(&wtpman->conn->addr,sock_buf), wtpman->conn->wait_dtls);
return 0; return 0;
} }
@ -227,6 +230,7 @@ static int wtpman_join(void *arg, time_t timer)
static void wtpman_image_data(struct wtpman *wtpman) static void wtpman_image_data(struct wtpman *wtpman)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct conn *conn = wtpman->conn; struct conn *conn = wtpman->conn;
/* Image upload */ /* Image upload */
@ -234,15 +238,15 @@ static void wtpman_image_data(struct wtpman *wtpman)
if (!filename) { if (!filename) {
cw_log(LOG_ERR, cw_log(LOG_ERR,
"Can't send image to %s. No Image Filename Item found.", "Can't send image to %s. No Image Filename Item found.",
sock_addr2str(&conn->addr)); sock_addr2str(&conn->addr,sock_buf));
return; return;
} }
cw_dbg(DBG_INFO, "Sending image file '%s' to '%s'.", filename, cw_dbg(DBG_INFO, "Sending image file '%s' to '%s'.", filename,
sock_addr2str(&conn->addr)); sock_addr2str(&conn->addr,sock_buf));
FILE *infile = fopen(filename, "rb"); FILE *infile = fopen(filename, "rb");
if (infile == NULL) { if (infile == NULL) {
cw_log(LOG_ERR, "Can't open image %s: %s", cw_log(LOG_ERR, "Can't open image %s: %s",
sock_addr2str(&conn->addr), strerror(errno)); sock_addr2str(&conn->addr,sock_buf), strerror(errno));
return; return;
} }
@ -263,10 +267,10 @@ static void wtpman_image_data(struct wtpman *wtpman)
if (rc) { if (rc) {
cw_log(LOG_ERR, "Error sending image to %s: %s", cw_log(LOG_ERR, "Error sending image to %s: %s",
sock_addr2str(&conn->addr), cw_strrc(rc)); sock_addr2str(&conn->addr,sock_buf), cw_strrc(rc));
} else { } else {
cw_dbg(DBG_INFO, "Image '%s' sucessful sent to %s in %0.1f seconds.", cw_dbg(DBG_INFO, "Image '%s' sucessful sent to %s in %0.1f seconds.",
filename, sock_addr2str(&conn->addr), cw_clock_stop(&clk)); filename, sock_addr2str(&conn->addr,sock_buf), cw_clock_stop(&clk));
conn->capwap_state = CW_STATE_NONE; conn->capwap_state = CW_STATE_NONE;
} }
@ -424,7 +428,8 @@ void radio_to_sql(struct conn *conn, char *wtp_id, int rid, mbag_t radio)
void radios_to_sql(struct conn *conn) void radios_to_sql(struct conn *conn)
{ {
char *wtp_id = sock_addr2str(&conn->addr); char sock_buf[SOCK_ADDR_BUFSIZE];
char *wtp_id = sock_addr2str(&conn->addr,sock_buf);
MAVLITER_DEFINE(it, conn->radios); MAVLITER_DEFINE(it, conn->radios);
mavliter_foreach(&it) { mavliter_foreach(&it) {
struct mbag_item * i = mavliter_get(&it); struct mbag_item * i = mavliter_get(&it);
@ -475,7 +480,7 @@ static int msg_end_handler(struct conn *conn, struct cw_action_in *a, uint8_t *
static void wtpman_run(void *arg) static void wtpman_run(void *arg)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct wtpman *wtpman = (struct wtpman *) arg; struct wtpman *wtpman = (struct wtpman *) arg;
@ -514,7 +519,7 @@ static void wtpman_run(void *arg)
cw_dbg(DBG_INFO, "WTP from %s has joined with session id: %s", cw_dbg(DBG_INFO, "WTP from %s has joined with session id: %s",
sock_addr2str_p(&conn->addr), sock_addr2str_p(&conn->addr,sock_buf),
format_bin2hex(conn->session_id,16)); format_bin2hex(conn->session_id,16));
@ -579,7 +584,7 @@ static void wtpman_run(void *arg)
if (cw_timer_timeout(wtpman->echointerval_timer)) { if (cw_timer_timeout(wtpman->echointerval_timer)) {
cw_dbg(DBG_INFO, "Lost connection to WTP:%s", cw_dbg(DBG_INFO, "Lost connection to WTP:%s",
sock_addr2str_p(&conn->addr)); sock_addr2str_p(&conn->addr,sock_buf));
break; break;
} }
@ -592,13 +597,13 @@ static void wtpman_run(void *arg)
mavl_conststr_t r; mavl_conststr_t r;
r = db_get_update_tasks(conn, sock_addr2str(&conn->addr)); r = db_get_update_tasks(conn, sock_addr2str(&conn->addr,sock_buf));
if (r) { if (r) {
if (!conn->outgoing->count) if (!conn->outgoing->count)
continue; continue;
cw_dbg(DBG_INFO, "Updating WTP %s",sock_addr2str(&conn->addr)); cw_dbg(DBG_INFO, "Updating WTP %s",sock_addr2str(&conn->addr,sock_buf));
rc = cw_send_request(conn, CAPWAP_MSG_CONFIGURATION_UPDATE_REQUEST); rc = cw_send_request(conn, CAPWAP_MSG_CONFIGURATION_UPDATE_REQUEST);
mavl_merge(conn->config, conn->outgoing); mavl_merge(conn->config, conn->outgoing);
@ -609,13 +614,13 @@ static void wtpman_run(void *arg)
mavl_destroy(r); mavl_destroy(r);
} }
r = db_get_radio_tasks(conn, sock_addr2str(&conn->addr)); r = db_get_radio_tasks(conn, sock_addr2str(&conn->addr,sock_buf));
if (r) { if (r) {
if (!conn->radios_upd->count) if (!conn->radios_upd->count)
continue; continue;
cw_dbg(DBG_INFO, "Updating Radios for %s",sock_addr2str(&conn->addr)); cw_dbg(DBG_INFO, "Updating Radios for %s",sock_addr2str(&conn->addr,sock_buf));
rc = cw_send_request(conn, CAPWAP_MSG_CONFIGURATION_UPDATE_REQUEST); rc = cw_send_request(conn, CAPWAP_MSG_CONFIGURATION_UPDATE_REQUEST);
@ -642,7 +647,7 @@ static void wtpman_run(void *arg)
} }
db_ping_wtp(sock_addr2str_p(&conn->addr), ""); db_ping_wtp(sock_addr2str_p(&conn->addr,sock_buf), "");
wtpman_remove(wtpman); wtpman_remove(wtpman);
return; return;
} }
@ -650,7 +655,7 @@ static void wtpman_run(void *arg)
static void wtpman_run_dtls(void *arg) static void wtpman_run_dtls(void *arg)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct wtpman *wtpman = (struct wtpman *) arg; struct wtpman *wtpman = (struct wtpman *) arg;
@ -658,7 +663,7 @@ static void wtpman_run_dtls(void *arg)
/* reject connections to our multi- or broadcast sockets */ /* reject connections to our multi- or broadcast sockets */
if (socklist[wtpman->socklistindex].type != SOCKLIST_UNICAST_SOCKET) { if (socklist[wtpman->socklistindex].type != SOCKLIST_UNICAST_SOCKET) {
cw_dbg(DBG_DTLS, "Dropping connection from %s to non-unicast socket.", cw_dbg(DBG_DTLS, "Dropping connection from %s to non-unicast socket.",
sock_addr2str_p(&wtpman->conn->addr)); sock_addr2str_p(&wtpman->conn->addr,sock_buf));
wtpman_remove(wtpman); wtpman_remove(wtpman);
return; return;
} }
@ -686,6 +691,7 @@ void wtpman_destroy(struct wtpman *wtpman)
struct wtpman *wtpman_create(int socklistindex, struct sockaddr *srcaddr) struct wtpman *wtpman_create(int socklistindex, struct sockaddr *srcaddr)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct wtpman *wtpman; struct wtpman *wtpman;
wtpman = malloc(sizeof(struct wtpman)); wtpman = malloc(sizeof(struct wtpman));
if (!wtpman) if (!wtpman)
@ -701,7 +707,7 @@ struct wtpman *wtpman_create(int socklistindex, struct sockaddr *srcaddr)
if (replyfd == -1) { if (replyfd == -1) {
cw_log(LOG_ERR, "Can't find reply socket for request from %s", cw_log(LOG_ERR, "Can't find reply socket for request from %s",
sock_addr2str(srcaddr)); sock_addr2str(srcaddr,sock_buf));
free(wtpman); free(wtpman);
return NULL; return NULL;
} }
@ -717,7 +723,7 @@ struct wtpman *wtpman_create(int socklistindex, struct sockaddr *srcaddr)
getsockname(sockfd, &dbgaddr, &dbgaddrl); getsockname(sockfd, &dbgaddr, &dbgaddrl);
cw_dbg(DBG_INFO, "Creating wtpman on socket %d, %s:%d", sockfd, cw_dbg(DBG_INFO, "Creating wtpman on socket %d, %s:%d", sockfd,
sock_addr2str(&dbgaddr), sock_getport(&dbgaddr)); sock_addr2str(&dbgaddr,sock_buf), sock_getport(&dbgaddr));
//extern int conn_process_packet2(struct conn *conn, uint8_t * packet, int len, //extern int conn_process_packet2(struct conn *conn, uint8_t * packet, int len,
// struct sockaddr *from); // struct sockaddr *from);

View File

@ -181,13 +181,14 @@ static int check_len(struct conn *conn, struct cw_action_in *a, uint8_t * data,
static struct cw_MsgSet *load_msg_set(struct conn *conn, uint8_t * rawmsg, int len, static struct cw_MsgSet *load_msg_set(struct conn *conn, uint8_t * rawmsg, int len,
int elems_len, struct sockaddr *from) int elems_len, struct sockaddr *from)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct cw_Mod *cmod = struct cw_Mod *cmod =
cw_mod_detect(conn, rawmsg, len, elems_len, from, CW_MOD_MODE_CAPWAP); cw_mod_detect(conn, rawmsg, len, elems_len, from, CW_MOD_MODE_CAPWAP);
if (cmod == MOD_NULL) { if (cmod == MOD_NULL) {
cw_dbg(DBG_MSG_ERR, cw_dbg(DBG_MSG_ERR,
"Can't find mod to handle connection from %s, discarding message", "Can't find mod to handle connection from %s, discarding message",
sock_addr2str_p(from)); sock_addr2str_p(from,sock_buf));
return NULL; return NULL;
} }
@ -219,6 +220,7 @@ int cw_in_check_generic(struct conn *conn, struct cw_action_in *a, uint8_t * dat
static int process_elements(struct conn *conn, uint8_t * rawmsg, int len, static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
struct sockaddr *from) struct sockaddr *from)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct cw_action_in as, *af, *afm; struct cw_action_in as, *af, *afm;
int offset = cw_get_hdr_msg_offset(rawmsg); int offset = cw_get_hdr_msg_offset(rawmsg);
@ -236,7 +238,7 @@ static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
if (conn->strict_hdr) { if (conn->strict_hdr) {
cw_dbg(DBG_MSG_ERR, cw_dbg(DBG_MSG_ERR,
"Discarding message from %s, msgelems len=%d, payload len=%d, (Strict CAPWAP) ", "Discarding message from %s, msgelems len=%d, payload len=%d, (Strict CAPWAP) ",
sock_addr2str(&conn->addr), elems_len, payloadlen - 8); sock_addr2str(&conn->addr,sock_buf), elems_len, payloadlen - 8);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -245,7 +247,7 @@ static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
if (elems_len < payloadlen - 8) { if (elems_len < payloadlen - 8) {
cw_dbg(DBG_RFC, cw_dbg(DBG_RFC,
"Packet from from %s has %d bytes of extra data, ignoring.", "Packet from from %s has %d bytes of extra data, ignoring.",
sock_addr2str(&conn->addr), payloadlen - 8 - elems_len); sock_addr2str(&conn->addr,sock_buf), payloadlen - 8 - elems_len);
elems_len = len - 8; elems_len = len - 8;
} }
@ -253,7 +255,7 @@ static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
cw_dbg(DBG_RFC, cw_dbg(DBG_RFC,
"Packet from from %s has msgelems len of %d bytes, but has only %d bytes of data, truncating.", "Packet from from %s has msgelems len of %d bytes, but has only %d bytes of data, truncating.",
sock_addr2str(&conn->addr), elems_len, payloadlen - 8); sock_addr2str(&conn->addr, sock_buf), elems_len, payloadlen - 8);
elems_len = payloadlen - 8; elems_len = payloadlen - 8;
} }
} }
@ -487,7 +489,7 @@ static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
int process_message(struct conn *conn, uint8_t * rawmsg, int rawlen, int process_message(struct conn *conn, uint8_t * rawmsg, int rawlen,
struct sockaddr *from) struct sockaddr *from)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
uint8_t *msgptr = rawmsg + cw_get_hdr_msg_offset(rawmsg); uint8_t *msgptr = rawmsg + cw_get_hdr_msg_offset(rawmsg);
@ -517,7 +519,7 @@ int process_message(struct conn *conn, uint8_t * rawmsg, int rawlen,
if (sd != 0) { if (sd != 0) {
cw_dbg(DBG_MSG_ERR, cw_dbg(DBG_MSG_ERR,
"Discarding message from %s, old seqnum, seqnum = %d, last seqnum=%d", "Discarding message from %s, old seqnum, seqnum = %d, last seqnum=%d",
sock_addr2str(&conn->addr), s2, s1); sock_addr2str(&conn->addr,sock_buf), s2, s1);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -528,7 +530,7 @@ int process_message(struct conn *conn, uint8_t * rawmsg, int rawlen,
cw_dbg(DBG_MSG_ERR, cw_dbg(DBG_MSG_ERR,
"Retransmitted request message from %s detected, seqnum=%d, type=%d", "Retransmitted request message from %s detected, seqnum=%d, type=%d",
sock_addr2str(&conn->addr), s2, type); sock_addr2str(&conn->addr,sock_buf), s2, type);
if (cw_get_hdr_msg_type(conn->resp_buffer) - 1 != type) { if (cw_get_hdr_msg_type(conn->resp_buffer) - 1 != type) {
@ -540,7 +542,7 @@ int process_message(struct conn *conn, uint8_t * rawmsg, int rawlen,
} }
cw_dbg(DBG_MSG_ERR, "Retransmitting response message to %s, seqnum=%d", cw_dbg(DBG_MSG_ERR, "Retransmitting response message to %s, seqnum=%d",
sock_addr2str(&conn->addr), s2); sock_addr2str(&conn->addr, sock_buf), s2);
// XXX untested // XXX untested
conn_send_msg(conn, conn->resp_buffer); conn_send_msg(conn, conn->resp_buffer);
@ -558,13 +560,13 @@ int process_message(struct conn *conn, uint8_t * rawmsg, int rawlen,
int conn_process_packet2(struct conn *conn, uint8_t * packet, int len, int conn_process_packet2(struct conn *conn, uint8_t * packet, int len,
struct sockaddr *from) struct sockaddr *from)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
if (len < 8) { if (len < 8) {
/* packet too short */ /* packet too short */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, packet too short, len=%d, at least 8 expected.", "Discarding packet from %s, packet too short, len=%d, at least 8 expected.",
sock_addr2str(&conn->addr), len); sock_addr2str(&conn->addr, sock_buf), len);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -575,7 +577,7 @@ int conn_process_packet2(struct conn *conn, uint8_t * packet, int len,
/* wrong version */ /* wrong version */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, wrong version, version=%d, version %d expected.", "Discarding packet from %s, wrong version, version=%d, version %d expected.",
sock_addr2str(&conn->addr), (preamble & 0xf0) >> 4, sock_addr2str(&conn->addr,sock_buf), (preamble & 0xf0) >> 4,
CAPWAP_VERSION); CAPWAP_VERSION);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
@ -585,7 +587,7 @@ int conn_process_packet2(struct conn *conn, uint8_t * packet, int len,
/* Encrypted data, this shuold never happen here */ /* Encrypted data, this shuold never happen here */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, encrypted data after decryption ...", "Discarding packet from %s, encrypted data after decryption ...",
sock_addr2str(&conn->addr)); sock_addr2str(&conn->addr,sock_buf));
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -599,7 +601,7 @@ int conn_process_packet2(struct conn *conn, uint8_t * packet, int len,
/* Eleminate messages with wrong header size */ /* Eleminate messages with wrong header size */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, header length (%d) greater than packet len (%d).", "Discarding packet from %s, header length (%d) greater than packet len (%d).",
sock_addr2str(&conn->addr), offs, len); sock_addr2str(&conn->addr,sock_buf), offs, len);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -611,7 +613,7 @@ int conn_process_packet2(struct conn *conn, uint8_t * packet, int len,
/* wrong rmac size */ /* wrong rmac size */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, wrong R-MAC size, size=%d", "Discarding packet from %s, wrong R-MAC size, size=%d",
sock_addr2str(&conn->addr), *(packet + 8)); sock_addr2str(&conn->addr,sock_buf), *(packet + 8));
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }

View File

@ -27,6 +27,7 @@
void conn_q_add_packet(struct conn * conn,uint8_t *packet,int len) void conn_q_add_packet(struct conn * conn,uint8_t *packet,int len)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
int qwpos = conn->qwpos; int qwpos = conn->qwpos;
if (qwpos==conn->qsize) if (qwpos==conn->qsize)
qwpos=0; qwpos=0;
@ -34,7 +35,7 @@ void conn_q_add_packet(struct conn * conn,uint8_t *packet,int len)
if (conn->qrpos==qwpos){ if (conn->qrpos==qwpos){
/* no buffers, discard packet */ /* no buffers, discard packet */
cw_dbg(DBG_PKT_ERR, "Discarding packet from %s, no queue buffers left", cw_dbg(DBG_PKT_ERR, "Discarding packet from %s, no queue buffers left",
sock_addr2str(&conn->addr)); sock_addr2str(&conn->addr,sock_buf));
return; return;
} }

View File

@ -31,9 +31,10 @@
int conn_send_data_packet(struct conn * conn, const uint8_t * buffer, int len) int conn_send_data_packet(struct conn * conn, const uint8_t * buffer, int len)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
int n; int n;
cw_dbg(DBG_X,"Sending data packet to %s\n",sock_addr2str_p(&conn->data_addr)); cw_dbg(DBG_X,"Sending data packet to %s\n",sock_addr2str_p(&conn->data_addr,sock_buf));
while((n=sendto( conn->data_sock, buffer, len, 0, while((n=sendto( conn->data_sock, buffer, len, 0,
(struct sockaddr*)&conn->data_addr, (struct sockaddr*)&conn->data_addr,

View File

@ -16,7 +16,8 @@ void cw_get_wtp_name(struct conn *conn,struct sockaddr *addr)
int cw_set_capwap_mode(struct conn *conn,int mode) int cw_set_capwap_mode(struct conn *conn,int mode)
{ {
cw_dbg(DBG_INFO,"Setting CAPWAP mode to %d for %s",mode,sock_addr2str(&conn->addr)); char sock_buf[SOCK_ADDR_BUFSIZE];
cw_dbg(DBG_INFO,"Setting CAPWAP mode to %d for %s",mode,sock_addr2str(&conn->addr,sock_buf));
conn->capwap_mode_out=mode; conn->capwap_mode_out=mode;
return 1; return 1;
} }

View File

@ -10,6 +10,7 @@
int cw_in_check_disc_req(struct conn *conn, struct cw_action_in *a, uint8_t * data, int cw_in_check_disc_req(struct conn *conn, struct cw_action_in *a, uint8_t * data,
int len,struct sockaddr *from) int len,struct sockaddr *from)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
cw_action_in_t *mlist[120]; cw_action_in_t *mlist[120];
int n = cw_check_missing_mand(mlist, conn, a); int n = cw_check_missing_mand(mlist, conn, a);
@ -23,7 +24,7 @@ int cw_in_check_disc_req(struct conn *conn, struct cw_action_in *a, uint8_t * da
mode send no discovery response */ mode send no discovery response */
cw_dbg(DBG_MSG_ERR, cw_dbg(DBG_MSG_ERR,
"Ignoring Discovery Request from %s - missing mandatory elements.", "Ignoring Discovery Request from %s - missing mandatory elements.",
sock_addr2str(from)); sock_addr2str(from,sock_buf));
return -1; return -1;
} }

View File

@ -217,21 +217,24 @@ void cw_dbg_missing_mand(int level, struct conn *conn, cw_action_in_t ** ml, int
int cw_format_pkt_hdr(char *dst, int level, struct conn *conn, uint8_t * packet, int len, int cw_format_pkt_hdr(char *dst, int level, struct conn *conn, uint8_t * packet, int len,
struct sockaddr *from) struct sockaddr *from)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
char *s = dst; char *s = dst;
switch (level) { switch (level) {
case DBG_PKT_IN: case DBG_PKT_IN:
if (cw_get_hdr_flag_f(packet)) { if (cw_get_hdr_flag_f(packet)) {
s += sprintf(s, "Fragment from %s", s += sprintf(s, "Fragment from %s",
sock_addr2str_p(from)); sock_addr2str_p(from,sock_buf));
} else { } else {
s += sprintf(s, "From %s", sock_addr2str_p(from)); s += sprintf(s, "From %s", sock_addr2str_p(from,sock_buf));
} }
break; break;
case DBG_PKT_OUT: case DBG_PKT_OUT:
if (cw_get_hdr_flag_f(packet)) { if (cw_get_hdr_flag_f(packet)) {
s += sprintf(s, "Fragment to %s", sock_addr2str(from)); s += sprintf(s, "Fragment to %s", sock_addr2str(from,sock_buf));
} else { } else {
s += sprintf(s, "To %s", sock_addr2str(from)); s += sprintf(s, "To %s", sock_addr2str(from,sock_buf));
} }
break; break;
} }
@ -477,7 +480,7 @@ void cw_dbg_msg(int level, struct conn *conn, uint8_t * packet, int len,
{ {
if (!cw_dbg_is_level(level)) if (!cw_dbg_is_level(level))
return; return;
char sock_buf[SOCK_ADDR_BUFSIZE];
char buf[1024]; char buf[1024];
char *s = buf; char *s = buf;
@ -501,9 +504,9 @@ void cw_dbg_msg(int level, struct conn *conn, uint8_t * packet, int len,
s += sprintf(s, "%s Message (type=%d) ", msname /*cw_strmsg(msg_id)*/, msg_id); s += sprintf(s, "%s Message (type=%d) ", msname /*cw_strmsg(msg_id)*/, msg_id);
if (level == DBG_MSG_IN) if (level == DBG_MSG_IN)
s += sprintf(s, "from %s ", sock_addr2str(from)); s += sprintf(s, "from %s ", sock_addr2str(from,sock_buf));
else else
s += sprintf(s, "to %s ", sock_addr2str(from)); s += sprintf(s, "to %s ", sock_addr2str(from,sock_buf));
s += sprintf(s, ", Seqnum: %d ElemLen: %d", cw_get_msg_seqnum(msgptr), s += sprintf(s, ", Seqnum: %d ElemLen: %d", cw_get_msg_seqnum(msgptr),
cw_get_msg_elems_len(msgptr)); cw_get_msg_elems_len(msgptr));

View File

@ -27,6 +27,7 @@
#include "conn.h" #include "conn.h"
#ifndef CW_LOG_DUMP_ROW_LEN #ifndef CW_LOG_DUMP_ROW_LEN
#define CW_LOG_DUMP_ROW_LEN 32 #define CW_LOG_DUMP_ROW_LEN 32
#endif #endif
@ -35,6 +36,7 @@
#define CW_LOG_DUMP_ROW_TAB_LEN 8 #define CW_LOG_DUMP_ROW_TAB_LEN 8
#endif #endif
/** /**
*@defgroup DBG DBG *@defgroup DBG DBG
*@{ *@{

View File

@ -37,13 +37,14 @@
int dtls_gnutls_accept(struct conn *conn) int dtls_gnutls_accept(struct conn *conn)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct dtls_gnutls_data *d; struct dtls_gnutls_data *d;
gnutls_datum_t cookie_key; gnutls_datum_t cookie_key;
gnutls_key_generate(&cookie_key, GNUTLS_COOKIE_KEY_SIZE); gnutls_key_generate(&cookie_key, GNUTLS_COOKIE_KEY_SIZE);
cw_dbg(DBG_DTLS, "Session cookie for %s generated: %s", cw_dbg(DBG_DTLS, "Session cookie for %s generated: %s",
sock_addr2str(&conn->addr), sock_hwaddr2idstr((uint8_t *) (&cookie_key), sock_addr2str(&conn->addr,sock_buf), sock_hwaddr2idstr((uint8_t *) (&cookie_key),
sizeof(cookie_key))); sizeof(cookie_key)));
gnutls_dtls_prestate_st prestate; gnutls_dtls_prestate_st prestate;
@ -94,7 +95,7 @@ int dtls_gnutls_accept(struct conn *conn)
} }
cw_dbg(DBG_DTLS, "Cookie verified! Starting handshake with %s ...",sock_addr2str(&conn->addr)); cw_dbg(DBG_DTLS, "Cookie verified! Starting handshake with %s ...",sock_addr2str(&conn->addr,sock_buf));
@ -113,12 +114,12 @@ int dtls_gnutls_accept(struct conn *conn)
if ( rc < 0 ) { if ( rc < 0 ) {
cw_log(LOG_ERR, "Error in handshake with %s: %s",sock_addr2str(&conn->addr), gnutls_strerror(rc)); cw_log(LOG_ERR, "Error in handshake with %s: %s",sock_addr2str(&conn->addr,sock_buf), gnutls_strerror(rc));
return 0; return 0;
} }
cw_dbg(DBG_DTLS,"Handshake with %s successful.",sock_addr2str(&conn->addr)); cw_dbg(DBG_DTLS,"Handshake with %s successful.",sock_addr2str(&conn->addr,sock_buf));
conn->dtls_data=d; conn->dtls_data=d;
conn->read = dtls_gnutls_read; conn->read = dtls_gnutls_read;

View File

@ -38,6 +38,7 @@
*/ */
int dtls_gnutls_connect(struct conn *conn) int dtls_gnutls_connect(struct conn *conn)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
struct dtls_gnutls_data *d; struct dtls_gnutls_data *d;
d = dtls_gnutls_data_create(conn, d = dtls_gnutls_data_create(conn,
GNUTLS_CLIENT | GNUTLS_DATAGRAM | GNUTLS_NONBLOCK); GNUTLS_CLIENT | GNUTLS_DATAGRAM | GNUTLS_NONBLOCK);
@ -63,12 +64,12 @@ int dtls_gnutls_connect(struct conn *conn)
if (rc < 0) { if (rc < 0) {
cw_log(LOG_ERR, "DTLS (gnutls) Can't connect to %s: %s", cw_log(LOG_ERR, "DTLS (gnutls) Can't connect to %s: %s",
sock_addr2str(&conn->addr), gnutls_strerror(rc)); sock_addr2str(&conn->addr,sock_buf), gnutls_strerror(rc));
return 0; return 0;
} }
cw_dbg(DBG_DTLS, "Handshake with %s successful", sock_addr2str(&conn->addr)); cw_dbg(DBG_DTLS, "Handshake with %s successful", sock_addr2str(&conn->addr,sock_buf));
conn->dtls_data = d; conn->dtls_data = d;
conn->read = dtls_gnutls_read; conn->read = dtls_gnutls_read;

View File

@ -531,6 +531,7 @@ int dtls_openssl_shutdown(struct conn *conn)
int dtls_openssl_generate_cookie(SSL *ssl, unsigned char *cookie, unsigned int *cookie_len) int dtls_openssl_generate_cookie(SSL *ssl, unsigned char *cookie, unsigned int *cookie_len)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
BIO * b = SSL_get_rbio(ssl); BIO * b = SSL_get_rbio(ssl);
struct conn * conn = b->ptr; struct conn * conn = b->ptr;
@ -539,7 +540,7 @@ int dtls_openssl_generate_cookie(SSL *ssl, unsigned char *cookie, unsigned int *
/* we "missuse" sockaddr2str to convert our cookie to a hex str */ /* we "missuse" sockaddr2str to convert our cookie to a hex str */
cw_dbg(DBG_DTLS,"DTLS session cookie for %s generated: %s", cw_dbg(DBG_DTLS,"DTLS session cookie for %s generated: %s",
sock_addr2str(&conn->addr), sock_hwaddr2idstr(conn->dtls_cookie,sizeof(conn->dtls_cookie))); sock_addr2str(&conn->addr,sock_buf), sock_hwaddr2idstr(conn->dtls_cookie,sizeof(conn->dtls_cookie)));
memcpy(cookie,conn->dtls_cookie,sizeof(conn->dtls_cookie)); memcpy(cookie,conn->dtls_cookie,sizeof(conn->dtls_cookie));
*cookie_len=sizeof(conn->dtls_cookie); *cookie_len=sizeof(conn->dtls_cookie);
@ -552,11 +553,12 @@ int dtls_openssl_generate_cookie(SSL *ssl, unsigned char *cookie, unsigned int *
int dtls_openssl_verify_cookie(SSL *ssl, unsigned char *cookie, unsigned int len) int dtls_openssl_verify_cookie(SSL *ssl, unsigned char *cookie, unsigned int len)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
BIO * b = SSL_get_rbio(ssl); BIO * b = SSL_get_rbio(ssl);
struct conn * conn = b->ptr; struct conn * conn = b->ptr;
cw_dbg(DBG_DTLS,"Verifying DTLS cookie from %s: %s", cw_dbg(DBG_DTLS,"Verifying DTLS cookie from %s: %s",
sock_addr2str(&conn->addr),sock_hwaddr2idstr(conn->dtls_cookie,len)); sock_addr2str(&conn->addr,sock_buf),sock_hwaddr2idstr(conn->dtls_cookie,len));
if (len != sizeof(conn->dtls_cookie)){ if (len != sizeof(conn->dtls_cookie)){
return 0; return 0;

View File

@ -26,6 +26,8 @@
int dtls_openssl_accept(struct conn *conn) int dtls_openssl_accept(struct conn *conn)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
if (!conn->dtls_data) if (!conn->dtls_data)
conn->dtls_data = conn->dtls_data =
dtls_openssl_data_create(conn, DTLSv1_server_method(), dtls_openssl_data_create(conn, DTLSv1_server_method(),
@ -49,6 +51,6 @@ int dtls_openssl_accept(struct conn *conn)
return 0; return 0;
} }
cw_log(LOG_ERR, "DTLS Error: Timeout while establishing session with %s.", cw_log(LOG_ERR, "DTLS Error: Timeout while establishing session with %s.",
sock_addr2str(&conn->addr)); sock_addr2str(&conn->addr, sock_buf));
return 0; return 0;
} }

View File

@ -124,6 +124,7 @@ int netconn_q_recv_packet_peek(struct netconn *nc, uint8_t * buffer, int len)
void netconn_q_add_packet(struct netconn * nc,uint8_t *packet,int len) void netconn_q_add_packet(struct netconn * nc,uint8_t *packet,int len)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
int qwpos = nc->qwpos; int qwpos = nc->qwpos;
if (qwpos==nc->qsize) if (qwpos==nc->qsize)
qwpos=0; qwpos=0;
@ -131,7 +132,7 @@ void netconn_q_add_packet(struct netconn * nc,uint8_t *packet,int len)
if (nc->qrpos==qwpos){ if (nc->qrpos==qwpos){
/* no buffers, discard packet */ /* no buffers, discard packet */
cw_dbg(DBG_PKT_ERR, "Discarding packet from %s, no queue buffers left", cw_dbg(DBG_PKT_ERR, "Discarding packet from %s, no queue buffers left",
sock_addr2str(&nc->addr)); sock_addr2str(&nc->addr,sock_buf));
return; return;
} }
@ -236,13 +237,14 @@ int netconn_send_capwap_msg(struct netconn * nc, uint8_t *rawmsg, int msglen)
int netconn_process_packet(struct netconn *nc, uint8_t * packet, int len, int netconn_process_packet(struct netconn *nc, uint8_t * packet, int len,
struct sockaddr *from) struct sockaddr *from)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
cw_dbg_pkt_nc(DBG_PKT_IN, nc, packet, len, from); cw_dbg_pkt_nc(DBG_PKT_IN, nc, packet, len, from);
if (len < 8) { if (len < 8) {
/* packet too short */ /* packet too short */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, packet too short, len=%d, at least 8 expected.", "Discarding packet from %s, packet too short, len=%d, at least 8 expected.",
sock_addr2str(&nc->addr), len); sock_addr2str(&nc->addr,sock_buf), len);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -253,7 +255,7 @@ int netconn_process_packet(struct netconn *nc, uint8_t * packet, int len,
/* wrong version */ /* wrong version */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, wrong version, version=%d, version %d expected.", "Discarding packet from %s, wrong version, version=%d, version %d expected.",
sock_addr2str(&nc->addr), (preamble & 0xf0) >> 4, sock_addr2str(&nc->addr,sock_buf), (preamble & 0xf0) >> 4,
CAPWAP_VERSION); CAPWAP_VERSION);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
@ -263,7 +265,7 @@ int netconn_process_packet(struct netconn *nc, uint8_t * packet, int len,
/* Encrypted data, this shuold never happen here */ /* Encrypted data, this shuold never happen here */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, encrypted data after decryption ...", "Discarding packet from %s, encrypted data after decryption ...",
sock_addr2str(&nc->addr)); sock_addr2str(&nc->addr,sock_buf));
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -277,7 +279,7 @@ int netconn_process_packet(struct netconn *nc, uint8_t * packet, int len,
/* Eleminate messages with wrong header size */ /* Eleminate messages with wrong header size */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, header length (%d) greater than packet len (%d).", "Discarding packet from %s, header length (%d) greater than packet len (%d).",
sock_addr2str(&nc->addr), offs, len); sock_addr2str(&nc->addr,sock_buf), offs, len);
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }
@ -289,7 +291,7 @@ int netconn_process_packet(struct netconn *nc, uint8_t * packet, int len,
/* wrong rmac size */ /* wrong rmac size */
cw_dbg(DBG_PKT_ERR, cw_dbg(DBG_PKT_ERR,
"Discarding packet from %s, wrong R-MAC size, size=%d", "Discarding packet from %s, wrong R-MAC size, size=%d",
sock_addr2str(&nc->addr), *(packet + 8)); sock_addr2str(&nc->addr,sock_buf), *(packet + 8));
errno = EAGAIN; errno = EAGAIN;
return -1; return -1;
} }

View File

@ -124,6 +124,7 @@ int conn_send_data_msg(struct conn * conn, uint8_t *rawmsg,int len)
int cw_send_request(struct conn *conn,int msg_id) int cw_send_request(struct conn *conn,int msg_id)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE];
cw_init_request(conn, msg_id); cw_init_request(conn, msg_id);
if ( cw_put_msg(conn, conn->req_buffer) == -1 ){ if ( cw_put_msg(conn, conn->req_buffer) == -1 ){
errno=ENOMSG; errno=ENOMSG;
@ -157,7 +158,7 @@ int cw_send_request(struct conn *conn,int msg_id)
} }
if ( rc <0 && errno != EAGAIN) { if ( rc <0 && errno != EAGAIN) {
cw_log(LOG_ERR,"Can't read from %s: %s",sock_addr2str(&conn->addr),strerror(errno)); cw_log(LOG_ERR,"Can't read from %s: %s",sock_addr2str(&conn->addr,sock_buf),strerror(errno));
} }
if ( rc <0 && errno == EAGAIN) { if ( rc <0 && errno == EAGAIN) {
errno=ETIMEDOUT; errno=ETIMEDOUT;

View File

@ -84,6 +84,9 @@ extern int sock_getifinfo(const struct sockaddr *addr, char *ifname,
char *sock_addrtostr(const struct sockaddr *sa, char *s, size_t maxlen, int addport); char *sock_addrtostr(const struct sockaddr *sa, char *s, size_t maxlen, int addport);
#define SOCK_ADDR_BUFSIZE 64
#define SOCK_ADDR_BUF_DEFINE char __sock_buf__[SOCK_ADDR_BUFSIZE]
/** /**
* Convert a sockaddr structure to a human readable string * Convert a sockaddr structure to a human readable string
@ -100,13 +103,13 @@ char *sock_addrtostr(const struct sockaddr *sa, char *s, size_t maxlen, int addp
sprintf("Adress: %s",sock_addr2str(&sa)); sprintf("Adress: %s",sock_addr2str(&sa));
\endcode \endcode
*/ */
#define sock_addr2str(s) ( sock_addrtostr( (struct sockaddr*)s, (char[64]){0}, 64, 0 ) ) #define sock_addr2str(s,buf) ( sock_addrtostr( (struct sockaddr*)s, buf , SOCK_ADDR_BUFSIZE, 0 ) )
/** /**
* Same as #sock_addr2str, but also the port number is appended to the result * Same as #sock_addr2str, but also the port number is appended to the result
* @see #sock_addr2str * @see #sock_addr2str
*/ */
#define sock_addr2str_p(s) ( sock_addrtostr( (struct sockaddr*)s, (char[64]){0}, 64,1 ) ) #define sock_addr2str_p(s,buf) ( sock_addrtostr( (struct sockaddr*)s, buf, SOCK_ADDR_BUFSIZE, 1 ) )