tpm: lookup cancel path under tpm device class
Since Linux commit 313d21eeab9282e, tpm devices have their own device
class "tpm" and the cancel path must be looked up under
/sys/class/tpm/ instead of /sys/class/misc/.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Reviewed-by: Stefan Berger <stefanb@linux.vnet.ibm.com>
Signed-off-by: Stefan Berger <stefanb@linux.vnet.ibm.com>
(cherry picked from commit 05b71fb207
)
[LY: BSC#1079405]
Signed-off-by: Liang Yan <lyan@suse.com>
This commit is contained in:
committed by
Bruce Rogers
parent
d78adee7e2
commit
3b9aa00611
@@ -369,7 +369,8 @@ static TPMVersion tpm_passthrough_get_tpm_version(TPMBackend *tb)
|
||||
* Unless path or file descriptor set has been provided by user,
|
||||
* determine the sysfs cancel file following kernel documentation
|
||||
* in Documentation/ABI/stable/sysfs-class-tpm.
|
||||
* From /dev/tpm0 create /sys/class/misc/tpm0/device/cancel
|
||||
* From /dev/tpm0 create /sys/class/tpm/tpm0/device/cancel
|
||||
* before 4.0: /sys/class/misc/tpm0/device/cancel
|
||||
*/
|
||||
static int tpm_passthrough_open_sysfs_cancel(TPMBackend *tb)
|
||||
{
|
||||
@@ -390,9 +391,14 @@ static int tpm_passthrough_open_sysfs_cancel(TPMBackend *tb)
|
||||
dev = strrchr(tpm_pt->tpm_dev, '/');
|
||||
if (dev) {
|
||||
dev++;
|
||||
if (snprintf(path, sizeof(path), "/sys/class/misc/%s/device/cancel",
|
||||
if (snprintf(path, sizeof(path), "/sys/class/tpm/%s/device/cancel",
|
||||
dev) < sizeof(path)) {
|
||||
fd = qemu_open(path, O_WRONLY);
|
||||
if (fd < 0) {
|
||||
if (snprintf(path, sizeof(path), "/sys/class/misc/%s/device/cancel", dev) < sizeof(path)) {
|
||||
fd = qemu_open(path, O_WRONLY);
|
||||
}
|
||||
}
|
||||
if (fd >= 0) {
|
||||
tb->cancel_path = g_strdup(path);
|
||||
} else {
|
||||
|
Reference in New Issue
Block a user