Skip to content

Commit

Permalink
[WebNN EP] Fixed WebNN constant operand is detached issue (#20229)
Browse files Browse the repository at this point in the history
Wasm allows growing the memory size, this will cause all array buffers
reallocation. WebNN EP passes a wasm view to a WebNN constant directly
which would lead to the WebNN constant be treated as detached buffers in
JS side. Simply create a copy for WebNN constant to fix it.
  • Loading branch information
Honry authored Apr 11, 2024
1 parent e6ca360 commit ee603ee
Showing 1 changed file with 6 additions and 13 deletions.
19 changes: 6 additions & 13 deletions onnxruntime/core/providers/webnn/builders/model_builder.cc
Original file line number Diff line number Diff line change
Expand Up @@ -197,14 +197,10 @@ Status ModelBuilder::RegisterInitializers() {
default:
break;
}
#ifdef ENABLE_WEBASSEMBLY_THREADS
// Workaround for WebAssembly multi-threads enabled since WebNN API only accepts non-shared ArrayBufferView.
// https://www.w3.org/TR/webnn/#typedefdef-mlnamedarraybufferviews
operand = wnn_builder_.call<emscripten::val>("constant", desc, view.call<emscripten::val>("slice"));
#else
operand = wnn_builder_.call<emscripten::val>("constant", desc, view);
#endif

// Wasm memory grow will cause all array buffers reallocation, which will be treated as detached
// buffers in JS side. Simply create a copy to fix it.
operand = wnn_builder_.call<emscripten::val>("constant", desc, view.call<emscripten::val>("slice"));
} else {
// TODO: support other type.
return ORT_MAKE_STATUS(ONNXRUNTIME, INVALID_ARGUMENT,
Expand Down Expand Up @@ -360,13 +356,10 @@ Status ModelBuilder::AddOperandFromPersistMemoryBuffer(

desc.set("dimensions", emscripten::val::array(shape));
emscripten::val operand = emscripten::val::object();
#ifdef ENABLE_WEBASSEMBLY_THREADS
// Workaround for WebAssembly multi-threads enabled since WebNN API only accepts non-shared ArrayBufferView.
// https://www.w3.org/TR/webnn/#typedefdef-mlnamedarraybufferviews
// Wasm memory grow will cause all array buffers reallocation, which will be treated as detached
// buffers in JS side. Simply create a copy to fix it.
operand = wnn_builder_.call<emscripten::val>("constant", desc, view.call<emscripten::val>("slice"));
#else
operand = wnn_builder_.call<emscripten::val>("constant", desc, view);
#endif

AddOperand(name, operand);
mem_persist_buffers_.push_back(std::move(persist_buffer));
return Status::OK();
Expand Down

0 comments on commit ee603ee

Please sign in to comment.