lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20260107134710.15363555@canb.auug.org.au>
Date: Wed, 7 Jan 2026 13:47:10 +1100
From: Stephen Rothwell <sfr@...b.auug.org.au>
To: Thomas Gleixner <tglx@...utronix.de>, Ingo Molnar <mingo@...nel.org>,
 "H. Peter Anvin" <hpa@...or.com>, Peter Zijlstra <peterz@...radead.org>
Cc: "Borislav Petkov (AMD)" <bp@...en8.de>, Linux Kernel Mailing List
 <linux-kernel@...r.kernel.org>, Linux Next Mailing List
 <linux-next@...r.kernel.org>
Subject: linux-next: build failure after merge of the tip tree

Hi all,

After merging the tip tree, today's linux-next build (x86_64 allmodconfig)
failed like this:

In file included from arch/x86/coco/sev/svsm.c:8:
arch/x86/include/asm/sev.h:393:9: error: unknown type name 'pte_t'
  393 |         pte_t *kpte;
      |         ^~~~~
arch/x86/include/asm/sev.h:404:9: error: unknown type name 'pgprot_t'
  404 |         pgprot_t new_pgprot;
      |         ^~~~~~~~
arch/x86/include/asm/sev.h:464:44: error: unknown type name 'pgd_t'; did you mean 'pid_t'?
  464 | extern int __init sev_es_efi_map_ghcbs_cas(pgd_t *pgd);
      |                                            ^~~~~
      |                                            pid_t
arch/x86/include/asm/sev.h:521:23: error: unknown type name 'pte_t'
  521 | void set_pte_enc_mask(pte_t *kpte, unsigned long pfn, pgprot_t new_prot);
      |                       ^~~~~
arch/x86/include/asm/sev.h:521:55: error: unknown type name 'pgprot_t'
  521 | void set_pte_enc_mask(pte_t *kpte, unsigned long pfn, pgprot_t new_prot);
      |                                                       ^~~~~~~~
arch/x86/include/asm/sev.h:655:45: error: 'enum pg_level' declared inside parameter list will not be visible outside of this definition or declaration [-Werror]
  655 | int rmp_make_private(u64 pfn, u64 gpa, enum pg_level level, u32 asid, bool immutable);
      |                                             ^~~~~~~~
arch/x86/include/asm/sev.h:656:35: error: 'enum pg_level' declared inside parameter list will not be visible outside of this definition or declaration [-Werror]
  656 | int rmp_make_shared(u64 pfn, enum pg_level level);
      |                                   ^~~~~~~~
In file included from arch/x86/coco/sev/svsm.c:10:
arch/x86/coco/sev/internal.h:56:46: error: unknown type name 'runtime_data'
   56 | DECLARE_PER_CPU(struct sev_es_runtime_data*, runtime_data);
      |                                              ^~~~~~~~~~~~
arch/x86/coco/sev/internal.h:57:44: error: unknown type name 'sev_vmsa'
   57 | DECLARE_PER_CPU(struct sev_es_save_area *, sev_vmsa);
      |                                            ^~~~~~~~
arch/x86/coco/sev/internal.h:62:35: error: unknown type name 'svsm_caa'
   62 | DECLARE_PER_CPU(struct svsm_ca *, svsm_caa);
      |                                   ^~~~~~~~
arch/x86/coco/sev/internal.h:63:22: error: unknown type name 'svsm_caa_pa'
   63 | DECLARE_PER_CPU(u64, svsm_caa_pa);
      |                      ^~~~~~~~~~~
arch/x86/coco/sev/internal.h: In function 'sev_es_rd_ghcb_msr':
arch/x86/coco/sev/internal.h:75:16: error: implicit declaration of function 'native_rdmsrq' [-Wimplicit-function-declaration]
   75 |         return native_rdmsrq(MSR_AMD64_SEV_ES_GHCB);
      |                ^~~~~~~~~~~~~
arch/x86/coco/sev/internal.h:75:30: error: 'MSR_AMD64_SEV_ES_GHCB' undeclared (first use in this function)
   75 |         return native_rdmsrq(MSR_AMD64_SEV_ES_GHCB);
      |                              ^~~~~~~~~~~~~~~~~~~~~
arch/x86/coco/sev/internal.h:75:30: note: each undeclared identifier is reported only once for each function it appears in
arch/x86/coco/sev/internal.h: In function 'sev_es_wr_ghcb_msr':
arch/x86/coco/sev/internal.h:85:9: error: implicit declaration of function 'native_wrmsr' [-Wimplicit-function-declaration]
   85 |         native_wrmsr(MSR_AMD64_SEV_ES_GHCB, low, high);
      |         ^~~~~~~~~~~~
arch/x86/coco/sev/internal.h:85:22: error: 'MSR_AMD64_SEV_ES_GHCB' undeclared (first use in this function)
   85 |         native_wrmsr(MSR_AMD64_SEV_ES_GHCB, low, high);
      |                      ^~~~~~~~~~~~~~~~~~~~~
