123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- #
- #
- # Nim's Runtime Library
- # (c) Copyright 2015 Andreas Rumpf
- #
- # See the file "copying.txt", included in this
- # distribution, for details about the copyright.
- #
- # Nim high-level memory manager: It supports Boehm's GC, Go's GC, no GC and the
- # native Nim GC. The native Nim GC is the default.
- #{.push checks:on, assertions:on.}
- {.push checks:off.}
- const
- debugGC = false # we wish to debug the GC...
- logGC = false
- traceGC = false # extensive debugging
- alwaysCycleGC = defined(nimSmokeCycles)
- alwaysGC = defined(nimFulldebug) # collect after every memory
- # allocation (for debugging)
- leakDetector = defined(nimLeakDetector)
- overwriteFree = defined(nimBurnFree) # overwrite memory with 0xFF before free
- trackAllocationSource = leakDetector
- cycleGC = true # (de)activate the cycle GC
- reallyDealloc = true # for debugging purposes this can be set to false
- reallyOsDealloc = true
- coalescRight = true
- coalescLeft = true
- logAlloc = false
- useCellIds = defined(nimCorruption)
- type
- PPointer = ptr pointer
- ByteArray = UncheckedArray[byte]
- PByte = ptr ByteArray
- PString = ptr string
- when declared(IntsPerTrunk):
- discard
- else:
- include bitmasks
- proc raiseOutOfMem() {.noinline.} =
- if outOfMemHook != nil: outOfMemHook()
- cstderr.rawWrite("out of memory\n")
- quit(1)
- when defined(boehmgc):
- include system / mm / boehm
- elif defined(gogc):
- include system / mm / go
- elif (defined(nogc) or defined(gcDestructors)) and defined(useMalloc):
- include system / mm / malloc
- when defined(nogc):
- proc GC_getStatistics(): string = ""
- proc newObj(typ: PNimType, size: int): pointer {.compilerproc.} =
- result = alloc0(size)
- proc newSeq(typ: PNimType, len: int): pointer {.compilerproc.} =
- result = newObj(typ, align(GenericSeqSize, typ.align) + len * typ.base.size)
- cast[PGenericSeq](result).len = len
- cast[PGenericSeq](result).reserved = len
- elif defined(nogc):
- include system / mm / none
- else:
- when not defined(gcRegions):
- include "system/alloc"
- when not usesDestructors:
- include "system/cellsets"
- when not leakDetector and not useCellIds and not defined(nimV2):
- sysAssert(sizeof(Cell) == sizeof(FreeCell), "sizeof FreeCell")
- when defined(gcRegions):
- # XXX due to bootstrapping reasons, we cannot use compileOption("gc", "stack") here
- include "system/gc_regions"
- elif defined(nimV2) or usesDestructors:
- when not defined(useNimRtl):
- var allocator {.rtlThreadVar.}: MemRegion
- instantiateForRegion(allocator)
- when defined(gcHooks):
- include "system/gc_hooks"
- elif defined(gcMarkAndSweep):
- # XXX use 'compileOption' here
- include "system/gc_ms"
- else:
- include "system/gc"
- when not declared(nimNewSeqOfCap) and not defined(nimSeqsV2):
- {.push overflowChecks: on.}
- proc nimNewSeqOfCap(typ: PNimType, cap: int): pointer {.compilerproc.} =
- when defined(gcRegions):
- let s = cap * typ.base.size # newStr already adds GenericSeqSize
- result = newStr(typ, s, ntfNoRefs notin typ.base.flags)
- else:
- let s = align(GenericSeqSize, typ.base.align) + cap * typ.base.size
- when declared(newObjNoInit):
- result = if ntfNoRefs in typ.base.flags: newObjNoInit(typ, s) else: newObj(typ, s)
- else:
- result = newObj(typ, s)
- cast[PGenericSeq](result).len = 0
- cast[PGenericSeq](result).reserved = cap
- {.pop.}
- {.pop.}
- when not declared(ForeignCell):
- type ForeignCell* = object
- data*: pointer
- proc protect*(x: pointer): ForeignCell = ForeignCell(data: x)
- proc dispose*(x: ForeignCell) = discard
- proc isNotForeign*(x: ForeignCell): bool = false
|