[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <7b9198260801081539x7aee72fbm53b5f298c5faf56@mail.gmail.com>
Date: Tue, 8 Jan 2008 23:39:58 +0000
From: "Tom Spink" <tspink@...il.com>
To: "Brent Casavant" <bcasavan@....com>
Cc: "Rick Jones" <rick.jones2@...com>, netdev@...r.kernel.org,
"David Miller" <davem@...emloft.net>, linux-kernel@...r.kernel.org
Subject: Re: AF_UNIX MSG_PEEK bug?
On 08/01/2008, Brent Casavant <bcasavan@....com> wrote:
> On Tue, 8 Jan 2008, Tom Spink wrote:
>
> > Where in the code is the message length being sent across the socket?
>
> In do_producer(), there are the following lines in the main loop:
>
> /* Send random lengths of data */
> messages[i].length = (rand() % MAXLEN) + sizeof(size_t);
> iov[i].iov_len = messages[i].length;
>
> The entire "struct sockmsg" is sent across the socket, so the first
> size_t in each message contains the length of the entire message
> (including the size_t). This size gets picked up at the
> recv(...,MSG_PEEK) line in do_consumer().
>
> Thanks,
> Brent
>
> --
> Brent Casavant All music is folk music. I ain't
> bcasavan@....com never heard a horse sing a song.
> Silicon Graphics, Inc. -- Louis Armstrong
>
Hi,
But you're not consuming the size_t on the other end. You're only
peeking it, i.e. you're doing the recv to peek at the message, but
never calling recv to remove that data from the queue... or am I
missing something?
--
Regards,
Tom Spink
University of Edinburgh
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists