1. 26 4月, 2007 2 次提交
  2. 19 4月, 2007 1 次提交
    • V
      [SCTP]: Do not interleave non-fragments when in partial delivery · d0cf0d99
      Vlad Yasevich 提交于
      The way partial delivery is currently implemnted, it is possible to
      intereleave a message (either from another steram, or unordered) that
      is not part of partial delivery process.  The only way to this is for
      a message to not be a fragment and be 'in order' or unorderd for a
      given stream.  This will result in bypassing the reassembly/ordering
      queues where things live duing partial delivery, and the
      message will be delivered to the socket in the middle of partial delivery.
      
      This is a two-fold problem, in that:
      1.  the app now must check the stream-id and flags which it may not
      be doing.
      2.  this clearing partial delivery state from the association and results
      in ulp hanging.
      
      This patch is a band-aid over a much bigger problem in that we
      don't do stream interleave.
      Signed-off-by: NVlad Yasevich <vladislav.yasevich@hp.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      d0cf0d99
  3. 20 3月, 2007 1 次提交
  4. 11 2月, 2007 1 次提交
  5. 12 10月, 2006 1 次提交
  6. 06 5月, 2006 1 次提交
    • V
      [SCTP]: Prevent possible infinite recursion with multiple bundled DATA. · 672e7cca
      Vladislav Yasevich 提交于
      There is a rare situation that causes lksctp to go into infinite recursion
      and crash the system.  The trigger is a packet that contains at least the
      first two DATA fragments of a message bundled together. The recursion is
      triggered when the user data buffer is smaller that the full data message.
      The problem is that we clone the skb for every fragment in the message.
      When reassembling the full message, we try to link skbs from the "first
      fragment" clone using the frag_list. However, since the frag_list is shared
      between two clones in this rare situation, we end up setting the frag_list
      pointer of the second fragment to point to itself.  This causes
      sctp_skb_pull() to potentially recurse indefinitely.
      
      Proposed solution is to make a copy of the skb when attempting to link
      things using frag_list.
      Signed-off-by: NVladislav Yasevich <vladsilav.yasevich@hp.com>
      Signed-off-by: NSridhar Samudrala <sri@us.ibm.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      672e7cca
  7. 09 10月, 2005 1 次提交
  8. 30 8月, 2005 1 次提交
  9. 12 7月, 2005 1 次提交
  10. 17 4月, 2005 1 次提交
    • L
      Linux-2.6.12-rc2 · 1da177e4
      Linus Torvalds 提交于
      Initial git repository build. I'm not bothering with the full history,
      even though we have it. We can create a separate "historical" git
      archive of that later if we want to, and in the meantime it's about
      3.2GB when imported into git - space that would just make the early
      git days unnecessarily complicated, when we don't have a lot of good
      infrastructure for it.
      
      Let it rip!
      1da177e4