)]}'
{
  "commit": "da24e906cbfc08171d24a2b7cf66fad565fdd121",
  "tree": "4ce4464bb570ed4ff67298b724ef676000e4b08a",
  "parents": [
    "f24fd89ab5148d00f58aaf1d8999e9966fc7215c"
  ],
  "author": {
    "name": "Haiyang Zhang",
    "email": "haiyangz@microsoft.com",
    "time": "Mon Mar 19 17:27:06 2012 -0400"
  },
  "committer": {
    "name": "David S. Miller",
    "email": "davem@davemloft.net",
    "time": "Mon Mar 19 17:27:06 2012 -0400"
  },
  "message": "net/hyperv: Fix the code handling tx busy\n\nInstead of dropping the packet, we keep the skb buffer, and return\nNETDEV_TX_BUSY to let upper layer retry send. This will not cause\nendless loop, because the host is taking data away from ring buffer,\nand we have called the stop_queue before returning NETDEV_TX_BUSY.\n\nThe stop_queue was called in the function netvsc_send() in file \nnetvsc.c, then it returns to rndis_filter_send(), which returns to\nnetvsc_start_xmit() in file netvsc_drv.c. So the NETDEV_TX_BUSY is\nindeed returned AFTER queue is stopped.\n\nSigned-off-by: Haiyang Zhang \u003chaiyangz@microsoft.com\u003e\nReviewed-by: K. Y. Srinivasan \u003ckys@microsoft.com\u003e\nAcked-by: Eric Dumazet \u003ceric.dumazet@gmail.com\u003e\nSigned-off-by: David S. Miller \u003cdavem@davemloft.net\u003e\n",
  "tree_diff": [
    {
      "type": "modify",
      "old_id": "2517d209d602f7d715f6a8a7a8a01db9dc3ccc88",
      "old_mode": 33188,
      "old_path": "drivers/net/hyperv/netvsc_drv.c",
      "new_id": "dd294783b5c5b77c3d48ecd14067921d9e90d4bb",
      "new_mode": 33188,
      "new_path": "drivers/net/hyperv/netvsc_drv.c"
    }
  ]
}
