From 30ee8465882d27499344062df05b05af99075c31 Mon Sep 17 00:00:00 2001 From: Divy Srivastava Date: Thu, 30 Mar 2023 22:00:19 +0530 Subject: perf(ext/websocket): special op for sending binary data frames (#18506) Easy perf win by avoiding deserializing `SendValue` through serde_v8. | name | avg msg/sec/core | | --- | --- | | deno_main | `127820.750000` | | deno_this | `140079.000000` | --- ext/websocket/01_websocket.js | 5 +---- ext/websocket/lib.rs | 15 +++++++++++++++ 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/ext/websocket/01_websocket.js b/ext/websocket/01_websocket.js index d483608d8..06eb08b60 100644 --- a/ext/websocket/01_websocket.js +++ b/ext/websocket/01_websocket.js @@ -301,10 +301,7 @@ class WebSocket extends EventTarget { const sendTypedArray = (ta) => { this[_bufferedAmount] += ta.byteLength; PromisePrototypeThen( - core.opAsync("op_ws_send", this[_rid], { - kind: "binary", - value: ta, - }), + core.opAsync("op_ws_send_binary", this[_rid], ta), () => { this[_bufferedAmount] -= ta.byteLength; }, diff --git a/ext/websocket/lib.rs b/ext/websocket/lib.rs index 8eac3e350..8d3cb20d2 100644 --- a/ext/websocket/lib.rs +++ b/ext/websocket/lib.rs @@ -402,6 +402,20 @@ pub enum SendValue { Ping, } +#[op] +pub async fn op_ws_send_binary( + state: Rc>, + rid: ResourceId, + data: ZeroCopyBuf, +) -> Result<(), AnyError> { + let resource = state + .borrow_mut() + .resource_table + .get::(rid)?; + resource.send(Message::Binary(data.to_vec())).await?; + Ok(()) +} + #[op] pub async fn op_ws_send_text( state: Rc>, @@ -518,6 +532,7 @@ deno_core::extension!(deno_websocket, op_ws_send, op_ws_close, op_ws_next_event, + op_ws_send_binary, op_ws_send_text, ], esm = [ "01_websocket.js", "02_websocketstream.js" ], -- cgit v1.2.3