1. 21 Sep, 2010 5 commits
    • Gerrit Renker's avatar
      dccp ccid-3: Remove redundant 'options_received' struct · 536bb20b
      Gerrit Renker authored
      The `options_received' struct is redundant, since it re-duplicates the existing
      `p' and `x_recv' fields. This patch removes the sub-struct and migrates the
      format conversion operations to ccid3_hc_tx_parse_options().
      Signed-off-by: default avatarGerrit Renker <gerrit@erg.abdn.ac.uk>
      536bb20b
    • Gerrit Renker's avatar
      dccp tfrc/ccid-3: computing the loss rate from the Loss Event Rate · 792e6d33
      Gerrit Renker authored
      This adds a function to take care of the following, separate cases occurring in
      the computation of the Loss Rate p:
      
       * 1/(2^32-1) is mapped into 0% as per RFC 4342, 8.5;
       * 1/0        is mapped into 100%, the maximum;
       * to avoid that p = 1/x is rounded down to 0 when x is very large, since this
         means accidentally re-entering slow-start indicated by p == 0, the minimum
         resolution value of p is now returned instead;
       * a bug in ccid3_hc_rx_getsockopt is fixed: 1/0 was mapped into ~0U.
      Signed-off-by: default avatarGerrit Renker <gerrit@erg.abdn.ac.uk>
      792e6d33
    • Gerrit Renker's avatar
      dccp ccid-3: remove dead states · 80763dfb
      Gerrit Renker authored
      This patch is thanks to an investigation by Leandro Sales de Melo and his
      colleagues. They worked out two state diagrams which highlight the fact that
      the xxx_TERM states in CCID-3/4 are in fact not necessary.
      
      And this can be confirmed by in turn looking at the code: the xxx_TERM states
      are only ever set in ccid3_hc_{rx,tx}_exit(): when CCID-3 sets the state
      to xxx_TERM, it is at a time where no more processing should be going on,
      hence it is not necessary to introduce a dedicated exit state - this is already
      implied by unloading the CCID.
      Signed-off-by: default avatarGerrit Renker <gerrit@erg.abdn.ac.uk>
      80763dfb
    • Gerrit Renker's avatar
      dccp: Replace magic CCID-specific numbers by symbolic constants · a18213d1
      Gerrit Renker authored
      The constants DCCPO_{MIN,MAX}_CCID_SPECIFIC are nowhere used in the code, but
      instead for the CCID-specific options numbers are used.
      
      This patch unifies the use of CCID-specific option numbers, by adding symbolic
      names reflecting the definitions in RFC 4340, 10.3.
      Signed-off-by: default avatarGerrit Renker <gerrit@erg.abdn.ac.uk>
      a18213d1
    • Gerrit Renker's avatar
      dccp: Add packet type information to CCID-specific option parsing · 4874c131
      Gerrit Renker authored
      This
       1. adds packet type information to ccid_hc_{rx,tx}_parse_options(). This is
          necessary, since table 3 in RFC 4340, 5.8 leaves it to the CCIDs to state
          which options may (not) appear on what packet type.
      
       2. adds such a check for CCID-3's {Loss Event, Receive} Rate as specified in
          RFC 4340 8.3 ("Receive Rate options MUST NOT be sent on DCCP-Data packets")
          and 8.5 ("Loss Event Rate options MUST NOT be sent on DCCP-Data packets").
      
       3. removes an unused argument `idx' from ccid_hc_{rx,tx}_parse_options(). This
          is also no longer necessary, since the CCID-specific option-parsing routines
          are passed every single parameter of the type-length-value option encoding.
      Signed-off-by: default avatarGerrit Renker <gerrit@erg.abdn.ac.uk>
      4874c131
  2. 19 Sep, 2010 6 commits
  3. 17 Sep, 2010 18 commits
  4. 16 Sep, 2010 11 commits