Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 268040
b: refs/heads/master
c: 5e6f4d0
h: refs/heads/master
v: v3
  • Loading branch information
K. Y. Srinivasan authored and Greg Kroah-Hartman committed Aug 29, 2011
1 parent dc8fd12 commit 27e77c7
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 30 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a5b2359b05925ade4b9a645b9e45a6c4b8fb1ff0
refs/heads/master: 5e6f4d069f102b6a49433943cf37e3bdc52e2314
18 changes: 2 additions & 16 deletions trunk/drivers/staging/hv/hyperv_storage.h
Original file line number Diff line number Diff line change
Expand Up @@ -264,8 +264,6 @@ struct storvsc_major_info {
struct storvsc_device {
struct hv_device *device;

/* 0 indicates the device is being destroyed */
atomic_t ref_count;
bool destroy;
bool drain_notify;
atomic_t num_outstanding_req;
Expand All @@ -287,32 +285,20 @@ struct storvsc_device {
};


/* Get the stordevice object iff exists and its refcount > 1 */
static inline struct storvsc_device *get_out_stor_device(
struct hv_device *device)
{
struct storvsc_device *stor_device;

stor_device = (struct storvsc_device *)device->ext;
if (stor_device && (atomic_read(&stor_device->ref_count) > 1) &&
!stor_device->destroy)
atomic_inc(&stor_device->ref_count);
else

if (stor_device && stor_device->destroy)
stor_device = NULL;

return stor_device;
}


static inline void put_stor_device(struct hv_device *device)
{
struct storvsc_device *stor_device;

stor_device = (struct storvsc_device *)device->ext;

atomic_dec(&stor_device->ref_count);
}

static inline void storvsc_wait_to_drain(struct storvsc_device *dev)
{
dev->drain_notify = true;
Expand Down
33 changes: 21 additions & 12 deletions trunk/drivers/staging/hv/storvsc.c
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,6 @@ static inline struct storvsc_device *alloc_stor_device(struct hv_device *device)
if (!stor_device)
return NULL;

/* Set to 2 to allow both inbound and outbound traffics */
/* (ie get_out_stor_device() and get_in_stor_device()) to proceed. */
atomic_set(&stor_device->ref_count, 2);
stor_device->destroy = false;
init_waitqueue_head(&stor_device->waiting_to_drain);
stor_device->device = device;
Expand All @@ -52,19 +49,31 @@ static inline struct storvsc_device *alloc_stor_device(struct hv_device *device)
}


/* Get the stordevice object iff exists and its refcount > 0 */
static inline struct storvsc_device *get_in_stor_device(
struct hv_device *device)
{
struct storvsc_device *stor_device;
unsigned long flags;

spin_lock_irqsave(&device->channel->inbound_lock, flags);
stor_device = (struct storvsc_device *)device->ext;
if (stor_device && atomic_read(&stor_device->ref_count))
atomic_inc(&stor_device->ref_count);
else

if (!stor_device)
goto get_in_err;

/*
* If the device is being destroyed; allow incoming
* traffic only to cleanup outstanding requests.
*/

if (stor_device->destroy &&
(atomic_read(&stor_device->num_outstanding_req) == 0))
stor_device = NULL;

get_in_err:
spin_unlock_irqrestore(&device->channel->inbound_lock, flags);
return stor_device;

}

static int storvsc_channel_init(struct hv_device *device)
Expand Down Expand Up @@ -190,7 +199,6 @@ static int storvsc_channel_init(struct hv_device *device)


cleanup:
put_stor_device(device);
return ret;
}

Expand Down Expand Up @@ -303,7 +311,6 @@ static void storvsc_on_channel_callback(void *context)
}
} while (1);

put_stor_device(device);
return;
}

Expand Down Expand Up @@ -371,7 +378,6 @@ int storvsc_dev_remove(struct hv_device *device)
unsigned long flags;

stor_device = (struct storvsc_device *)device->ext;
atomic_dec(&stor_device->ref_count);

spin_lock_irqsave(&device->channel->inbound_lock, flags);
stor_device->destroy = true;
Expand All @@ -388,9 +394,13 @@ int storvsc_dev_remove(struct hv_device *device)
/*
* Since we have already drained, we don't need to busy wait
* as was done in final_release_stor_device()
* Note that we cannot set the ext pointer to NULL until
* we have drained - to drain the outgoing packets, we need to
* allow incoming packets.
*/
atomic_set(&stor_device->ref_count, 0);
spin_lock_irqsave(&device->channel->inbound_lock, flags);
device->ext = NULL;
spin_unlock_irqrestore(&device->channel->inbound_lock, flags);

/* Close the channel */
vmbus_close(device->channel);
Expand Down Expand Up @@ -448,7 +458,6 @@ int storvsc_do_io(struct hv_device *device,

atomic_inc(&stor_device->num_outstanding_req);

put_stor_device(device);
return ret;
}

Expand Down
1 change: 0 additions & 1 deletion trunk/drivers/staging/hv/storvsc_drv.c
Original file line number Diff line number Diff line change
Expand Up @@ -378,7 +378,6 @@ static int storvsc_host_reset(struct hv_device *device)
*/

cleanup:
put_stor_device(device);
return ret;
}

Expand Down

0 comments on commit 27e77c7

Please sign in to comment.