diff --git a/packages/SwingSet/docs/configuration.md b/packages/SwingSet/docs/configuration.md index a014e4b2b5b9..d1214155bbcf 100644 --- a/packages/SwingSet/docs/configuration.md +++ b/packages/SwingSet/docs/configuration.md @@ -104,10 +104,10 @@ bootstrap vat. If this property is missing, there will be no bootstrap vat, which may be disallowed in certain use cases. The `defaultManagerType` property indicates what sort of vat worker to run vats -in if they are not specifically configured otherwise. Currently allowed manager -types are `'local'`, `'nodeWorker'`, `'node-subprocess'`, `'xs-worker'`, and -`'xs-worker-no-gc'`. Of these, only `'local'` and `'xs-worker'` are fully -supported; the others are experimental. If omitted, it defaults to `'local'`. +in if they are not specifically configured otherwise. Currently allowed +manager types are `'local'`, `'nodeWorker'`, `'node-subprocess'`, and +`'xs-worker'`. Of these, only `'local'` and `'xs-worker'` are fully supported; +the others are experimental. If omitted, it defaults to `'local'`. The `includeDevDependencies` property, if `true`, instructs the bundler which creates bundles to include the SwingSet package's dev dependencies as well as diff --git a/packages/SwingSet/misc-tools/replay-transcript.js b/packages/SwingSet/misc-tools/replay-transcript.js index 64aa9b41c359..37b53d29ac6f 100644 --- a/packages/SwingSet/misc-tools/replay-transcript.js +++ b/packages/SwingSet/misc-tools/replay-transcript.js @@ -47,7 +47,6 @@ function compareSyscalls(vatID, originalSyscall, newSyscall) { // 3.8s v8-false, 27.5s v8-gc // 10.8s xs-no-gc, 15s xs-gc const worker = 'xs-worker'; -const gcEveryCrank = true; // false means GC is hard-disabled async function replay(transcriptFile) { let vatID; // we learn this from the first line of the transcript @@ -71,7 +70,7 @@ async function replay(transcriptFile) { WeakRef, FinalizationRegistry, waitUntilQuiescent, - gcAndFinalize: makeGcAndFinalize(gcEveryCrank ? engineGC : false), + gcAndFinalize: makeGcAndFinalize(engineGC), meterControl, }); const allVatPowers = { testLog }; @@ -151,7 +150,6 @@ async function replay(transcriptFile) { vatParameters, compareSyscalls, useTranscript: true, - gcEveryCrank, }; const vatSyscallHandler = undefined; manager = await factory.createFromBundle( diff --git a/packages/SwingSet/src/controller/initializeSwingset.js b/packages/SwingSet/src/controller/initializeSwingset.js index 61aebcc3b934..0a6d7a5899b4 100644 --- a/packages/SwingSet/src/controller/initializeSwingset.js +++ b/packages/SwingSet/src/controller/initializeSwingset.js @@ -323,7 +323,6 @@ export async function initializeSwingset( case 'nodeWorker': case 'node-subprocess': case 'xs-worker': - case 'xs-worker-no-gc': config.defaultManagerType = defaultManagerType; break; case undefined: diff --git a/packages/SwingSet/src/kernel/state/kernelKeeper.js b/packages/SwingSet/src/kernel/state/kernelKeeper.js index c4a85811eed0..d0ef0cc807f3 100644 --- a/packages/SwingSet/src/kernel/state/kernelKeeper.js +++ b/packages/SwingSet/src/kernel/state/kernelKeeper.js @@ -304,13 +304,7 @@ export default function makeKernelKeeper( function insistManagerType(mt) { assert( - [ - 'local', - 'nodeWorker', - 'node-subprocess', - 'xs-worker', - 'xs-worker-no-gc', - ].includes(mt), + ['local', 'nodeWorker', 'node-subprocess', 'xs-worker'].includes(mt), ); } diff --git a/packages/SwingSet/src/kernel/vat-loader/manager-factory.js b/packages/SwingSet/src/kernel/vat-loader/manager-factory.js index d48f8d60a297..64e0d40e274e 100644 --- a/packages/SwingSet/src/kernel/vat-loader/manager-factory.js +++ b/packages/SwingSet/src/kernel/vat-loader/manager-factory.js @@ -50,7 +50,6 @@ export function makeVatManagerFactory({ assertKnownOptions(managerOptions, [ 'enablePipelining', 'managerType', - 'gcEveryCrank', 'setup', 'bundle', 'metered', @@ -85,12 +84,7 @@ export function makeVatManagerFactory({ enableSetup, } = managerOptions; - if ( - metered && - managerType !== 'local' && - managerType !== 'xs-worker' && - managerType !== 'xs-worker-no-gc' - ) { + if (metered && managerType !== 'local' && managerType !== 'xs-worker') { console.warn(`TODO: support metered with ${managerType}`); } if (setup && managerType !== 'local') { @@ -139,19 +133,11 @@ export function makeVatManagerFactory({ ); } - if (managerType === 'xs-worker' || managerType === 'xs-worker-no-gc') { - const transformedOptions = { - ...managerOptions, - managerType: 'xs-worker', - }; - if (managerOptions.gcEveryCrank === undefined) { - // Explicitly enable/disable gcEveryCrank. - transformedOptions.gcEveryCrank = managerType !== 'xs-worker-no-gc'; - } + if (managerType === 'xs-worker') { return xsWorkerFactory.createFromBundle( vatID, bundle, - transformedOptions, + managerOptions, vatSyscallHandler, ); } diff --git a/packages/SwingSet/src/kernel/vat-loader/manager-subprocess-xsnap.js b/packages/SwingSet/src/kernel/vat-loader/manager-subprocess-xsnap.js index bdb2a6dd5f43..6e8706dca615 100644 --- a/packages/SwingSet/src/kernel/vat-loader/manager-subprocess-xsnap.js +++ b/packages/SwingSet/src/kernel/vat-loader/manager-subprocess-xsnap.js @@ -53,7 +53,6 @@ export function makeXsSubprocessFactory({ const { virtualObjectCacheSize, enableDisavow, - gcEveryCrank = true, name: vatName, metered, compareSyscalls, @@ -155,7 +154,6 @@ export function makeXsSubprocessFactory({ virtualObjectCacheSize, enableDisavow, kernelKeeper.getRelaxDurabilityRules(), - gcEveryCrank, ]); if (bundleReply[0] === 'dispatchReady') { parentLog(vatID, `bundle loaded. dispatch ready.`); diff --git a/packages/SwingSet/src/supervisors/subprocess-xsnap/supervisor-subprocess-xsnap.js b/packages/SwingSet/src/supervisors/subprocess-xsnap/supervisor-subprocess-xsnap.js index 2840f4a6e35d..c2b992f02074 100644 --- a/packages/SwingSet/src/supervisors/subprocess-xsnap/supervisor-subprocess-xsnap.js +++ b/packages/SwingSet/src/supervisors/subprocess-xsnap/supervisor-subprocess-xsnap.js @@ -186,7 +186,6 @@ function makeWorker(port) { * @param {unknown} virtualObjectCacheSize * @param {boolean} enableDisavow * @param {boolean} relaxDurabilityRules - * @param {boolean} [gcEveryCrank] * @returns {Promise} */ async function setBundle( @@ -195,7 +194,6 @@ function makeWorker(port) { virtualObjectCacheSize, enableDisavow, relaxDurabilityRules, - gcEveryCrank, ) { /** @type { (vso: VatSyscallObject) => VatSyscallResult } */ function syscallToManager(vatSyscallObject) { @@ -230,9 +228,7 @@ function makeWorker(port) { WeakRef, FinalizationRegistry, waitUntilQuiescent, - // FIXME(mfig): Here is where GC-per-crank is silently disabled. - // We need to do a better analysis of the tradeoffs. - gcAndFinalize: makeGcAndFinalize(gcEveryCrank && globalThis.gc), + gcAndFinalize: makeGcAndFinalize(globalThis.gc), meterControl, }); @@ -312,14 +308,12 @@ function makeWorker(port) { assert(!dispatch, 'cannot setBundle again'); const enableDisavow = !!args[3]; const relaxDurabilityRules = !!args[4]; - const gcEveryCrank = args[5] === undefined ? true : !!args[5]; return setBundle( args[0], args[1], args[2], enableDisavow, relaxDurabilityRules, - gcEveryCrank, ); } case 'deliver': { diff --git a/packages/SwingSet/src/types-external.js b/packages/SwingSet/src/types-external.js index e4e190f765b0..820f10b77f9e 100644 --- a/packages/SwingSet/src/types-external.js +++ b/packages/SwingSet/src/types-external.js @@ -28,11 +28,10 @@ export {}; * enableSetup: true, * }} HasSetup * - * @typedef { 'local' | 'nodeWorker' | 'node-subprocess' | 'xs-worker' | 'xs-worker-no-gc' } ManagerType + * @typedef { 'local' | 'nodeWorker' | 'node-subprocess' | 'xs-worker' } ManagerType * @typedef {{ * enablePipelining?: boolean, * managerType: ManagerType, - * gcEveryCrank?: boolean, * metered?: boolean, * critical?: boolean, * enableDisavow?: boolean, diff --git a/packages/SwingSet/src/vats/vat-admin/vat-vat-admin.js b/packages/SwingSet/src/vats/vat-admin/vat-vat-admin.js index 0b04bf64c906..7a1a2b517edf 100644 --- a/packages/SwingSet/src/vats/vat-admin/vat-vat-admin.js +++ b/packages/SwingSet/src/vats/vat-admin/vat-vat-admin.js @@ -12,13 +12,7 @@ import { Nat, isNat } from '@agoric/nat'; const { details: X } = assert; -const managerTypes = [ - 'local', - 'nodeWorker', - 'node-subprocess', - 'xs-worker', - 'xs-worker-no-gc', -]; +const managerTypes = ['local', 'nodeWorker', 'node-subprocess', 'xs-worker']; function producePRR() { const { promise, resolve, reject } = makePromiseKit();