Use macro expansion for maximum sockaddr storage length rather than hardcoded value
This commit is contained in:
parent
c5ecf54d51
commit
c58a4a3743
@ -6,10 +6,10 @@
|
||||
int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
||||
{
|
||||
int ret = 0;
|
||||
int tmp_addrlen = 0x1c;
|
||||
int tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
int fd, dev;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
u32 saved_threadstorage[2];
|
||||
|
||||
sockfd = soc_get_fd(sockfd);
|
||||
@ -27,7 +27,7 @@ int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
||||
fd = __alloc_handle(dev);
|
||||
if(fd < 0) return fd;
|
||||
|
||||
memset(tmpaddr, 0, 0x1c);
|
||||
memset(tmpaddr, 0, ADDR_STORAGE_LEN);
|
||||
|
||||
cmdbuf[0] = IPC_MakeHeader(0x4,2,2); // 0x40082
|
||||
cmdbuf[1] = (u32)sockfd;
|
||||
|
@ -8,7 +8,7 @@ int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen)
|
||||
int ret = 0;
|
||||
int tmp_addrlen = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
|
||||
sockfd = soc_get_fd(sockfd);
|
||||
if(sockfd < 0) {
|
||||
@ -16,12 +16,12 @@ int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen)
|
||||
return -1;
|
||||
}
|
||||
|
||||
memset(tmpaddr, 0, 0x1c);
|
||||
memset(tmpaddr, 0, ADDR_STORAGE_LEN);
|
||||
|
||||
if(addr->sa_family == AF_INET)
|
||||
tmp_addrlen = 8;
|
||||
else
|
||||
tmp_addrlen = 0x1c;
|
||||
tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
|
||||
if(addrlen < tmp_addrlen) {
|
||||
errno = EINVAL;
|
||||
|
@ -10,6 +10,7 @@
|
||||
#include <3ds/services/soc.h>
|
||||
|
||||
#define SYNC_ERROR ENODEV
|
||||
#define ADDR_STORAGE_LEN sizeof(struct sockaddr_storage)
|
||||
|
||||
extern Handle SOCU_handle;
|
||||
extern Handle socMemhandle;
|
||||
|
@ -8,7 +8,7 @@ int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen)
|
||||
int ret = 0;
|
||||
int tmp_addrlen = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
|
||||
sockfd = soc_get_fd(sockfd);
|
||||
if(sockfd < 0) {
|
||||
@ -16,12 +16,12 @@ int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen)
|
||||
return -1;
|
||||
}
|
||||
|
||||
memset(tmpaddr, 0, 0x1c);
|
||||
memset(tmpaddr, 0, ADDR_STORAGE_LEN);
|
||||
|
||||
if(addr->sa_family == AF_INET)
|
||||
tmp_addrlen = 8;
|
||||
else
|
||||
tmp_addrlen = 0x1c;
|
||||
tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
|
||||
if(addrlen < tmp_addrlen) {
|
||||
errno = EINVAL;
|
||||
|
@ -8,7 +8,7 @@ int getnameinfo(const struct sockaddr *sa, socklen_t salen, char *host, socklen_
|
||||
int i,tmp_addrlen;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u32 saved_threadstorage[4];
|
||||
u8 tmpaddr[0x1c]; // sockaddr size for the kernel is 0x1C (sockaddr_in6?)
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN]; // sockaddr size for the kernel is 0x1C (sockaddr_in6?)
|
||||
|
||||
if((host == NULL || hostlen == 0) && (serv == NULL || servlen == 0))
|
||||
{
|
||||
@ -18,7 +18,7 @@ int getnameinfo(const struct sockaddr *sa, socklen_t salen, char *host, socklen_
|
||||
if(sa->sa_family == AF_INET)
|
||||
tmp_addrlen = 8;
|
||||
else
|
||||
tmp_addrlen = 0x1c;
|
||||
tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
|
||||
if(salen < tmp_addrlen) {
|
||||
errno = EINVAL;
|
||||
|
@ -8,7 +8,7 @@ int getpeername(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
||||
int ret = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u32 saved_threadstorage[2];
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
|
||||
sockfd = soc_get_fd(sockfd);
|
||||
if(sockfd < 0) {
|
||||
@ -18,14 +18,14 @@ int getpeername(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
||||
|
||||
cmdbuf[0] = IPC_MakeHeader(0x18,2,2); // 0x180082
|
||||
cmdbuf[1] = (u32)sockfd;
|
||||
cmdbuf[2] = 0x1c;
|
||||
cmdbuf[2] = ADDR_STORAGE_LEN;
|
||||
cmdbuf[3] = IPC_Desc_CurProcessId();
|
||||
|
||||
u32 * staticbufs = getThreadStaticBuffers();
|
||||
saved_threadstorage[0] = staticbufs[0];
|
||||
saved_threadstorage[1] = staticbufs[1];
|
||||
|
||||
staticbufs[0] = IPC_Desc_StaticBuffer(0x1c,0);
|
||||
staticbufs[0] = IPC_Desc_StaticBuffer(ADDR_STORAGE_LEN,0);
|
||||
staticbufs[1] = (u32)tmpaddr;
|
||||
|
||||
ret = svcSendSyncRequest(SOCU_handle);
|
||||
|
@ -8,7 +8,7 @@ int getsockname(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
||||
int ret = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u32 saved_threadstorage[2];
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
|
||||
sockfd = soc_get_fd(sockfd);
|
||||
if(sockfd < 0) {
|
||||
@ -18,14 +18,14 @@ int getsockname(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
|
||||
|
||||
cmdbuf[0] = IPC_MakeHeader(0x17,2,2); // 0x170082
|
||||
cmdbuf[1] = (u32)sockfd;
|
||||
cmdbuf[2] = 0x1c;
|
||||
cmdbuf[2] = ADDR_STORAGE_LEN;
|
||||
cmdbuf[3] = IPC_Desc_CurProcessId();
|
||||
|
||||
u32 * staticbufs = getThreadStaticBuffers();
|
||||
saved_threadstorage[0] = staticbufs[0];
|
||||
saved_threadstorage[1] = staticbufs[1];
|
||||
|
||||
staticbufs[0] = IPC_Desc_StaticBuffer(0x1c,0);
|
||||
staticbufs[0] = IPC_Desc_StaticBuffer(ADDR_STORAGE_LEN,0);
|
||||
staticbufs[1] = (u32)tmpaddr;
|
||||
|
||||
ret = svcSendSyncRequest(SOCU_handle);
|
||||
|
@ -8,13 +8,13 @@ ssize_t socuipc_cmd7(int sockfd, void *buf, size_t len, int flags, struct sockad
|
||||
int ret = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u32 tmp_addrlen = 0;
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
u32 saved_threadstorage[2];
|
||||
|
||||
memset(tmpaddr, 0, 0x1c);
|
||||
memset(tmpaddr, 0, ADDR_STORAGE_LEN);
|
||||
|
||||
if(src_addr)
|
||||
tmp_addrlen = 0x1c;
|
||||
tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
|
||||
cmdbuf[0] = IPC_MakeHeader(0x7,4,4); // 0x70104
|
||||
cmdbuf[1] = (u32)sockfd;
|
||||
@ -66,13 +66,13 @@ ssize_t socuipc_cmd8(int sockfd, void *buf, size_t len, int flags, struct sockad
|
||||
int ret = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u32 tmp_addrlen = 0;
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
u32 saved_threadstorage[4];
|
||||
|
||||
if(src_addr)
|
||||
tmp_addrlen = 0x1c;
|
||||
tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
|
||||
memset(tmpaddr, 0, 0x1c);
|
||||
memset(tmpaddr, 0, ADDR_STORAGE_LEN);
|
||||
|
||||
cmdbuf[0] = 0x00080102;
|
||||
cmdbuf[1] = (u32)sockfd;
|
||||
|
@ -8,15 +8,15 @@ ssize_t socuipc_cmd9(int sockfd, const void *buf, size_t len, int flags, const s
|
||||
int ret = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u32 tmp_addrlen = 0;
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
|
||||
memset(tmpaddr, 0, 0x1c);
|
||||
memset(tmpaddr, 0, ADDR_STORAGE_LEN);
|
||||
|
||||
if(dest_addr) {
|
||||
if(dest_addr->sa_family == AF_INET)
|
||||
tmp_addrlen = 8;
|
||||
else
|
||||
tmp_addrlen = 0x1c;
|
||||
tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
|
||||
if(addrlen < tmp_addrlen) {
|
||||
errno = EINVAL;
|
||||
@ -62,15 +62,15 @@ ssize_t socuipc_cmda(int sockfd, const void *buf, size_t len, int flags, const s
|
||||
int ret = 0;
|
||||
u32 *cmdbuf = getThreadCommandBuffer();
|
||||
u32 tmp_addrlen = 0;
|
||||
u8 tmpaddr[0x1c];
|
||||
u8 tmpaddr[ADDR_STORAGE_LEN];
|
||||
|
||||
memset(tmpaddr, 0, 0x1c);
|
||||
memset(tmpaddr, 0, ADDR_STORAGE_LEN);
|
||||
|
||||
if(dest_addr) {
|
||||
if(dest_addr->sa_family == AF_INET)
|
||||
tmp_addrlen = 8;
|
||||
else
|
||||
tmp_addrlen = 0x1c;
|
||||
tmp_addrlen = ADDR_STORAGE_LEN;
|
||||
|
||||
if(addrlen < tmp_addrlen) {
|
||||
errno = EINVAL;
|
||||
|
Loading…
Reference in New Issue
Block a user