From 255dc76db9b68e926d0cc5bf406f90772114694a Mon Sep 17 00:00:00 2001 From: DerelictDrone <57756830+DerelictDrone@users.noreply.github.com> Date: Sat, 27 Jan 2024 18:17:37 -0600 Subject: [PATCH] Sandboxes the ZVM (#48) * Sandboxed * Including only used functions in env --- lua/entities/gmod_wire_gpu/cl_gpuvm.lua | 14 ++++++++++++ lua/entities/gmod_wire_spu/cl_spuvm.lua | 5 +++++ lua/wire/zvm/zvm_core.lua | 30 +++++++++++++++++++++---- 3 files changed, 45 insertions(+), 4 deletions(-) diff --git a/lua/entities/gmod_wire_gpu/cl_gpuvm.lua b/lua/entities/gmod_wire_gpu/cl_gpuvm.lua index 8f58233..ca678b6 100644 --- a/lua/entities/gmod_wire_gpu/cl_gpuvm.lua +++ b/lua/entities/gmod_wire_gpu/cl_gpuvm.lua @@ -26,6 +26,20 @@ function ENT:OverrideVM() end end + self.VM.Env["surface"] = { + SetTexture = surface.SetTexture, + SetDrawColor = surface.SetDrawColor, + DrawRect = surface.DrawRect, + DrawTexturedRect = surface.DrawTexturedRect + } + self.VM.Env["GPULib"] = { + Material = GPULib.Material + } + self.VM.Env["render"] = { + CopyTexture = render.CopyTexture + } + self.VM.Env["WireGPU_matBuffer"] = WireGPU_matBuffer + self.VM.ErrorText = {} self.VM.ErrorText[2] = "Program ended unexpectedly" self.VM.ErrorText[3] = "Arithmetic division by zero" diff --git a/lua/entities/gmod_wire_spu/cl_spuvm.lua b/lua/entities/gmod_wire_spu/cl_spuvm.lua index cb7a7df..576c157 100644 --- a/lua/entities/gmod_wire_spu/cl_spuvm.lua +++ b/lua/entities/gmod_wire_spu/cl_spuvm.lua @@ -18,6 +18,11 @@ function ENT:OverrideVM() end end + self.VM.Env["WireSPU_GetSound"] = WireSPU_GetSound + self.VM.Env["WireSPU_SoundCache"] = WireSPU_SoundCache + self.VM.Env["WireSPU_MaxChannels"] = WireSPU_MaxChannels + self.VM.Env["CreateSound"] = CreateSound + self.VM.Entity = self self.VM.Interrupt = function(self,interruptNo,interruptParameter,isExternal,cascadeInterrupt) diff --git a/lua/wire/zvm/zvm_core.lua b/lua/wire/zvm/zvm_core.lua index 78beaef..6d41da0 100644 --- a/lua/wire/zvm/zvm_core.lua +++ b/lua/wire/zvm/zvm_core.lua @@ -408,6 +408,7 @@ function ZVM:Precompile_Finalize() end table.insert(self.IsAddressPrecompiled[address],self.PrecompileStartXEIP) end + setfenv(result,self.Env) self.PrecompiledData[self.PrecompileStartXEIP] = result end @@ -671,8 +672,6 @@ function ZVM:Step(overrideSteps,extraEmitFunction) end -- Execute precompiled instruction - local previousVM = VM - VM = self if CLIENT then -- FIXME: hack around crash on PCALL self.PrecompiledData[self.XEIP]() else @@ -682,7 +681,6 @@ function ZVM:Step(overrideSteps,extraEmitFunction) self:Interrupt(5,1) end end - VM = previousVM else -- Precompile several next instructions self:Precompile_Initialize() @@ -704,7 +702,31 @@ function ZVM:Step(overrideSteps,extraEmitFunction) return end - +-- Any library that's needed by the entirety of the ZVM instruction set should go here +-- Platform dependant libraries(GPU or SPU for example) should be added to the env by the platform +ZVM.Env = { + math={ + Clamp = math.Clamp, + floor = math.floor, + min = math.min, + max = math.max, + sqrt = math.sqrt, + sin = math.sin, + cos = math.cos, + pi = math.pi, + abs = math.abs, + random = math.random + }, + bit={ + bnot = bit.bnot, + band = bit.band, + bor = bit.bor, + bxor = bit.bxor, + lshift = bit.lshift, + rshift = bit.rshift + }, + VM = ZVM +} --------------------------------------------------------------------------------