Skip to content

Commit

Permalink
chore: Ensure Profiling.prepare is called before profiling (#104)
Browse files Browse the repository at this point in the history
Fixes: #93

---------

Signed-off-by: Rajiv Singh <[email protected]>
Signed-off-by: Rajiv Singh <[email protected]>
Co-authored-by: Rajiv Singh <[email protected]>
  • Loading branch information
iamrajiv and rajiv-maersk authored Aug 28, 2024
1 parent f6ad619 commit 4fcaba2
Showing 1 changed file with 24 additions and 13 deletions.
37 changes: 24 additions & 13 deletions wzprof.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@ type Profiling struct {
symbols symbolizer
stackIterator func(mod api.Module, def api.FunctionDefinition, wasmsi experimental.StackIterator) experimental.StackIterator

lang language
lang language
prepareCalled bool // Flag to indicate if Prepare has been called
}

type language int8
Expand Down Expand Up @@ -95,18 +96,6 @@ func ProfilingFor(wasm []byte) *Profiling {
return r
}

// CPUProfiler constructs a new instance of CPUProfiler using the given time
// function to record the CPU time consumed.
func (p *Profiling) CPUProfiler(options ...CPUProfilerOption) *CPUProfiler {
return newCPUProfiler(p, options...)
}

// MemoryProfiler constructs a new instance of MemoryProfiler using the given
// time function to record the profile execution time.
func (p *Profiling) MemoryProfiler(options ...MemoryProfilerOption) *MemoryProfiler {
return newMemoryProfiler(p, options...)
}

// Prepare selects the most appropriate analysis functions for the guest
// code in the provided module.
func (p *Profiling) Prepare(mod wazero.CompiledModule) error {
Expand Down Expand Up @@ -147,9 +136,31 @@ func (p *Profiling) Prepare(mod wazero.CompiledModule) error {
}
p.symbols = buildDwarfSymbolizer(dwarf)
}

// Set the flag to true if Prepare succeeds
p.prepareCalled = true

return nil
}

// CPUProfiler constructs a new instance of CPUProfiler using the given time
// function to record the CPU time consumed.
func (p *Profiling) CPUProfiler(options ...CPUProfilerOption) *CPUProfiler {
if !p.prepareCalled {
panic("Profiling.Prepare must be called before creating a CPU profiler")
}
return newCPUProfiler(p, options...)
}

// MemoryProfiler constructs a new instance of MemoryProfiler using the given
// time function to record the profile execution time.
func (p *Profiling) MemoryProfiler(options ...MemoryProfilerOption) *MemoryProfiler {
if !p.prepareCalled {
panic("Profiling.Prepare must be called before creating a Memory profiler")
}
return newMemoryProfiler(p, options...)
}

// profilingListener wraps a FunctionListener to adapt its stack iterator to the
// appropriate implementation according to the module support.
type profilingListener struct {
Expand Down

0 comments on commit 4fcaba2

Please sign in to comment.