aboutsummaryrefslogtreecommitdiff
path: root/toys/pending/tftpd.c
diff options
context:
space:
mode:
Diffstat (limited to 'toys/pending/tftpd.c')
-rw-r--r--toys/pending/tftpd.c24
1 files changed, 11 insertions, 13 deletions
diff --git a/toys/pending/tftpd.c b/toys/pending/tftpd.c
index 41a1cc72..31af44be 100644
--- a/toys/pending/tftpd.c
+++ b/toys/pending/tftpd.c
@@ -15,9 +15,9 @@ config TFTPD
Transfer file from/to tftp server.
- -r Prohibit upload
+ -r read only
-c Allow file creation via upload
- -u Access files as USER
+ -u run as USER
-l Log to syslog (inetd mode requires this)
*/
@@ -236,7 +236,7 @@ CLEAN_APP:
void tftpd_main(void)
{
- int recvmsg_len, rbuflen, opcode, blksize = TFTPD_BLKSIZE, tsize = 0, set =1;
+ int fd = 0, recvmsg_len, rbuflen, opcode, blksize = TFTPD_BLKSIZE, tsize = 0, set =1;
struct sockaddr_storage srcaddr, dstaddr;
socklen_t socklen = sizeof(struct sockaddr_storage);
char *buf = toybuf;
@@ -250,28 +250,26 @@ void tftpd_main(void)
if (TT.user) TT.pw = xgetpwnam(TT.user);
if (*toys.optargs) xchroot(*toys.optargs);
- recvmsg_len = recvfrom(STDIN_FILENO, toybuf, TFTPD_BLKSIZE, 0,
- (struct sockaddr*)&dstaddr, &socklen);
+ recvmsg_len = recvfrom(fd, toybuf, blksize, 0, (void *)&dstaddr, &socklen);
- TT.sfd = xsocket(((struct sockaddr*)&dstaddr)->sa_family, SOCK_DGRAM, 0);
+ TT.sfd = xsocket(dstaddr.ss_family, SOCK_DGRAM, 0);
if (setsockopt(TT.sfd, SOL_SOCKET, SO_REUSEADDR, (const void *)&set,
sizeof(set)) < 0) perror_exit("setsockopt failed");
- if (bind(TT.sfd, (struct sockaddr*)&srcaddr, socklen)) perror_exit("bind");
- if (connect(TT.sfd, (struct sockaddr*)&dstaddr, socklen) < 0)
+ if (bind(TT.sfd, (void *)&srcaddr, socklen)) perror_exit("bind");
+ if (connect(TT.sfd, (void *)&dstaddr, socklen) < 0)
perror_exit("can't connect to remote host");
// Error condition.
- if (recvmsg_len < 4 || recvmsg_len > TFTPD_BLKSIZE
- || toybuf[recvmsg_len-1] != '\0') {
+ if (recvmsg_len<4 || recvmsg_len>TFTPD_BLKSIZE || toybuf[recvmsg_len-1]) {
send_errpkt((struct sockaddr*)&dstaddr, socklen, "packet format error");
return;
}
// request is either upload or Download.
- opcode = ntohs(*(uint16_t*)buf);
+ opcode = buf[1];
if (((opcode != TFTPD_OP_RRQ) && (opcode != TFTPD_OP_WRQ))
|| ((opcode == TFTPD_OP_WRQ) && (toys.optflags & FLAG_r))) {
send_errpkt((struct sockaddr*)&dstaddr, socklen,
- ((opcode == TFTPD_OP_WRQ) ? "write error" : "packet format error"));
+ (opcode == TFTPD_OP_WRQ) ? "write error" : "packet format error");
return;
}
@@ -283,7 +281,7 @@ void tftpd_main(void)
buf += strlen(buf) + 1; //1 '\0'.
// As per RFC 1350, mode is case in-sensitive.
- if ((buf >= (toybuf + recvmsg_len)) || (strcasecmp(buf, "octet"))) {
+ if (buf >= toybuf+recvmsg_len || strcasecmp(buf, "octet")) {
send_errpkt((struct sockaddr*)&dstaddr, socklen, "packet format error");
return;
}