@aztec/bb.js 3.0.0-nightly.20251124 → 3.0.0-nightly.20251125

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/build/amd64-linux/bb +0 -0
  2. package/build/amd64-linux/nodejs_module.node +0 -0
  3. package/build/amd64-macos/bb +0 -0
  4. package/build/amd64-macos/nodejs_module.node +0 -0
  5. package/build/arm64-linux/bb +0 -0
  6. package/build/arm64-linux/nodejs_module.node +0 -0
  7. package/build/arm64-macos/bb +0 -0
  8. package/build/arm64-macos/nodejs_module.node +0 -0
  9. package/dest/browser/barretenberg/index.js +7 -6
  10. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +1 -1
  11. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.js +1 -1
  12. package/dest/browser/bb_backends/index.d.ts +1 -1
  13. package/dest/browser/bb_backends/index.d.ts.map +1 -1
  14. package/dest/browser/bb_backends/index.js +2 -2
  15. package/dest/browser/bin/index.d.ts +3 -0
  16. package/dest/browser/bin/index.d.ts.map +1 -0
  17. package/dest/browser/bin/index.js +11 -0
  18. package/dest/node/barretenberg/index.js +7 -6
  19. package/dest/node/barretenberg/poseidon.bench.test.js +55 -13
  20. package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  21. package/dest/node/bb_backends/index.d.ts +1 -1
  22. package/dest/node/bb_backends/index.d.ts.map +1 -1
  23. package/dest/node/bb_backends/index.js +2 -2
  24. package/dest/node/bb_backends/node/index.d.ts.map +1 -1
  25. package/dest/node/bb_backends/node/index.js +6 -8
  26. package/dest/node/bb_backends/node/native_shm.d.ts +1 -2
  27. package/dest/node/bb_backends/node/native_shm.d.ts.map +1 -1
  28. package/dest/node/bb_backends/node/native_shm.js +9 -20
  29. package/dest/node/bb_backends/node/native_shm_async.d.ts +51 -0
  30. package/dest/node/bb_backends/node/native_shm_async.d.ts.map +1 -0
  31. package/dest/node/bb_backends/node/native_shm_async.js +234 -0
  32. package/dest/node/bin/index.d.ts +3 -0
  33. package/dest/node/bin/index.d.ts.map +1 -0
  34. package/dest/node/bin/index.js +11 -0
  35. package/dest/node-cjs/barretenberg/index.js +7 -6
  36. package/dest/node-cjs/barretenberg/poseidon.bench.test.js +55 -13
  37. package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  38. package/dest/node-cjs/bb_backends/index.d.ts +1 -1
  39. package/dest/node-cjs/bb_backends/index.d.ts.map +1 -1
  40. package/dest/node-cjs/bb_backends/index.js +2 -2
  41. package/dest/node-cjs/bb_backends/node/index.d.ts.map +1 -1
  42. package/dest/node-cjs/bb_backends/node/index.js +6 -8
  43. package/dest/node-cjs/bb_backends/node/native_shm.d.ts +1 -2
  44. package/dest/node-cjs/bb_backends/node/native_shm.d.ts.map +1 -1
  45. package/dest/node-cjs/bb_backends/node/native_shm.js +9 -20
  46. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts +51 -0
  47. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts.map +1 -0
  48. package/dest/node-cjs/bb_backends/node/native_shm_async.js +238 -0
  49. package/dest/node-cjs/bin/index.d.ts +3 -0
  50. package/dest/node-cjs/bin/index.d.ts.map +1 -0
  51. package/dest/node-cjs/bin/index.js +13 -0
  52. package/package.json +5 -3
  53. package/src/barretenberg/index.ts +5 -5
  54. package/src/barretenberg/poseidon.bench.test.ts +62 -12
  55. package/src/bb_backends/index.ts +1 -1
  56. package/src/bb_backends/node/index.ts +5 -17
  57. package/src/bb_backends/node/native_shm.ts +8 -21
  58. package/src/bb_backends/node/native_shm_async.ts +266 -0
  59. package/src/bin/index.ts +14 -0
  60. package/src/cbind/generated/api_types.ts +4271 -0
  61. package/src/cbind/generated/async.ts +717 -0
  62. package/src/cbind/generated/curve_constants.ts +53 -0
  63. package/src/cbind/generated/sync.ts +663 -0
  64. package/dest/browser/bb_backends/sync_to_async_adapter.d.ts +0 -15
  65. package/dest/browser/bb_backends/sync_to_async_adapter.d.ts.map +0 -1
  66. package/dest/browser/bb_backends/sync_to_async_adapter.js +0 -20
  67. package/dest/node/bb_backends/sync_to_async_adapter.d.ts +0 -15
  68. package/dest/node/bb_backends/sync_to_async_adapter.d.ts.map +0 -1
  69. package/dest/node/bb_backends/sync_to_async_adapter.js +0 -20
  70. package/dest/node-cjs/bb_backends/sync_to_async_adapter.d.ts +0 -15
  71. package/dest/node-cjs/bb_backends/sync_to_async_adapter.d.ts.map +0 -1
  72. package/dest/node-cjs/bb_backends/sync_to_async_adapter.js +0 -24
  73. package/src/bb_backends/sync_to_async_adapter.ts +0 -21
