All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH BlueZ] AVCTP: Make use of sendmsg to avoid copying data
@ 2012-07-19 10:49 Luiz Augusto von Dentz
  2012-07-19 11:22 ` Johan Hedberg
  2012-07-19 11:36 ` Lucas De Marchi
  0 siblings, 2 replies; 4+ messages in thread
From: Luiz Augusto von Dentz @ 2012-07-19 10:49 UTC (permalink / raw)
  To: linux-bluetooth

From: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>

This use sendmsg to send headers and operands in separated buffers
avoiding memcpy.
---
 audio/avctp.c |   21 ++++++++++++---------
 1 file changed, 12 insertions(+), 9 deletions(-)

diff --git a/audio/avctp.c b/audio/avctp.c
index e3e5275..9ef6161 100644
--- a/audio/avctp.c
+++ b/audio/avctp.c
@@ -929,23 +929,20 @@ static int avctp_send(struct avctp *session, uint8_t transaction, uint8_t cr,
 				uint8_t code, uint8_t subunit, uint8_t opcode,
 				uint8_t *operands, size_t operand_count)
 {
-	uint8_t *buf;
+	uint8_t buf[AVCTP_HEADER_LENGTH + AVC_HEADER_LENGTH];
 	struct avctp_header *avctp;
 	struct avc_header *avc;
-	uint8_t *pdu;
+	struct msghdr msg;
+	struct iovec iov[2];
 	int sk, err = 0;
-	uint16_t size;
 
 	if (session->state != AVCTP_STATE_CONNECTED)
 		return -ENOTCONN;
 
 	sk = g_io_channel_unix_get_fd(session->io);
-	size = AVCTP_HEADER_LENGTH + AVC_HEADER_LENGTH + operand_count;
-	buf = g_malloc0(size);
 
 	avctp = (void *) buf;
 	avc = (void *) &buf[AVCTP_HEADER_LENGTH];
-	pdu = (void *) &buf[AVCTP_HEADER_LENGTH + AVC_HEADER_LENGTH];
 
 	avctp->transaction = transaction;
 	avctp->packet_type = AVCTP_PACKET_SINGLE;
@@ -956,12 +953,18 @@ static int avctp_send(struct avctp *session, uint8_t transaction, uint8_t cr,
 	avc->subunit_type = subunit;
 	avc->opcode = opcode;
 
-	memcpy(pdu, operands, operand_count);
+	iov[0].iov_base = buf;
+	iov[0].iov_len  = sizeof(buf);
+	iov[1].iov_base = operands;
+	iov[1].iov_len  = operand_count;
 
-	if (write(sk, buf, size) < 0)
+	memset(&msg, 0, sizeof(msg));
+	msg.msg_iov = iov;
+	msg.msg_iovlen = 2;
+
+	if (sendmsg(sk, &msg, 0) < 0)
 		err = -errno;
 
-	g_free(buf);
 	return err;
 }
 
-- 
1.7.10.4


^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH BlueZ] AVCTP: Make use of sendmsg to avoid copying data
  2012-07-19 10:49 [PATCH BlueZ] AVCTP: Make use of sendmsg to avoid copying data Luiz Augusto von Dentz
@ 2012-07-19 11:22 ` Johan Hedberg
  2012-07-19 11:36 ` Lucas De Marchi
  1 sibling, 0 replies; 4+ messages in thread
From: Johan Hedberg @ 2012-07-19 11:22 UTC (permalink / raw)
  To: Luiz Augusto von Dentz; +Cc: linux-bluetooth

Hi Luiz,

On Thu, Jul 19, 2012, Luiz Augusto von Dentz wrote:
> This use sendmsg to send headers and operands in separated buffers
> avoiding memcpy.
> ---
>  audio/avctp.c |   21 ++++++++++++---------
>  1 file changed, 12 insertions(+), 9 deletions(-)

Applied. Thanks.

