Index: llvm/trunk/lib/Target/WebAssembly/WebAssemblyISelLowering.h =================================================================== --- llvm/trunk/lib/Target/WebAssembly/WebAssemblyISelLowering.h +++ llvm/trunk/lib/Target/WebAssembly/WebAssemblyISelLowering.h @@ -89,6 +89,10 @@ void ReplaceNodeResults(SDNode *N, SmallVectorImpl &Results, SelectionDAG &DAG) const override; + const char *getClearCacheBuiltinName() const override { + report_fatal_error("llvm.clear_cache is not supported on wasm"); + } + // Custom lowering hooks. SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const override; SDValue LowerFrameIndex(SDValue Op, SelectionDAG &DAG) const; Index: llvm/trunk/test/CodeGen/WebAssembly/clear-cache.ll =================================================================== --- llvm/trunk/test/CodeGen/WebAssembly/clear-cache.ll +++ llvm/trunk/test/CodeGen/WebAssembly/clear-cache.ll @@ -0,0 +1,13 @@ +; RUN: not llc < %s -asm-verbose=false 2>&1 | FileCheck %s + +target datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128" +target triple = "wasm32-unknown-unknown" + +; CHECK: LLVM ERROR: llvm.clear_cache is not supported on wasm +define void @clear_cache(i8* %begin, i8* %end) { +entry: + call void @llvm.clear_cache(i8* %begin, i8* %end) + ret void +} + +declare void @llvm.clear_cache(i8*, i8*)