mirror of
https://github.com/nim-lang/Nim.git
synced 2025-12-28 17:04:41 +00:00
* refactorings in preparation for ropes elimination of the C code generator; mostly the usual ': Rope' -> 'result: var Rope' rewrite * rewrote ccgcalls.nim * refactored ccgexprs.nim * ccgliterals: refactoring * refactoring: code dealing with name mangling * refactoring: getRecordFieldsAux * ropes are strings (insert obscene joke here) * optimize JS code gen * optimizations and code improvements * more optimizations * final cleanups
60 lines
2.3 KiB
Nim
60 lines
2.3 KiB
Nim
#
|
|
#
|
|
# The Nim Compiler
|
|
# (c) Copyright 2012 Andreas Rumpf
|
|
#
|
|
# See the file "copying.txt", included in this
|
|
# distribution, for details about the copyright.
|
|
#
|
|
|
|
## Thread var support for architectures that lack native support for
|
|
## thread local storage.
|
|
|
|
# included from cgen.nim
|
|
|
|
proc emulatedThreadVars(conf: ConfigRef): bool =
|
|
result = {optThreads, optTlsEmulation} <= conf.globalOptions
|
|
|
|
proc accessThreadLocalVar(p: BProc, s: PSym) =
|
|
if emulatedThreadVars(p.config) and threadVarAccessed notin p.flags:
|
|
p.flags.incl threadVarAccessed
|
|
incl p.module.flags, usesThreadVars
|
|
p.procSec(cpsLocals).addf("\tNimThreadVars* NimTV_;$n", [])
|
|
p.procSec(cpsInit).add(
|
|
ropecg(p.module, "\tNimTV_ = (NimThreadVars*) #GetThreadLocalVars();$n", []))
|
|
|
|
proc declareThreadVar(m: BModule, s: PSym, isExtern: bool) =
|
|
if emulatedThreadVars(m.config):
|
|
# we gather all thread locals var into a struct; we need to allocate
|
|
# storage for that somehow, can't use the thread local storage
|
|
# allocator for it :-(
|
|
if not containsOrIncl(m.g.nimtvDeclared, s.id):
|
|
m.g.nimtvDeps.add(s.loc.t)
|
|
m.g.nimtv.addf("$1 $2;$n", [getTypeDesc(m, s.loc.t), s.loc.r])
|
|
else:
|
|
if isExtern: m.s[cfsVars].add("extern ")
|
|
elif lfExportLib in s.loc.flags: m.s[cfsVars].add("N_LIB_EXPORT_VAR ")
|
|
else: m.s[cfsVars].add("N_LIB_PRIVATE ")
|
|
if optThreads in m.config.globalOptions:
|
|
let sym = s.typ.sym
|
|
if sym != nil and sfCppNonPod in sym.flags:
|
|
m.s[cfsVars].add("NIM_THREAD_LOCAL ")
|
|
else: m.s[cfsVars].add("NIM_THREADVAR ")
|
|
m.s[cfsVars].add(getTypeDesc(m, s.loc.t))
|
|
m.s[cfsVars].addf(" $1;$n", [s.loc.r])
|
|
|
|
proc generateThreadLocalStorage(m: BModule) =
|
|
if m.g.nimtv != "" and (usesThreadVars in m.flags or sfMainModule in m.module.flags):
|
|
for t in items(m.g.nimtvDeps): discard getTypeDesc(m, t)
|
|
finishTypeDescriptions(m)
|
|
m.s[cfsSeqTypes].addf("typedef struct {$1} NimThreadVars;$n", [m.g.nimtv])
|
|
|
|
proc generateThreadVarsSize(m: BModule) =
|
|
if m.g.nimtv != "":
|
|
let externc = if m.config.backend == backendCpp or
|
|
sfCompileToCpp in m.module.flags: "extern \"C\" "
|
|
else: ""
|
|
m.s[cfsProcs].addf(
|
|
"$#NI NimThreadVarsSize(){return (NI)sizeof(NimThreadVars);}$n",
|
|
[externc.rope])
|