@@ -20,6 +20,7 @@ catch (err) {
20
20
  // Addon not built yet or not available
21
21
  addon = null;
22
22
  }
23
+ let instanceCounter = 0;
23
24
  /**
24
25
  * Synchronous shared memory backend that communicates with bb binary via shared memory.
25
26
  * Uses NAPI module to interface with shared memory IPC.
@@ -41,19 +42,16 @@ class BarretenbergNativeShmSyncBackend {
41
42
  * Create and initialize a shared memory backend.
42
43
  * @param bbBinaryPath Path to bb binary
43
44
  * @param threads Optional number of threads
44
- * @param maxClients Optional maximum concurrent clients (default: 1)
45
45
  */
46
- static async new(bbBinaryPath, threads, maxClients, logger) {
46
+ static async new(bbBinaryPath, threads, logger) {
47
47
  if (!addon || !addon.MsgpackClient) {
48
48
  throw new Error('Shared memory NAPI not available.');
49
49
  }
50
50
  // Create a unique shared memory name
51
- const shmName = `bb-${process.pid}`;
52
- // Default maxClients to 1 if not specified
53
- const clientCount = maxClients ?? 1;
51
+ const shmName = `bb-sync-${process.pid}-${instanceCounter++}`;
54
52
  // If threads not set use 1 thread. We're not expected to do long lived work on sync backends.
55
53
  const hwc = threads ? threads.toString() : '1';
56
- const env = { ...process.env, HARDWARE_CONCURRENCY: '1' };
54
+ const env = { ...process.env, HARDWARE_CONCURRENCY: hwc };
57
55
  // Set up file logging if logger is provided.
58
56
  // Direct file redirection bypasses Node event loop - logs are written even if process hangs.
59
57
  let logFd;
@@ -63,17 +61,8 @@ class BarretenbergNativeShmSyncBackend {
63
61
  logFd = (0, fs_1.openSync)(logPath, 'w');
64
62
  logger(`BB process logs redirected to: ${logPath}`);
65
63
  }
66
- // Spawn bb process with shared memory mode
67
- const args = [
68
- 'msgpack',
69
- 'run',
70
- '--input',
71
- `${shmName}.shm`,
72
- '--max-clients',
73
- clientCount.toString(),
74
- '--request-ring-size',
75
- `${1024 * 1024 * 2}`,
76
- ];
64
+ // Spawn bb process with shared memory mode (SPSC-only, no max-clients needed)
65
+ const args = ['msgpack', 'run', '--input', `${shmName}.shm`, '--request-ring-size', `${1024 * 1024 * 4}`];
77
66
  const bbProcess = (0, child_process_1.spawn)(bbBinaryPath, args, {
78
67
  stdio: ['ignore', logFd ?? 'ignore', logFd ?? 'ignore'],
79
68
  env,
@@ -115,8 +104,8 @@ class BarretenbergNativeShmSyncBackend {
115
104
  await new Promise(resolve => setTimeout(resolve, retryInterval));
116
105
  }
117
106
  try {
118
- // Create NAPI client with matching max_clients value
119
- client = new addon.MsgpackClient(shmName, clientCount);
107
+ // Create NAPI client (SPSC-only, no max_clients needed)
108
+ client = new addon.MsgpackClient(shmName);
120
109
  break; // Success!
121
110
  }
122
111
  catch (err) {
@@ -186,4 +175,4 @@ class BarretenbergNativeShmSyncBackend {
186
175
  }
187
176
  }
188
177
  exports.BarretenbergNativeShmSyncBackend = BarretenbergNativeShmSyncBackend;
189
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF0aXZlX3NobS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iYl9iYWNrZW5kcy9ub2RlL25hdGl2ZV9zaG0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQXVDO0FBQ3ZDLGlEQUFvRDtBQUNwRCwyQkFBeUM7QUFFekMsK0NBQWdFO0FBR2hFLHlCQUF5QjtBQUN6QixvREFBb0Q7QUFDcEQsTUFBTSxTQUFTLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUM7QUFDbkMsbUZBQW1GO0FBQ25GLElBQUksS0FBSyxHQUFRLElBQUksQ0FBQztBQUN0QixJQUFJLENBQUM7SUFDSCxJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQ2QsTUFBTSxPQUFPLEdBQUcsSUFBQSxzQkFBYSxFQUFDLElBQUEsNkJBQWUsR0FBRyxDQUFDLENBQUM7UUFDbEQsS0FBSyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM3QixDQUFDO0FBQ0gsQ0FBQztBQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDYix1Q0FBdUM7SUFDdkMsS0FBSyxHQUFHLElBQUksQ0FBQztBQUNmLENBQUM7QUFFRDs7Ozs7Ozs7OztHQVVHO0FBQ0gsTUFBYSxnQ0FBZ0M7SUFLM0MsWUFBb0IsT0FBcUIsRUFBRSxNQUFXLEVBQUUsS0FBYztRQUNwRSxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUNyQixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FDZCxZQUFvQixFQUNwQixPQUFnQixFQUNoQixVQUFtQixFQUNuQixNQUE4QjtRQUU5QixJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ25DLE1BQU0sSUFBSSxLQUFL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
178
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF0aXZlX3NobS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iYl9iYWNrZW5kcy9ub2RlL25hdGl2ZV9zaG0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQXVDO0FBQ3ZDLGlEQUFvRDtBQUNwRCwyQkFBeUM7QUFFekMsK0NBQWdFO0FBRWhFLHlCQUF5QjtBQUN6QixvREFBb0Q7QUFDcEQsTUFBTSxTQUFTLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUM7QUFDbkMsbUZBQW1GO0FBQ25GLElBQUksS0FBSyxHQUFRLElBQUksQ0FBQztBQUN0QixJQUFJLENBQUM7SUFDSCxJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQ2QsTUFBTSxPQUFPLEdBQUcsSUFBQSxzQkFBYSxFQUFDLElBQUEsNkJBQWUsR0FBRyxDQUFDLENBQUM7UUFDbEQsS0FBSyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM3QixDQUFDO0FBQ0gsQ0FBQztBQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDYix1Q0FBdUM7SUFDdkMsS0FBSyxHQUFHLElBQUksQ0FBQztBQUNmLENBQUM7QUFFRCxJQUFJLGVBQWUsR0FBRyxDQUFDLENBQUM7QUFFeEI7Ozs7Ozs7Ozs7R0FVRztBQUNILE1BQWEsZ0NBQWdDO0lBSzNDLFlBQW9CLE9BQXFCLEVBQUUsTUFBVyxFQUFFLEtBQWM7UUFDcEUsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFDdkIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FDZCxZQUFvQixFQUNwQixPQUFnQixFQUNoQixNQUE4QjtRQUU5QixJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lB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
@@ -0,0 +1,51 @@
1
+ import { IMsgpackBackendAsync } from '../interface.js';
2
+ /**
3
+ * Asynchronous shared memory backend that communicates with bb binary via shared memory.
4
+ * Uses NAPI module with background thread polling for async operations.
5
+ * Supports request pipelining - multiple requests can be in flight simultaneously.
6
+ *
7
+ * Architecture (matches socket backend pattern):
8
+ * - bb acts as the SERVER, TypeScript is the CLIENT
9
+ * - bb creates the shared memory region
10
+ * - TypeScript connects via NAPI wrapper (MsgpackClientAsync)
11
+ * - TypeScript manages promise queue (single-threaded, no mutex needed)
12
+ * - C++ background thread polls for responses, calls JavaScript callback
13
+ * - JavaScript callback pops queue and resolves promises in FIFO order
14
+ */
15
+ export declare class BarretenbergNativeShmAsyncBackend implements IMsgpackBackendAsync {
16
+ private process;
17
+ private client;
18
+ private logFd?;
19
+ private pendingCallbacks;
20
+ private constructor();
21
+ /**
22
+ * Handle response from C++ background thread
23
+ * Dequeues the next pending callback and resolves it (FIFO order)
24
+ */
25
+ private handleResponse;
26
+ /**
27
+ * Create and initialize an async shared memory backend.
28
+ * @param bbBinaryPath Path to bb binary
29
+ * @param threads Optional number of threads (defaults to min(32, num_cpus))
30
+ * @param logger Optional logger function for bb output
31
+ */
32
+ static new(bbBinaryPath: string, threads?: number, logger?: (msg: string) => void): Promise<BarretenbergNativeShmAsyncBackend>;
33
+ /**
34
+ * Send a msgpack request asynchronously.
35
+ * Supports pipelining - can be called multiple times before awaiting responses.
36
+ * Use Promise.all() to send multiple requests concurrently.
37
+ *
38
+ * Example:
39
+ * const results = await Promise.all([
40
+ * backend.call(buf1),
41
+ * backend.call(buf2),
42
+ * backend.call(buf3)
43
+ * ]);
44
+ *
45
+ * @param inputBuffer The msgpack-encoded request
46
+ * @returns Promise resolving to msgpack-encoded response
47
+ */
48
+ call(inputBuffer: Uint8Array): Promise<Uint8Array>;
49
+ destroy(): Promise<void>;
50
+ }
51
+ //# sourceMappingURL=native_shm_async.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"native_shm_async.d.ts","sourceRoot":"","sources":["../../../../src/bb_backends/node/native_shm_async.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AAoBvD;;;;;;;;;;;;GAYG;AACH,qBAAa,iCAAkC,YAAW,oBAAoB;IAC5E,OAAO,CAAC,OAAO,CAAe;IAC9B,OAAO,CAAC,MAAM,CAAM;IACpB,OAAO,CAAC,KAAK,CAAC,CAAS;IAIvB,OAAO,CAAC,gBAAgB,CAGhB;IAER,OAAO;IAYP;;;OAGG;IACH,OAAO,CAAC,cAAc;IAgBtB;;;;;OAKG;WACU,GAAG,CACd,YAAY,EAAE,MAAM,EACpB,OAAO,CAAC,EAAE,MAAM,EAChB,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,GAC7B,OAAO,CAAC,iCAAiC,CAAC;IAqH7C;;;;;;;;;;;;;;OAcG;IACG,IAAI,CAAC,WAAW,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;IA4BlD,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;CAe/B"}
@@ -0,0 +1,238 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BarretenbergNativeShmAsyncBackend = void 0;
4
+ const module_1 = require("module");
5
+ const child_process_1 = require("child_process");
6
+ const fs_1 = require("fs");
7
+ const platform_js_1 = require("./platform.js");
8
+ // Import the NAPI module
9
+ // The addon is built to the nodejs_module directory
10
+ const addonPath = (0, platform_js_1.findNapiBinary)();
11
+ // Try loading, but don't throw if it doesn't exist (will be caught in constructor)
12
+ let addon = null;
13
+ try {
14
+ if (addonPath) {
15
+ const require = (0, module_1.createRequire)((0, platform_js_1.findPackageRoot)());
16
+ addon = require(addonPath);
17
+ }
18
+ }
19
+ catch (err) {
20
+ // Addon not built yet or not available
21
+ addon = null;
22
+ }
23
+ let instanceCounter = 0;
24
+ /**
25
+ * Asynchronous shared memory backend that communicates with bb binary via shared memory.
26
+ * Uses NAPI module with background thread polling for async operations.
27
+ * Supports request pipelining - multiple requests can be in flight simultaneously.
28
+ *
29
+ * Architecture (matches socket backend pattern):
30
+ * - bb acts as the SERVER, TypeScript is the CLIENT
31
+ * - bb creates the shared memory region
32
+ * - TypeScript connects via NAPI wrapper (MsgpackClientAsync)
33
+ * - TypeScript manages promise queue (single-threaded, no mutex needed)
34
+ * - C++ background thread polls for responses, calls JavaScript callback
35
+ * - JavaScript callback pops queue and resolves promises in FIFO order
36
+ */
37
+ class BarretenbergNativeShmAsyncBackend {
38
+ constructor(process, client, logFd) {
39
+ // Queue of pending callbacks for pipelined requests
40
+ // Responses come back in FIFO order, so we match them with queued callbacks
41
+ this.pendingCallbacks = [];
42
+ this.process = process;
43
+ this.client = client;
44
+ this.logFd = logFd;
45
+ // Register our response handler with the C++ client
46
+ // This callback will be invoked from the background thread via ThreadSafeFunction
47
+ this.client.setResponseCallback((responseBuffer) => {
48
+ this.handleResponse(responseBuffer);
49
+ });
50
+ }
51
+ /**
52
+ * Handle response from C++ background thread
53
+ * Dequeues the next pending callback and resolves it (FIFO order)
54
+ */
55
+ handleResponse(responseBuffer) {
56
+ // Response is complete - dequeue the next pending callback (FIFO)
57
+ const callback = this.pendingCallbacks.shift();
58
+ if (callback) {
59
+ callback.resolve(new Uint8Array(responseBuffer));
60
+ }
61
+ else {
62
+ // This shouldn't happen - response without a pending request
63
+ console.warn('Received response but no pending callback');
64
+ }
65
+ // If no more pending callbacks, release ref to allow process to exit
66
+ if (this.pendingCallbacks.length === 0) {
67
+ this.client.release();
68
+ }
69
+ }
70
+ /**
71
+ * Create and initialize an async shared memory backend.
72
+ * @param bbBinaryPath Path to bb binary
73
+ * @param threads Optional number of threads (defaults to min(32, num_cpus))
74
+ * @param logger Optional logger function for bb output
75
+ */
76
+ static async new(bbBinaryPath, threads, logger) {
77
+ if (!addon || !addon.MsgpackClientAsync) {
78
+ throw new Error('Shared memory async NAPI not available.');
79
+ }
80
+ // Create a unique shared memory name
81
+ const shmName = `bb-async-${process.pid}-${instanceCounter++}`;
82
+ // If threads not set use num cpu cores, max 32 (same as socket backend)
83
+ const hwc = threads ? threads.toString() : '1';
84
+ const env = { ...process.env, HARDWARE_CONCURRENCY: hwc };
85
+ // Set up file logging if logger is provided
86
+ // Direct file redirection bypasses Node event loop - logs are written even if process hangs
87
+ let logFd;
88
+ let logPath;
89
+ if (logger) {
90
+ logPath = `/tmp/${shmName}.log`;
91
+ logFd = (0, fs_1.openSync)(logPath, 'w');
92
+ logger(`BB process logs redirected to: ${logPath}`);
93
+ }
94
+ // Spawn bb process with shared memory mode
95
+ // Use larger ring buffers for async mode to support pipelining
96
+ const args = [
97
+ 'msgpack',
98
+ 'run',
99
+ '--input',
100
+ `${shmName}.shm`,
101
+ '--request-ring-size',
102
+ `${1024 * 1024 * 4}`,
103
+ '--response-ring-size',
104
+ `${1024 * 1024 * 4}`,
105
+ ];
106
+ const bbProcess = (0, child_process_1.spawn)(bbBinaryPath, args, {
107
+ stdio: ['ignore', logFd ?? 'ignore', logFd ?? 'ignore'],
108
+ env,
109
+ });
110
+ // Disconnect from event loop so process can exit without waiting for bb
111
+ // The bb process has parent death monitoring (prctl on Linux, kqueue on macOS)
112
+ // so it will automatically exit when Node.js exits
113
+ bbProcess.unref();
114
+ // Track if process has exited
115
+ let processExited = false;
116
+ let exitError = null;
117
+ bbProcess.on('error', err => {
118
+ processExited = true;
119
+ exitError = new Error(`Native backend process error: ${err.message}`);
120
+ });
121
+ bbProcess.on('exit', (code, signal) => {
122
+ processExited = true;
123
+ if (code !== null && code !== 0) {
124
+ exitError = new Error(`Native backend process exited with code ${code}`);
125
+ }
126
+ else if (signal && signal !== 'SIGTERM') {
127
+ exitError = new Error(`Native backend process killed with signal ${signal}`);
128
+ }
129
+ });
130
+ // Wait for bb to create shared memory
131
+ // Retry connection every 100ms for up to 5 seconds (longer than sync for thread startup)
132
+ const retryInterval = 100; // ms
133
+ const timeout = 5000; // ms
134
+ const maxAttempts = Math.floor(timeout / retryInterval);
135
+ let client = null;
136
+ try {
137
+ for (let attempt = 0; attempt < maxAttempts; attempt++) {
138
+ // Check if bb process has exited before attempting connection
139
+ if (processExited) {
140
+ throw exitError || new Error('Native backend process exited unexpectedly during startup');
141
+ }
142
+ // Wait before attempting connection (except first attempt)
143
+ if (attempt > 0) {
144
+ await new Promise(resolve => setTimeout(resolve, retryInterval));
145
+ }
146
+ try {
147
+ // Create NAPI async client
148
+ client = new addon.MsgpackClientAsync(shmName);
149
+ break; // Success!
150
+ }
151
+ catch (err) {
152
+ // Connection failed, will retry
153
+ if (attempt === maxAttempts - 1) {
154
+ // Last attempt failed - check one more time if process exited
155
+ if (processExited && exitError) {
156
+ throw exitError;
157
+ }
158
+ throw new Error(`Failed to connect to shared memory after ${timeout}ms: ${err.message}`);
159
+ }
160
+ }
161
+ }
162
+ if (!client) {
163
+ throw new Error('Failed to create client connection');
164
+ }
165
+ return new BarretenbergNativeShmAsyncBackend(bbProcess, client, logFd);
166
+ }
167
+ finally {
168
+ // If we failed to connect, ensure the process is killed and log file closed
169
+ if (!client) {
170
+ bbProcess.kill('SIGKILL');
171
+ if (logFd !== undefined) {
172
+ try {
173
+ (0, fs_1.closeSync)(logFd);
174
+ }
175
+ catch (e) {
176
+ // Ignore errors during cleanup
177
+ }
178
+ }
179
+ }
180
+ }
181
+ }
182
+ /**
183
+ * Send a msgpack request asynchronously.
184
+ * Supports pipelining - can be called multiple times before awaiting responses.
185
+ * Use Promise.all() to send multiple requests concurrently.
186
+ *
187
+ * Example:
188
+ * const results = await Promise.all([
189
+ * backend.call(buf1),
190
+ * backend.call(buf2),
191
+ * backend.call(buf3)
192
+ * ]);
193
+ *
194
+ * @param inputBuffer The msgpack-encoded request
195
+ * @returns Promise resolving to msgpack-encoded response
196
+ */
197
+ async call(inputBuffer) {
198
+ return new Promise((resolve, reject) => {
199
+ // If this is the first pending callback, acquire ref to keep event loop alive
200
+ if (this.pendingCallbacks.length === 0) {
201
+ this.client.acquire();
202
+ }
203
+ // Enqueue this promise's callbacks (FIFO order)
204
+ this.pendingCallbacks.push({ resolve, reject });
205
+ try {
206
+ // Send request to shared memory (synchronous write)
207
+ // C++ call() no longer returns a promise - we manage them here
208
+ this.client.call(Buffer.from(inputBuffer));
209
+ }
210
+ catch (err) {
211
+ // Send failed - dequeue the callback we just added and reject
212
+ this.pendingCallbacks.pop();
213
+ // If queue is now empty, release ref to allow exit
214
+ if (this.pendingCallbacks.length === 0) {
215
+ this.client.release();
216
+ }
217
+ reject(new Error(`Shared memory async call failed: ${err.message}`));
218
+ }
219
+ });
220
+ }
221
+ async destroy() {
222
+ // Kill the bb process
223
+ // Background thread and callbacks will be cleaned up by OS on process exit
224
+ this.process.kill('SIGTERM');
225
+ this.process.removeAllListeners();
226
+ // Close log file if open
227
+ if (this.logFd !== undefined) {
228
+ try {
229
+ (0, fs_1.closeSync)(this.logFd);
230
+ }
231
+ catch (e) {
232
+ // Ignore errors during cleanup
233
+ }
234
+ }
235
+ }
236
+ }
237
+ exports.BarretenbergNativeShmAsyncBackend = BarretenbergNativeShmAsyncBackend;
238
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF0aXZlX3NobV9hc3luYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iYl9iYWNrZW5kcy9ub2RlL25hdGl2ZV9zaG1fYXN5bmMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQXVDO0FBQ3ZDLGlEQUFvRDtBQUNwRCwyQkFBeUM7QUFFekMsK0NBQWdFO0FBRWhFLHlCQUF5QjtBQUN6QixvREFBb0Q7QUFDcEQsTUFBTSxTQUFTLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUM7QUFDbkMsbUZBQW1GO0FBQ25GLElBQUksS0FBSyxHQUFRLElBQUksQ0FBQztBQUN0QixJQUFJLENBQUM7SUFDSCxJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQ2QsTUFBTSxPQUFPLEdBQUcsSUFBQSxzQkFBYSxFQUFDLElBQUEsNkJBQWUsR0FBRyxDQUFDLENBQUM7UUFDbEQsS0FBSyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM3QixDQUFDO0FBQ0gsQ0FBQztBQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDYix1Q0FBdUM7SUFDdkMsS0FBSyxHQUFHLElBQUksQ0FBQztBQUNmLENBQUM7QUFFRCxJQUFJLGVBQWUsR0FBRyxDQUFDLENBQUM7QUFFeEI7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsTUFBYSxpQ0FBaUM7SUFZNUMsWUFBb0IsT0FBcUIsRUFBRSxNQUFXLEVBQUUsS0FBYztRQVB0RSxvREFBb0Q7UUFDcEQsNEVBQTRFO1FBQ3BFLHFCQUFnQixHQUduQixFQUFFLENBQUM7UUFHTixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUVuQixvREFBb0Q7UUFDcEQsa0ZBQWtGO1FBQ2xGLElBQUksQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxjQUFzQixFQUFF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
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/bin/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,13 @@
1
+ #!/usr/bin/env node
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ const platform_js_1 = require("../bb_backends/node/platform.js");
5
+ const node_child_process_1 = require("node:child_process");
6
+ const bin = (0, platform_js_1.findBbBinary)();
7
+ if (!bin) {
8
+ console.error('Could not find bb binary. Please ensure it is built and accessible.');
9
+ process.exit(1);
10
+ }
11
+ const result = (0, node_child_process_1.spawnSync)(bin, process.argv.slice(2), { stdio: 'inherit' });
12
+ process.exit(result.status ?? 1);
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmluL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLGlFQUErRDtBQUMvRCwyREFBK0M7QUFFL0MsTUFBTSxHQUFHLEdBQUcsSUFBQSwwQkFBWSxHQUFFLENBQUM7QUFFM0IsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ1QsT0FBTyxDQUFDLEtBQUssQ0FBQyxxRUFBcUUsQ0FBQyxDQUFDO0lBQ3JGLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDbEIsQ0FBQztBQUVELE1BQU0sTUFBTSxHQUFHLElBQUEsOEJBQVMsRUFBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztBQUUzRSxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUMifQ==
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@aztec/bb.js",
3
3
  "packageManager": "yarn@4.5.2",
4
- "version": "3.0.0-nightly.20251124",
4
+ "version": "3.0.0-nightly.20251125",
5
5
  "homepage": "https://github.com/AztecProtocol/aztec-packages/tree/master/barretenberg/ts",
6
6
  "license": "MIT",
7
7
  "type": "module",
@@ -13,7 +13,9 @@
13
13
  "default": "./dest/node/index.js"
14
14
  }
15
15
  },
16
- "bin": "dest/node/main.js",
16
+ "bin": {
17
+ "bb": "dest/node/bin/index.js"
18
+ },
17
19
  "files": [
18
20
  "src/",
19
21
  "dest/",
@@ -25,7 +27,7 @@
25
27
  "build": "yarn clean && yarn generate && yarn build:wasm && yarn build:native && yarn build:esm && yarn build:cjs && yarn build:browser",
26
28
  "build:wasm": "./scripts/copy_wasm.sh",
27
29
  "build:native": "./scripts/copy_native.sh",
28
- "build:esm": "tsc -b tsconfig.esm.json",
30
+ "build:esm": "tsc -b tsconfig.esm.json && chmod +x ./dest/node/bin/index.js",
29
31
  "build:cjs": "tsc -b tsconfig.cjs.json && ./scripts/cjs_postprocess.sh",
30
32
  "build:browser": "tsc -b tsconfig.browser.json && ./scripts/browser_postprocess.sh",
31
33
  "generate": "NODE_OPTIONS='--loader ts-node/esm' NODE_NO_WARNINGS=1 ts-node src/cbind/generate.ts",
@@ -174,11 +174,11 @@ export class BarretenbergSync extends SyncApi {
174
174
  }
175
175
 
176
176
  // Try native, fallback to WASM.
177
- // try {
178
- // return await createSyncBackend(BackendType.NativeSharedMemory, options, logger);
179
- // } catch (err: any) {
180
- // logger(`Shared memory unavailable (${err.message}), falling back to WASM`);
181
- // }
177
+ try {
178
+ return await createSyncBackend(BackendType.NativeSharedMemory, options, logger);
179
+ } catch (err: any) {
180
+ logger(`Shared memory unavailable (${err.message}), falling back to WASM`);
181
+ }
182
182
 
183
183
  return await createSyncBackend(BackendType.Wasm, options, logger);
184
184
  }
@@ -94,7 +94,20 @@ describe('poseidon2Hash benchmark (Async API): WASM vs Native', () => {
94
94
  nativeSocketTime = performance.now() - nativeSocketStart;
95
95
  }
96
96
 
97
- // Benchmark 3: Native Shared Memory (async)
97
+ // Benchmark 3: Native Socket (async, request pipelined)
98
+ let nativeSocketPipelinedTime = 0;
99
+ if (nativeSocketApi) {
100
+ const nativeSocketPipelinedStart = performance.now();
101
+ // Use promise.all to pipeline requests
102
+ const promises = [];
103
+ for (let i = 0; i < ITERATIONS; i++) {
104
+ promises.push(nativeSocketApi.poseidon2Hash({ inputs }));
105
+ }
106
+ await Promise.all(promises);
107
+ nativeSocketPipelinedTime = performance.now() - nativeSocketPipelinedStart;
108
+ }
109
+
110
+ // Benchmark 4: Native Shared Memory (async)
98
111
  let nativeShmTime = 0;
99
112
  if (nativeShmApi) {
100
113
  const nativeShmStart = performance.now();
@@ -104,7 +117,20 @@ describe('poseidon2Hash benchmark (Async API): WASM vs Native', () => {
104
117
  nativeShmTime = performance.now() - nativeShmStart;
105
118
  }
106
119
 
107
- // Benchmark 4: Native Shared Memory (sync)
120
+ // Benchmark 5: Native Shared Memory (async, request pipelined)
121
+ let nativeShmPipelinedTime = 0;
122
+ if (nativeShmApi) {
123
+ const nativeShmPipelinedStart = performance.now();
124
+ // Use promise.all to pipeline requests
125
+ const promises = [];
126
+ for (let i = 0; i < ITERATIONS; i++) {
127
+ promises.push(nativeShmApi.poseidon2Hash({ inputs }));
128
+ }
129
+ await Promise.all(promises);
130
+ nativeShmPipelinedTime = performance.now() - nativeShmPipelinedStart;
131
+ }
132
+
133
+ // Benchmark 6: Native Shared Memory (sync)
108
134
  let nativeShmSyncTime = 0;
109
135
  if (nativeShmSyncApi) {
110
136
  const nativeShmSyncStart = performance.now();
@@ -116,16 +142,20 @@ describe('poseidon2Hash benchmark (Async API): WASM vs Native', () => {
116
142
 
117
143
  // Calculate metrics (all relative to WASM baseline)
118
144
  const nativeSocketOverhead = ((nativeSocketTime - wasmTime) / wasmTime) * 100;
145
+ const nativeSocketPipelinedOverhead = ((nativeSocketPipelinedTime - wasmTime) / wasmTime) * 100;
119
146
  const nativeShmOverhead = ((nativeShmTime - wasmTime) / wasmTime) * 100;
147
+ const nativeShmPipelinedOverhead = ((nativeShmPipelinedTime - wasmTime) / wasmTime) * 100;
120
148
  const nativeShmSyncOverhead = ((nativeShmSyncTime - wasmTime) / wasmTime) * 100;
121
149
 
122
150
  const avgWasmTimeUs = (wasmTime / ITERATIONS) * 1000;
123
151
  const avgNativeSocketTimeUs = (nativeSocketTime / ITERATIONS) * 1000;
152
+ const avgNativeSocketPipelinedTimeUs = (nativeSocketPipelinedTime / ITERATIONS) * 1000;
124
153
  const avgNativeShmTimeUs = (nativeShmTime / ITERATIONS) * 1000;
154
+ const avgNativeShmPipelinedTimeUs = (nativeShmPipelinedTime / ITERATIONS) * 1000;
125
155
  const avgNativeShmSyncTimeUs = (nativeShmSyncTime / ITERATIONS) * 1000;
126
156
 
127
157
  process.stdout.write(
128
- `┌─ Size ${size.toString().padStart(3)} field elements ──────────────────────────────────┐\n`,
158
+ `┌─ Size ${size.toString().padStart(3)} field elements ───────────────────────────────────────┐\n`,
129
159
  );
130
160
  const formatOverhead = (overhead: number): string => {
131
161
  const sign = overhead >= 0 ? '+' : '-';
@@ -135,37 +165,57 @@ describe('poseidon2Hash benchmark (Async API): WASM vs Native', () => {
135
165
 
136
166
  if (wasmApi) {
137
167
  process.stdout.write(
138
- `│ WASM: ${wasmTime.toFixed(2).padStart(8)}ms (${avgWasmTimeUs.toFixed(2).padStart(7)}µs/call) [baseline] │\n`,
168
+ `│ WASM: ${wasmTime.toFixed(2).padStart(8)}ms (${avgWasmTimeUs.toFixed(2).padStart(7)}µs/call) [baseline] │\n`,
169
+ );
170
+ } else {
171
+ process.stdout.write(`│ WASM: unavailable │\n`);
172
+ }
173
+
174
+ if (nativeSocketApi) {
175
+ process.stdout.write(
176
+ `│ Native Socket: ${nativeSocketTime.toFixed(2).padStart(8)}ms (${avgNativeSocketTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeSocketOverhead)} │\n`,
139
177
  );
140
178
  } else {
141
- process.stdout.write(`│ WASM: unavailable │\n`);
179
+ process.stdout.write(`│ Native Socket: unavailable │\n`);
142
180
  }
143
181
 
144
182
  if (nativeSocketApi) {
145
183
  process.stdout.write(
146
- `│ Native Socket: ${nativeSocketTime.toFixed(2).padStart(8)}ms (${avgNativeSocketTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeSocketOverhead)} │\n`,
184
+ `│ Native Socket Pipelined: ${nativeSocketPipelinedTime
185
+ .toFixed(2)
186
+ .padStart(8)}ms (${avgNativeSocketPipelinedTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(
187
+ nativeSocketPipelinedOverhead,
188
+ )} │\n`,
189
+ );
190
+ } else {
191
+ process.stdout.write(`│ Native Socket Pipelined: unavailable │\n`);
192
+ }
193
+
194
+ if (nativeShmApi) {
195
+ process.stdout.write(
196
+ `│ Native Shared: ${nativeShmTime.toFixed(2).padStart(8)}ms (${avgNativeShmTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmOverhead)} │\n`,
147
197
  );
148
198
  } else {
149
- process.stdout.write(`│ Native Socket: unavailable │\n`);
199
+ process.stdout.write(`│ Native Shared: unavailable │\n`);
150
200
  }
151
201
 
152
202
  if (nativeShmApi) {
153
203
  process.stdout.write(
154
- `│ Native Shared: ${nativeShmTime.toFixed(2).padStart(8)}ms (${avgNativeShmTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmOverhead)} │\n`,
204
+ `│ Native Shared Pipelined: ${nativeShmPipelinedTime.toFixed(2).padStart(8)}ms (${avgNativeShmPipelinedTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmPipelinedOverhead)} │\n`,
155
205
  );
156
206
  } else {
157
- process.stdout.write(`│ Native Shared: unavailable │\n`);
207
+ process.stdout.write(`│ Native Shared Pipelined: unavailable │\n`);
158
208
  }
159
209
 
160
210
  if (nativeShmSyncApi) {
161
211
  process.stdout.write(
162
- `│ Native Shared Sync: ${nativeShmSyncTime.toFixed(2).padStart(8)}ms (${avgNativeShmSyncTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmSyncOverhead)} │\n`,
212
+ `│ Native Shared Sync: ${nativeShmSyncTime.toFixed(2).padStart(8)}ms (${avgNativeShmSyncTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmSyncOverhead)} │\n`,
163
213
  );
164
214
  } else {
165
- process.stdout.write(`│ Native Shared Sync: unavailable │\n`);
215
+ process.stdout.write(`│ Native Shared Sync: unavailable │\n`);
166
216
  }
167
217
 
168
- process.stdout.write(`└────────────────────────────────────────────────────────────┘\n`);
218
+ process.stdout.write(`└─────────────────────────────────────────────────────────────────┘\n`);
169
219
 
170
220
  const wasmResult = await wasmApi!.poseidon2Hash({ inputs });
171
221
 
@@ -8,7 +8,7 @@ export enum BackendType {
8
8
  WasmWorker = 'WasmWorker',
9
9
  /** Native via Unix domain socket (async only) */
10
10
  NativeUnixSocket = 'NativeUnixSocket',
11
- /** Native via shared memory (sync only currently) */
11
+ /** Native via shared memory */
12
12
  NativeSharedMemory = 'NativeSharedMemory',
13
13
  }
14
14