1. 01 9月, 2012 1 次提交
  2. 12 7月, 2012 1 次提交
  3. 16 6月, 2012 1 次提交
    • D
      ipv6: Handle PMTU in ICMP error handlers. · 81aded24
      David S. Miller 提交于
      One tricky issue on the ipv6 side vs. ipv4 is that the ICMP callouts
      to handle the error pass the 32-bit info cookie in network byte order
      whereas ipv4 passes it around in host byte order.
      
      Like the ipv4 side, we have two helper functions.  One for when we
      have a socket context and one for when we do not.
      
      ip6ip6 tunnels are not handled here, because they handle PMTU events
      by essentially relaying another ICMP packet-too-big message back to
      the original sender.
      
      This patch allows us to get rid of rt6_do_pmtu_disc().  It handles all
      kinds of situations that simply cannot happen when we do the PMTU
      update directly using a fully resolved route.
      
      In fact, the "plen == 128" check in ip6_rt_update_pmtu() can very
      likely be removed or changed into a BUG_ON() check.  We should never
      have a prefixed ipv6 route when we get there.
      
      Another piece of strange history here is that TCP and DCCP, unlike in
      ipv4, never invoke the update_pmtu() method from their ICMP error
      handlers.  This is incredibly astonishing since this is the context
      where we have the most accurate context in which to make a PMTU
      update, namely we have a fully connected socket and associated cached
      socket route.
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      81aded24
  4. 27 5月, 2012 1 次提交
  5. 16 5月, 2012 2 次提交
  6. 27 4月, 2011 1 次提交
  7. 23 4月, 2011 1 次提交
  8. 14 3月, 2011 2 次提交
  9. 11 12月, 2010 1 次提交
  10. 23 2月, 2010 1 次提交
  11. 26 11月, 2009 1 次提交
  12. 15 9月, 2009 1 次提交
  13. 23 6月, 2009 1 次提交
  14. 26 11月, 2008 2 次提交
  15. 30 10月, 2008 1 次提交
  16. 29 10月, 2008 1 次提交
  17. 06 8月, 2008 1 次提交
  18. 28 3月, 2008 1 次提交
  19. 13 2月, 2008 1 次提交
  20. 01 2月, 2008 3 次提交
  21. 29 1月, 2008 4 次提交
  22. 11 12月, 2007 1 次提交
  23. 31 10月, 2007 1 次提交
    • D
      [NET]: Fix incorrect sg_mark_end() calls. · 51c739d1
      David S. Miller 提交于
      This fixes scatterlist corruptions added by
      
      	commit 68e3f5dd
      	[CRYPTO] users: Fix up scatterlist conversion errors
      
      The issue is that the code calls sg_mark_end() which clobbers the
      sg_page() pointer of the final scatterlist entry.
      
      The first part fo the fix makes skb_to_sgvec() do __sg_mark_end().
      
      After considering all skb_to_sgvec() call sites the most correct
      solution is to call __sg_mark_end() in skb_to_sgvec() since that is
      what all of the callers would end up doing anyways.
      
      I suspect this might have fixed some problems in virtio_net which is
      the sole non-crypto user of skb_to_sgvec().
      
      Other similar sg_mark_end() cases were converted over to
      __sg_mark_end() as well.
      
      Arguably sg_mark_end() is a poorly named function because it doesn't
      just "mark", it clears out the page pointer as a side effect, which is
      what led to these bugs in the first place.
      
      The one remaining plain sg_mark_end() call is in scsi_alloc_sgtable()
      and arguably it could be converted to __sg_mark_end() if only so that
      we can delete this confusing interface from linux/scatterlist.h
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      51c739d1
  24. 27 10月, 2007 2 次提交
  25. 26 10月, 2007 1 次提交
  26. 22 10月, 2007 1 次提交
  27. 18 10月, 2007 1 次提交
  28. 11 10月, 2007 4 次提交