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:
Jeff Ciesielski
2017-01-25 14:02:19 -05:00
committed by Andreas Rumpf
parent 1fa3a9dac2
commit 74ae66ddbc

30
lib/pure/volatile.nim Normal file
View 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, ";"].}