diff options
Diffstat (limited to 'drivers/char/tpm')
-rw-r--r-- | drivers/char/tpm/tpm.c | 7 | ||||
-rw-r--r-- | drivers/char/tpm/tpm.h | 2 |
2 files changed, 4 insertions, 5 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); |
diff --git a/drivers/char/tpm/tpm.h b/drivers/char/tpm/tpm.h index e885148b4cfb..2756cab9aee3 100644 --- a/drivers/char/tpm/tpm.h +++ b/drivers/char/tpm/tpm.h | |||
@@ -90,7 +90,7 @@ struct tpm_chip { | |||
90 | struct device *dev; /* Device stuff */ | 90 | struct device *dev; /* Device stuff */ |
91 | 91 | ||
92 | int dev_num; /* /dev/tpm# */ | 92 | int dev_num; /* /dev/tpm# */ |
93 | int num_opens; /* only one allowed */ | 93 | unsigned long is_open; /* only one allowed */ |
94 | int time_expired; | 94 | int time_expired; |
95 | 95 | ||
96 | /* Data passed to and from the tpm via the read/write calls */ | 96 | /* Data passed to and from the tpm via the read/write calls */ |