mirror of
https://github.com/nim-lang/Nim.git
synced 2025-12-28 17:04:41 +00:00
Add volatile load/store (#5263)
Adds volatile load/store capability to the impure part of the standard library. Note that this currently only supports numerical types. Should resolve https://github.com/nim-lang/Nim/issues/3382
This commit is contained in:
committed by
Andreas Rumpf
parent
1fa3a9dac2
commit
74ae66ddbc
30
lib/pure/volatile.nim
Normal file
30
lib/pure/volatile.nim
Normal file
@@ -0,0 +1,30 @@
|
||||
#
|
||||
#
|
||||
# Nim's Runtime Library
|
||||
# (c) Copyright 2017 Jeff Ciesielski
|
||||
#
|
||||
# See the file "copying.txt", included in this
|
||||
# distribution, for details about the copyright.
|
||||
#
|
||||
|
||||
## This module contains code for generating volatile loads and stores,
|
||||
## which are useful in embedded and systems programming.
|
||||
|
||||
template volatileLoad*[T](src: ptr T): T =
|
||||
## Generates a volatile load of the value stored in the container `src`.
|
||||
## Note that this only effects code generation on `C` like backends
|
||||
when defined(js):
|
||||
src[]
|
||||
else:
|
||||
var res: T
|
||||
{.emit: [res, " = (*(", type(src[]), " volatile*)", src, ");"].}
|
||||
res
|
||||
|
||||
template volatileStore*[T](dest: ptr T, val: T) =
|
||||
## Generates a volatile store into the container `dest` of the value
|
||||
## `val`. Note that this only effects code generation on `C` like
|
||||
## backends
|
||||
when defined(js):
|
||||
dest[] = val
|
||||
else:
|
||||
{.emit: ["*((", type(dest[]), " volatile*)(", dest, ")) = ", val, ";"].}
|
||||
Reference in New Issue
Block a user