提交 89d2d3af 编写于 作者: S Stefan Weil 提交者: Blue Swirl

slirp: Remove some type casts caused by bad declaration of x.tp_buf

x.tp_buf was declared as a uint8_t array, but always used as
a char array (which needed a lot of type casts).

The patch includes these changes:

* Fix declaration of x.tp_buf and remove all type casts.

* Use offsetof() to get the offset of x.tp_buf.
Signed-off-by: NStefan Weil <weil@mail.berlios.de>
Signed-off-by: NBlue Swirl <blauwirbel@gmail.com>
上级 c3febae6
...@@ -136,9 +136,9 @@ static int tftp_send_oack(struct tftp_session *spt, ...@@ -136,9 +136,9 @@ static int tftp_send_oack(struct tftp_session *spt,
m->m_data += sizeof(struct udpiphdr); m->m_data += sizeof(struct udpiphdr);
tp->tp_op = htons(TFTP_OACK); tp->tp_op = htons(TFTP_OACK);
n += snprintf((char *)tp->x.tp_buf + n, sizeof(tp->x.tp_buf) - n, "%s", n += snprintf(tp->x.tp_buf + n, sizeof(tp->x.tp_buf) - n, "%s",
key) + 1; key) + 1;
n += snprintf((char *)tp->x.tp_buf + n, sizeof(tp->x.tp_buf) - n, "%u", n += snprintf(tp->x.tp_buf + n, sizeof(tp->x.tp_buf) - n, "%u",
value) + 1; value) + 1;
saddr.sin_addr = recv_tp->ip.ip_dst; saddr.sin_addr = recv_tp->ip.ip_dst;
...@@ -283,7 +283,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen) ...@@ -283,7 +283,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen)
/* skip header fields */ /* skip header fields */
k = 0; k = 0;
pktlen -= ((uint8_t *)&tp->x.tp_buf[0] - (uint8_t *)tp); pktlen -= offsetof(struct tftp_t, x.tp_buf);
/* prepend tftp_prefix */ /* prepend tftp_prefix */
prefix_len = strlen(slirp->tftp_prefix); prefix_len = strlen(slirp->tftp_prefix);
...@@ -299,7 +299,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen) ...@@ -299,7 +299,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen)
tftp_send_error(spt, 2, "Access violation", tp); tftp_send_error(spt, 2, "Access violation", tp);
return; return;
} }
req_fname[k] = (char)tp->x.tp_buf[k]; req_fname[k] = tp->x.tp_buf[k];
if (req_fname[k++] == '\0') { if (req_fname[k++] == '\0') {
break; break;
} }
...@@ -311,7 +311,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen) ...@@ -311,7 +311,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen)
return; return;
} }
if (strcasecmp((const char *)&tp->x.tp_buf[k], "octet") != 0) { if (strcasecmp(&tp->x.tp_buf[k], "octet") != 0) {
tftp_send_error(spt, 4, "Unsupported transfer mode", tp); tftp_send_error(spt, 4, "Unsupported transfer mode", tp);
return; return;
} }
...@@ -340,7 +340,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen) ...@@ -340,7 +340,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen)
while (k < pktlen) { while (k < pktlen) {
const char *key, *value; const char *key, *value;
key = (const char *)&tp->x.tp_buf[k]; key = &tp->x.tp_buf[k];
k += strlen(key) + 1; k += strlen(key) + 1;
if (k >= pktlen) { if (k >= pktlen) {
...@@ -348,7 +348,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen) ...@@ -348,7 +348,7 @@ static void tftp_handle_rrq(Slirp *slirp, struct tftp_t *tp, int pktlen)
return; return;
} }
value = (const char *)&tp->x.tp_buf[k]; value = &tp->x.tp_buf[k];
k += strlen(value) + 1; k += strlen(value) + 1;
if (strcasecmp(key, "tsize") == 0) { if (strcasecmp(key, "tsize") == 0) {
......
...@@ -26,7 +26,7 @@ struct tftp_t { ...@@ -26,7 +26,7 @@ struct tftp_t {
uint16_t tp_error_code; uint16_t tp_error_code;
uint8_t tp_msg[512]; uint8_t tp_msg[512];
} tp_error; } tp_error;
uint8_t tp_buf[512 + 2]; char tp_buf[512 + 2];
} x; } x;
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册