Johan

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH BlueZ] AVCTP: Make use of sendmsg to avoid copying data
  2012-07-19 10:49 [PATCH BlueZ] AVCTP: Make use of sendmsg to avoid copying data Luiz Augusto von Dentz
  2012-07-19 11:22 ` Johan Hedberg
@ 2012-07-19 11:36 ` Lucas De Marchi
  2012-07-19 12:01   ` Luiz Augusto von Dentz
  1 sibling, 1 reply; 4+ messages in thread
From: Lucas De Marchi @ 2012-07-19 11:36 UTC (permalink / raw)
  To: Luiz Augusto von Dentz; +Cc: linux-bluetooth

Hi Luiz,

On Thu, Jul 19, 2012 at 7:49 AM, Luiz Augusto von Dentz
<luiz.dentz@gmail.com> wrote:
> From: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
>
> This use sendmsg to send headers and operands in separated buffers
> avoiding memcpy.
> ---

Nice...  only a small issue

>  audio/avctp.c |   21 ++++++++++++---------
>  1 file changed, 12 insertions(+), 9 deletions(-)
>
> diff --git a/audio/avctp.c b/audio/avctp.c
> index e3e5275..9ef6161 100644
> --- a/audio/avctp.c
> +++ b/audio/avctp.c
> @@ -929,23 +929,20 @@ static int avctp_send(struct avctp *session, uint8_t transaction, uint8_t cr,
>                                 uint8_t code, uint8_t subunit, uint8_t opcode,
>                                 uint8_t *operands, size_t operand_count)
>  {
> -       uint8_t *buf;
> +       uint8_t buf[AVCTP_HEADER_LENGTH + AVC_HEADER_LENGTH];

you need to zero-out this, or set all the fields below.



Lucas De Marchi

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH BlueZ] AVCTP: Make use of sendmsg to avoid copying data
  2012-07-19 11:36 ` Lucas De Marchi
@ 2012-07-19 12:01   ` Luiz Augusto von Dentz
  0 siblings, 0 replies; 4+ messages in thread
From: Luiz Augusto von Dentz @ 2012-07-19 12:01 UTC (permalink / raw)
  To: Lucas De Marchi; +Cc: linux-bluetooth

Hi Lucas,

On Thu, Jul 19, 2012 at 2:36 PM, Lucas De Marchi
<lucas.demarchi@profusion.mobi> wrote:
> Hi Luiz,
>
> On Thu, Jul 19, 2012 at 7:49 AM, Luiz Augusto von Dentz
> <luiz.dentz@gmail.com> wrote:
>> From: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
>>
>> This use sendmsg to send headers and operands in separated buffers
>> avoiding memcpy.
>> ---
>
> Nice...  only a small issue
>
>>  audio/avctp.c |   21 ++++++++++++---------
>>  1 file changed, 12 insertions(+), 9 deletions(-)
>>
>> diff --git a/audio/avctp.c b/audio/avctp.c
>> index e3e5275..9ef6161 100644
>> --- a/audio/avctp.c
>> +++ b/audio/avctp.c
>> @@ -929,23 +929,20 @@ static int avctp_send(struct avctp *session, uint8_t transaction, uint8_t cr,
>>                                 uint8_t code, uint8_t subunit, uint8_t opcode,
>>                                 uint8_t *operands, size_t operand_count)
>>  {
>> -       uint8_t *buf;
>> +       uint8_t buf[AVCTP_HEADER_LENGTH + AVC_HEADER_LENGTH];
>
> you need to zero-out this, or set all the fields below.

It should be now fixed, thanks.


-- 
Luiz Augusto von Dentz

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2012-07-19 12:01 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2012-07-19 10:49 [PATCH BlueZ] AVCTP: Make use of sendmsg to avoid copying data Luiz Augusto von Dentz
2012-07-19 11:22 ` Johan Hedberg
2012-07-19 11:36 ` Lucas De Marchi
2012-07-19 12:01   ` Luiz Augusto von Dentz

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.