On 04/12/2011 09:32 AM, Stefan Berger wrote:
+
+static u32 add_tpm_device(void **tpm_addr, void **tcpa_addr)
+{
+ struct tcpa_descriptor_rev2 *tcpa;
+
+ *tpm_addr = NULL;
+ *tcpa_addr = NULL;
+
+ if (has_working_tpm()) {
+ u32 laml = 64 * 1024;
Kevin,
the above line prepares 64 kb to be allocated for an ACPI table. It
works fine if booting a VM from an image. However, when passing the
kernel, initrd and command line parameters to Qemu directly (-kernel,
-append, ..), the 64kb above seem to be too much -- I see errors in the
Linux kernel's dmesg when Linux tries to access the ACPI tables.
Lowering the above to 48kb (happens to) makes it work. I am wondering
whether something is copying into the ACPI area or what else may be the
reason - do you know?
+ *tpm_addr = malloc_high(sizeof(AmlCode_TPM));
+
+ tcpa = malloc_high(sizeof(*tcpa) + laml);
+ if (!tcpa || !*tpm_addr) {
+ warn_noalloc();
+ return 1;
+ }
Regards,
Stefan
_______________________________________________
SeaBIOS mailing list
[email protected]
http://www.seabios.org/mailman/listinfo/seabios