* Re: [PATCH] (8/17) ipx -- size_t for send/recvmsg
2004-01-09 22:02 [PATCH] (8/17) ipx -- size_t for send/recvmsg Stephen Hemminger
@ 2004-01-08 22:17 ` Arnaldo Carvalho de Melo
0 siblings, 0 replies; 2+ messages in thread
From: Arnaldo Carvalho de Melo @ 2004-01-08 22:17 UTC (permalink / raw)
To: Stephen Hemminger; +Cc: David S. Miller, netdev
Em Fri, Jan 09, 2004 at 02:02:23PM -0800, Stephen Hemminger escreveu:
> Convert IPX to unsigned for send/receive message length.
> Enforce MTU limited by header pktsize.
ACK, thanks Stephen.
^ permalink raw reply [flat|nested] 2+ messages in thread
* [PATCH] (8/17) ipx -- size_t for send/recvmsg
@ 2004-01-09 22:02 Stephen Hemminger
2004-01-08 22:17 ` Arnaldo Carvalho de Melo
0 siblings, 1 reply; 2+ messages in thread
From: Stephen Hemminger @ 2004-01-09 22:02 UTC (permalink / raw)
To: David S. Miller, Arnaldo Carvalho de Melo; +Cc: netdev
Convert IPX to unsigned for send/receive message length.
Enforce MTU limited by header pktsize.
diff -Nru a/net/ipx/af_ipx.c b/net/ipx/af_ipx.c
--- a/net/ipx/af_ipx.c Mon Dec 8 16:19:52 2003
+++ b/net/ipx/af_ipx.c Mon Dec 8 16:19:52 2003
@@ -1683,7 +1683,7 @@
}
static int ipx_sendmsg(struct kiocb *iocb, struct socket *sock,
- struct msghdr *msg, int len)
+ struct msghdr *msg, size_t len)
{
struct sock *sk = sock->sk;
struct ipx_opt *ipxs = ipx_sk(sk);
@@ -1698,6 +1698,10 @@
if (flags & ~MSG_DONTWAIT)
goto out;
+ /* Max possible packet size limited by 16 bit pktsize in header */
+ if (len >= 65535 - sizeof(struct ipxhdr))
+ goto out;
+
if (usipx) {
if (!ipxs->port) {
struct sockaddr_ipx uaddr;
@@ -1744,7 +1748,7 @@
static int ipx_recvmsg(struct kiocb *iocb, struct socket *sock,
- struct msghdr *msg, int size, int flags)
+ struct msghdr *msg, size_t size, int flags)
{
struct sock *sk = sock->sk;
struct ipx_opt *ipxs = ipx_sk(sk);
diff -Nru a/net/ipx/ipx_route.c b/net/ipx/ipx_route.c
--- a/net/ipx/ipx_route.c Mon Dec 8 16:19:52 2003
+++ b/net/ipx/ipx_route.c Mon Dec 8 16:19:52 2003
@@ -169,13 +169,13 @@
* Route an outgoing frame from a socket.
*/
int ipxrtr_route_packet(struct sock *sk, struct sockaddr_ipx *usipx,
- struct iovec *iov, int len, int noblock)
+ struct iovec *iov, size_t len, int noblock)
{
struct sk_buff *skb;
struct ipx_opt *ipxs = ipx_sk(sk);
struct ipx_interface *intrfc;
struct ipxhdr *ipx;
- int size;
+ size_t size;
int ipx_offset;
struct ipx_route *rt = NULL;
int rc;
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2004-01-09 22:02 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-01-09 22:02 [PATCH] (8/17) ipx -- size_t for send/recvmsg Stephen Hemminger
2004-01-08 22:17 ` Arnaldo Carvalho de Melo
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.