summaryrefslogtreecommitdiff
path: root/0100-PGO-kernel-Add-fkernel-pgo-option-to-support-PGO-ker.patch
diff options
context:
space:
mode:
Diffstat (limited to '0100-PGO-kernel-Add-fkernel-pgo-option-to-support-PGO-ker.patch')
-rw-r--r--0100-PGO-kernel-Add-fkernel-pgo-option-to-support-PGO-ker.patch46
1 files changed, 46 insertions, 0 deletions
diff --git a/0100-PGO-kernel-Add-fkernel-pgo-option-to-support-PGO-ker.patch b/0100-PGO-kernel-Add-fkernel-pgo-option-to-support-PGO-ker.patch
new file mode 100644
index 0000000..a77c072
--- /dev/null
+++ b/0100-PGO-kernel-Add-fkernel-pgo-option-to-support-PGO-ker.patch
@@ -0,0 +1,46 @@
+From 90d3ef0637c66045eeab78ccf04e9ff51b9b451a Mon Sep 17 00:00:00 2001
+From: xiongzhou4 <xiongzhou4@huawei.com>
+Date: Thu, 1 Jun 2023 09:28:27 +0800
+Subject: [PATCH 5/5] [PGO kernel] Add fkernel-pgo option to support PGO kernel
+ compilation.
+
+If specified, disable TLS setting of instrumentation variables in
+gcc/tree-profile.c, as kernel does not support TLS.
+---
+ gcc/common.opt | 4 ++++
+ gcc/tree-profile.c | 4 +++-
+ 2 files changed, 7 insertions(+), 1 deletion(-)
+
+diff --git a/gcc/common.opt b/gcc/common.opt
+index 238c97db8..6f0ed7cea 100644
+--- a/gcc/common.opt
++++ b/gcc/common.opt
+@@ -2302,6 +2302,10 @@ fprofile-generate=
+ Common Joined RejectNegative
+ Enable common options for generating profile info for profile feedback directed optimizations, and set -fprofile-dir=.
+
++fkernel-pgo
++Common Report Var(flag_kernel_pgo) Optimization Init(0)
++Disable TLS setting of instrumentation variables to support PGO kernel compilation in -fprofile-generate, as kernel does not support TLS.
++
+ fprofile-partial-training
+ Common Report Var(flag_profile_partial_training) Optimization
+ Do not assume that functions never executed during the train run are cold.
+diff --git a/gcc/tree-profile.c b/gcc/tree-profile.c
+index 6c0838261..924817472 100644
+--- a/gcc/tree-profile.c
++++ b/gcc/tree-profile.c
+@@ -105,7 +105,9 @@ init_ic_make_global_vars (void)
+ DECL_ARTIFICIAL (ic_tuple_var) = 1;
+ DECL_INITIAL (ic_tuple_var) = NULL;
+ DECL_EXTERNAL (ic_tuple_var) = 1;
+- if (targetm.have_tls)
++ /* Disable TLS setting when compiling kernel in -fprofile-generate,
++ as kernel does not support TLS. */
++ if (targetm.have_tls && !flag_kernel_pgo)
+ set_decl_tls_model (ic_tuple_var, decl_default_tls_model (ic_tuple_var));
+ }
+
+--
+2.33.0
+