diff options
Diffstat (limited to 'drivers/char/tpm/tpm.c')
-rw-r--r-- | drivers/char/tpm/tpm.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/drivers/char/tpm/tpm.c b/drivers/char/tpm/tpm.c index ceba6082bd96..dfd4e7fc350b 100644 --- a/drivers/char/tpm/tpm.c +++ b/drivers/char/tpm/tpm.c | |||
@@ -978,20 +978,19 @@ int tpm_open(struct inode *inode, struct file *file) | |||
978 | goto err_out; | 978 | goto err_out; |
979 | } | 979 | } |
980 | 980 | ||
981 | if (chip->num_opens) { | 981 | if (test_and_set_bit(0, &chip->is_open)) { |
982 | dev_dbg(chip->dev, "Another process owns this TPM\n"); | 982 | dev_dbg(chip->dev, "Another process owns this TPM\n"); |
983 | rc = -EBUSY; | 983 | rc = -EBUSY; |
984 | goto err_out; | 984 | goto err_out; |
985 | } | 985 | } |
986 | 986 | ||
987 | chip->num_opens++; | ||
988 | get_device(chip->dev); | 987 | get_device(chip->dev); |
989 | 988 | ||
990 | spin_unlock(&driver_lock); | 989 | spin_unlock(&driver_lock); |
991 | 990 | ||
992 | chip->data_buffer = kmalloc(TPM_BUFSIZE * sizeof(u8), GFP_KERNEL); | 991 | chip->data_buffer = kmalloc(TPM_BUFSIZE * sizeof(u8), GFP_KERNEL); |
993 | if (chip->data_buffer == NULL) { | 992 | if (chip->data_buffer == NULL) { |
994 | chip->num_opens--; | 993 | clear_bit(0, &chip->is_open); |
995 | put_device(chip->dev); | 994 | put_device(chip->dev); |
996 | return -ENOMEM; | 995 | return -ENOMEM; |
997 | } | 996 | } |
@@ -1016,7 +1015,7 @@ int tpm_release(struct inode *inode, struct file *file) | |||
1016 | file->private_data = NULL; | 1015 | file->private_data = NULL; |
1017 | del_singleshot_timer_sync(&chip->user_read_timer); | 1016 | del_singleshot_timer_sync(&chip->user_read_timer); |
1018 | atomic_set(&chip->data_pending, 0); | 1017 | atomic_set(&chip->data_pending, 0); |
1019 | chip->num_opens--; | 1018 | clear_bit(0, &chip->is_open); |
1020 | put_device(chip->dev); | 1019 | put_device(chip->dev); |
1021 | kfree(chip->data_buffer); | 1020 | kfree(chip->data_buffer); |
1022 | spin_unlock(&driver_lock); | 1021 | spin_unlock(&driver_lock); |