All of lore.kernel.org
 help / color / mirror / Atom feed
From: Oliver Hartkopp <socketcan@hartkopp.net>
To: "Ahmed S. Darwish" <darwish.07@gmail.com>
Cc: linux-can@vger.kernel.org
Subject: Re: [PATCH v2 1/2] can: fix multiple delivery of a single CAN frame for overlapping CAN filters
Date: Thu, 19 Mar 2015 09:06:45 +0100	[thread overview]
Message-ID: <550A8395.4080307@hartkopp.net> (raw)
In-Reply-To: <20150318221709.GB2602@Darwish.PC>

On 18.03.2015 23:17, Ahmed S. Darwish wrote:

>> diff --git a/net/can/raw.c b/net/can/raw.c
>> index 00c13ef..0a6abf1 100644
>> --- a/net/can/raw.c
>> +++ b/net/can/raw.c
>> @@ -86,6 +86,8 @@ struct raw_sock {
>>   	struct can_filter dfilter; /* default/single filter */
>>   	struct can_filter *filter; /* pointer to filter(s) */
>>   	can_err_mask_t err_mask;
>> +	struct sk_buff *uniq_skb;
>> +	ktime_t uniq_tstamp;
>>   };
>>
>
> My knowledge of the networking internals are really shallow,
> but the `uniq_tstamp' field above feels a little bit redundant?

(..)

> If so, isn't the `uniq_skb' field, on its own, quite sufficient?

AFAIK the skbs are retrieved from a memory pool, so it can be that the skb 
pointer values can be the same by the time.

E.g. if you receive the CAN frames in a timely distance that the skb pointer 
accidentally is the same than the last time, you might unintentionally drop a 
new (changed) content.

With checking the timestamp this possibility of potentially identical skb 
pointers is removed.

Regards,
Oliver


      reply	other threads:[~2015-03-19  8:06 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-03-18  6:10 [PATCH v2 1/2] can: fix multiple delivery of a single CAN frame for overlapping CAN filters Oliver Hartkopp
2015-03-18  6:10 ` [PATCH v2 2/2] can: introduce new raw socket option to join the given " Oliver Hartkopp
2015-03-18 21:47   ` Ahmed S. Darwish
2015-03-18 22:17 ` [PATCH v2 1/2] can: fix multiple delivery of a single CAN frame for overlapping " Ahmed S. Darwish
2015-03-19  8:06   ` Oliver Hartkopp [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=550A8395.4080307@hartkopp.net \
    --to=socketcan@hartkopp.net \
    --cc=darwish.07@gmail.com \
    --cc=linux-can@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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.