* The temporary buffer was never freed in case it still contained more than one iovec.

* Minor cleanup.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@19459 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2006-12-11 16:56:23 +00:00
parent 2e31a85d7f
commit 84fcc63a5e

View File

@ -139,8 +139,6 @@ dprintf("try to send ethernet packet of %lu bytes (flags %ld):\n", buffer->size,
if (gBufferModule->count_iovecs(buffer) > 1) { if (gBufferModule->count_iovecs(buffer) > 1) {
// TODO: for now, create a new buffer containing the data // TODO: for now, create a new buffer containing the data
net_buffer *original = buffer;
buffer = gBufferModule->duplicate(original); buffer = gBufferModule->duplicate(original);
if (buffer == NULL) if (buffer == NULL)
return ENOBUFS; return ENOBUFS;
@ -149,6 +147,8 @@ dprintf("try to send ethernet packet of %lu bytes (flags %ld):\n", buffer->size,
if (gBufferModule->count_iovecs(buffer) > 1) { if (gBufferModule->count_iovecs(buffer) > 1) {
dprintf("scattered I/O is not yet supported by ethernet device.\n"); dprintf("scattered I/O is not yet supported by ethernet device.\n");
gBufferModule->free(buffer);
device->stats.send.errors++;
return B_NOT_SUPPORTED; return B_NOT_SUPPORTED;
} }
} }