arch/x86/coco/sev/internal.h: In function 'svsm_get_caa':
arch/x86/coco/sev/internal.h:97:24: error: implicit declaration of function 'this_cpu_read' [-Wimplicit-function-declaration]
   97 |                 return this_cpu_read(svsm_caa);
      |                        ^~~~~~~~~~~~~
arch/x86/coco/sev/internal.h:97:38: error: 'svsm_caa' undeclared (first use in this function); did you mean 'svsm_ca'?
   97 |                 return this_cpu_read(svsm_caa);
      |                                      ^~~~~~~~
      |                                      svsm_ca
arch/x86/coco/sev/internal.h: In function 'svsm_get_caa_pa':
arch/x86/coco/sev/internal.h:105:38: error: 'svsm_caa_pa' undeclared (first use in this function); did you mean 'svsm_get_caa_pa'?
  105 |                 return this_cpu_read(svsm_caa_pa);
      |                                      ^~~~~~~~~~~
      |                                      svsm_get_caa_pa
arch/x86/coco/sev/svsm.c: At top level:
arch/x86/coco/sev/svsm.c:24:22: error: expected '=', ',', ';', 'asm' or '__attribute__' before '__ro_after_init'
   24 | u64 boot_svsm_caa_pa __ro_after_init;
      |                      ^~~~~~~~~~~~~~~
arch/x86/coco/sev/svsm.c:27:34: error: unknown type name 'svsm_caa'
   27 | DEFINE_PER_CPU(struct svsm_ca *, svsm_caa);
      |                                  ^~~~~~~~
arch/x86/coco/sev/svsm.c:28:21: error: unknown type name 'svsm_caa_pa'
   28 | DEFINE_PER_CPU(u64, svsm_caa_pa);
      |                     ^~~~~~~~~~~
arch/x86/coco/sev/svsm.c: In function 'svsm_perform_call_protocol':
arch/x86/coco/sev/svsm.c:75:17: error: implicit declaration of function 'native_local_irq_save' [-Wimplicit-function-declaration]
   75 |         flags = native_local_irq_save();
      |                 ^~~~~~~~~~~~~~~~~~~~~
arch/x86/coco/sev/svsm.c:92:9: error: implicit declaration of function 'native_local_irq_restore' [-Wimplicit-function-declaration]
   92 |         native_local_irq_restore(flags);
      |         ^~~~~~~~~~~~~~~~~~~~~~~~
arch/x86/coco/sev/svsm.c: In function 'snp_issue_svsm_attest_req':
arch/x86/coco/sev/svsm.c:280:9: error: implicit declaration of function 'local_irq_save' [-Wimplicit-function-declaration]
  280 |         local_irq_save(flags);
      |         ^~~~~~~~~~~~~~
arch/x86/coco/sev/svsm.c:300:9: error: implicit declaration of function 'local_irq_restore' [-Wimplicit-function-declaration]
  300 |         local_irq_restore(flags);
      |         ^~~~~~~~~~~~~~~~~
In file included from <command-line>:
arch/x86/coco/sev/svsm.c: At top level:
arch/x86/include/asm/linkage.h:151:60: error: '__pi_boot_svsm_caa_pa' aliased to undefined symbol 'boot_svsm_caa_pa'
  151 | #define SYM_PIC_ALIAS(sym)      extern typeof(sym) __PASTE(__pi_, sym) __alias(sym)
      |                                                            ^~~~~
include/linux/compiler_types.h:15:24: note: in definition of macro '___PASTE'
   15 | #define ___PASTE(a, b) a##b
      |                        ^
arch/x86/include/asm/linkage.h:151:52: note: in expansion of macro '__PASTE'
  151 | #define SYM_PIC_ALIAS(sym)      extern typeof(sym) __PASTE(__pi_, sym) __alias(sym)
      |                                                    ^~~~~~~
arch/x86/coco/sev/svsm.c:25:1: note: in expansion of macro 'SYM_PIC_ALIAS'
   25 | SYM_PIC_ALIAS(boot_svsm_caa_pa);
      | ^~~~~~~~~~~~~
arch/x86/coco/sev/internal.h: In function 'svsm_get_caa':
arch/x86/coco/sev/internal.h:100:1: error: control reaches end of non-void function [-Werror=return-type]
  100 | }
      | ^
arch/x86/coco/sev/internal.h: In function 'svsm_get_caa_pa':
arch/x86/coco/sev/internal.h:108:1: error: control reaches end of non-void function [-Werror=return-type]
  108 | }
      | ^
cc1: all warnings being treated as errors

Caused by commit

  e21279b73ef6 ("x86/sev: Carve out the SVSM code into a separate compilation unit")

Clearly, arch/x86/include/asm/sev.h and arch/x86/coco/sev/internal.h
assume some header files are included before them that are now missing
from arch/x86/coco/sev/svsm.c but should probably be explicitly
included in these headers files.  I realise that these dependencies may
have been exposed by other changes in linux-next.

I have used the tip tree from next-20260106 for today.

-- 
Cheers,
Stephen Rothwell

Content of type "application/pgp-signature" skipped

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