]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
LoongArch: Define macro CLEAR_INSN_CACHE.
authorLulu Cheng <chenglulu@loongson.cn>
Mon, 23 Oct 2023 01:07:32 +0000 (09:07 +0800)
committerLulu Cheng <chenglulu@loongson.cn>
Mon, 23 Oct 2023 01:26:43 +0000 (09:26 +0800)
LoongArch's microstructure ensures cache consistency by hardware.
Due to out-of-order execution, "ibar" is required to ensure the visibility of the
store (invalidated icache) executed by this CPU before "ibar" (to the instance).
"ibar" will not invalidate the icache, so the start and end parameters are not Affect
"ibar" performance.

gcc/ChangeLog:

* config/loongarch/loongarch.h (CLEAR_INSN_CACHE): New definition.

gcc/config/loongarch/loongarch.h

index da3ec2add9ad6d967a3803e67e376dc3d669c10b..c72fc515aebb6a6ce5a43f06877745074a3bab80 100644 (file)
@@ -1231,3 +1231,8 @@ struct GTY (()) machine_function
   (TARGET_HARD_FLOAT_ABI ? (TARGET_DOUBLE_FLOAT_ABI ? 8 : 4) : 0)
 
 #define FUNCTION_VALUE_REGNO_P(N) ((N) == GP_RETURN || (N) == FP_RETURN)
+
+/* LoongArch maintains ICache/DCache coherency by hardware,
+   we just need "ibar" to avoid instruction hazard here.  */
+#undef  CLEAR_INSN_CACHE
+#define CLEAR_INSN_CACHE(beg, end) __builtin_loongarch_ibar (0)