target/i386/sev: Use local variable for kvm_sev_launch_measure
The struct kvm_sev_launch_measure has a constant and small size, and therefore we can use a regular local variable for it instead of allocating and freeing heap memory for it. Signed-off-by: Dov Murik <dovmurik@linux.ibm.com> Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Message-Id: <20211011173026.2454294-3-dovmurik@linux.ibm.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
eb8257a261
commit
59e42d88b6
@ -729,7 +729,7 @@ sev_launch_get_measure(Notifier *notifier, void *unused)
|
|||||||
SevGuestState *sev = sev_guest;
|
SevGuestState *sev = sev_guest;
|
||||||
int ret, error;
|
int ret, error;
|
||||||
g_autofree guchar *data = NULL;
|
g_autofree guchar *data = NULL;
|
||||||
g_autofree struct kvm_sev_launch_measure *measurement = NULL;
|
struct kvm_sev_launch_measure measurement = {};
|
||||||
|
|
||||||
if (!sev_check_state(sev, SEV_STATE_LAUNCH_UPDATE)) {
|
if (!sev_check_state(sev, SEV_STATE_LAUNCH_UPDATE)) {
|
||||||
return;
|
return;
|
||||||
@ -743,23 +743,21 @@ sev_launch_get_measure(Notifier *notifier, void *unused)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
measurement = g_new0(struct kvm_sev_launch_measure, 1);
|
|
||||||
|
|
||||||
/* query the measurement blob length */
|
/* query the measurement blob length */
|
||||||
ret = sev_ioctl(sev->sev_fd, KVM_SEV_LAUNCH_MEASURE,
|
ret = sev_ioctl(sev->sev_fd, KVM_SEV_LAUNCH_MEASURE,
|
||||||
measurement, &error);
|
&measurement, &error);
|
||||||
if (!measurement->len) {
|
if (!measurement.len) {
|
||||||
error_report("%s: LAUNCH_MEASURE ret=%d fw_error=%d '%s'",
|
error_report("%s: LAUNCH_MEASURE ret=%d fw_error=%d '%s'",
|
||||||
__func__, ret, error, fw_error_to_str(errno));
|
__func__, ret, error, fw_error_to_str(errno));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
data = g_new0(guchar, measurement->len);
|
data = g_new0(guchar, measurement.len);
|
||||||
measurement->uaddr = (unsigned long)data;
|
measurement.uaddr = (unsigned long)data;
|
||||||
|
|
||||||
/* get the measurement blob */
|
/* get the measurement blob */
|
||||||
ret = sev_ioctl(sev->sev_fd, KVM_SEV_LAUNCH_MEASURE,
|
ret = sev_ioctl(sev->sev_fd, KVM_SEV_LAUNCH_MEASURE,
|
||||||
measurement, &error);
|
&measurement, &error);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
error_report("%s: LAUNCH_MEASURE ret=%d fw_error=%d '%s'",
|
error_report("%s: LAUNCH_MEASURE ret=%d fw_error=%d '%s'",
|
||||||
__func__, ret, error, fw_error_to_str(errno));
|
__func__, ret, error, fw_error_to_str(errno));
|
||||||
@ -769,7 +767,7 @@ sev_launch_get_measure(Notifier *notifier, void *unused)
|
|||||||
sev_set_guest_state(sev, SEV_STATE_LAUNCH_SECRET);
|
sev_set_guest_state(sev, SEV_STATE_LAUNCH_SECRET);
|
||||||
|
|
||||||
/* encode the measurement value and emit the event */
|
/* encode the measurement value and emit the event */
|
||||||
sev->measurement = g_base64_encode(data, measurement->len);
|
sev->measurement = g_base64_encode(data, measurement.len);
|
||||||
trace_kvm_sev_launch_measurement(sev->measurement);
|
trace_kvm_sev_launch_measurement(sev->measurement);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user