[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <cb00fa210910210615v409d09c6p34cd6a48c48196f5@mail.gmail.com>
Date: Wed, 21 Oct 2009 10:15:10 -0300
From: Ivo Calado <ivocalado@...edded.ufcg.edu.br>
To: dccp <dccp@...r.kernel.org>, Gerrit Renker <gerrit@....abdn.ac.uk>,
Ivo Calado <ivocalado@...edded.ufcg.edu.br>,
netdev <netdev@...r.kernel.org>
Subject: Re: [PATCH 1/4] Adds random ect generation to tfrc-sp sender side
On Mon, Oct 19, 2009 at 2:23 AM, Gerrit Renker <gerrit@....abdn.ac.uk> wrote:
> | Adds random ect generation to tfrc-sp sender side.
>
> I thought about this and found several reasons why it would be better to
> defer ECN Nonce sums to a later implementation.
>
> 1) At the moment the code always sets ECT(0). Even if it would
> alternate ECT(0) and ECT(1), this would later be overwritten by ECT(0)
> in dccp_msghdr_parse(). Ok, this could be fixed, but the real problem
> is that the underlying machinery does not support ECN nonces, since
>
> * ECN / DiffServ information is in two separate places of the
> inet_sock (u8 `tos' field and u8 `tclass' field of ipv6_pinfo);
>
> * the ECN driver sits in include/net/inet_ecn.h as
> #define INET_ECN_xmit(sk) do { inet_sk(sk)->tos |= INET_ECN_ECT_0; } while (0)
>
> * hence this would need to be revised and the best way to make an
> acceptable suggestion would be a coded proof of concept that
> changing the underlying implementation does have benefits.
>
> On the receiver side the situation is the same. The function
> tfrc_sp_check_ecn_sum(), introduced in Patch 2/4 of the TFRC-SP sender
> implementation is only referenced in Patch 2/2 of the CCID-4 set, where
> it ends, without side effect in "TODO: consider ecn sum test fail".
>
> That is, at the moment both the sender and receiver side of the ECN Nonce
> sum verification are placeholders which currently have no effect.
>
Okay, then the implementation would be useless now.
>
> 2) As far as I can see the ECN Nonce is an optimisation, an
>
> "optional addition to Explicit Congestion Notification [RFC3168]
> improving its robustness against malicious or accidental
> concealment of marked packets [...]" (from the abstract)
>
> Hence if at all, we would only have a benefit of adding the ECN Nonce
> verification on top of an already verified implementation.
>
Yes, not priority at all. And you're right, no benefit.
> 3) Starting an implementation throws up further questions that need to
> be addressed, both the basis and the extension need to be verified.
>
> I would like to suggest to implement the basis, that is CCID-4 with ECN
> (using plain ECT(0)), test with that until it works satisfactorily, and
> then continue adding measures such as the ECN Nonce verification.
>
Okay. But, when would be good to at least include random ECT
generation? When DCCP ECN code will get fixed? Is there any work on
this?
> Nothing is lost, once we are at this stage we can return to this set of
> initial patches and revise the situation based on the insights gained
> with ECT(0) experience.
>
> In summary, I would like to suggest to remove the ECN verification for
> the moment and focus on the "basic" issues first.
>
> Would you be ok with that?
>
Yes, we'll keep the ECN verification code here at our git until the
scenario is ready.
>
>
> Appendix
> --------
> | +int tfrc_sp_get_random_ect(struct tfrc_tx_li_data *li_data, u64 seqn)
> | +{
> | + int ect;
> | + struct tfrc_ecn_echo_sum_entry *sum;
> | +
> | + /* TODO: implement random ect*/
> | + ect = INET_ECN_ECT_0;
> | +
> | + sum = kmem_cache_alloc(tfrc_ecn_echo_sum_slab, GFP_ATOMIC);
>
> For a later implementation, there should be protection against NULL, e.g.
> if (sum == NULL) {
> DCCP_CRIT("Problem here ...");
> return 0;
> }
> | +
> | + sum->previous = li_data->ecn_sums_head;
> | + sum->ecn_echo_sum = (sum->previous->ecn_echo_sum) ? !ect : ect;
>
Thanks, i forgot that.
> (Also for later) I wonder how to do the sums, with RFC 3168
> ECT(0) = 0x2 => !0x2 = 0
> ECT(1) = 0x1 => !0x1 = 0
>
I don't understand. Can you try to explain it? Or cite RFC section
that address it?
> From the addition table in RFC 3540, section 2,
> ECT(0) + ECT(0) = 0
> ECT(0) + ECT(1) = 1
> ECT(1) + ECT(1) = 0
>
> One way could be
> sum->ecn_echo_sum ^= (ect == INET_ECN_ECT_1);
Ok.
--
Ivo Augusto Andrade Rocha Calado
MSc. Candidate
Embedded Systems and Pervasive Computing Lab - http://embedded.ufcg.edu.br
Systems and Computing Department - http://www.dsc.ufcg.edu.br
Electrical Engineering and Informatics Center - http://www.ceei.ufcg.edu.br
Federal University of Campina Grande - http://www.ufcg.edu.br
PGP: 0x03422935
Quidquid latine dictum sit, altum viditur.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists