mirror of
https://github.com/nodemcu/nodemcu-firmware.git
synced 2025-01-16 20:52:57 +08:00
63 lines
2.0 KiB
Markdown
63 lines
2.0 KiB
Markdown
# rtcmem Module
|
|
The rtcmem module provides basic access to the RTC (Real Time Clock) memory.
|
|
|
|
The RTC in the ESP8266 contains memory registers which survive a deep sleep, making them highly useful for keeping state across sleep cycles. Some of this memory is reserved for system use, but 128 slots (each 32bit wide) are available for application use. This module provides read and write access to these.
|
|
|
|
Due to the very limited amount of memory available, there is no mechanism for arbitrating use of particular slots. It is up to the end user to be aware of which memory is used for what, and avoid conflicts. Note that some Lua modules lay claim to certain slots.
|
|
|
|
####See also
|
|
- rtctime module
|
|
- rtcfifo module
|
|
|
|
## rtcmem.read32()
|
|
|
|
Reads one or more 32bit values from RTC user memory.
|
|
|
|
####Syntax
|
|
`rtcmem.read32(idx [, num])`
|
|
|
|
####Parameters
|
|
- `idx`: The index to start reading from. Zero-based.
|
|
- `num`: Number of slots to read (default 1).
|
|
|
|
####Returns
|
|
The value(s) read from RTC user memory.
|
|
|
|
If `idx` is outside the valid range [0,127] this function returns nothing.
|
|
|
|
If `num` results in overstepping the end of available memory, the function only returns the data from the valid slots.
|
|
|
|
####Example
|
|
```lua
|
|
val = rtcmem.read32(0) -- Read the value in slot 0
|
|
val1, val2 = rtcmem.read32(42, 2) -- Read the values in slots 42 and 43
|
|
```
|
|
####See also
|
|
- `rtcmem.write32()`
|
|
___
|
|
## rtcmem.write32()
|
|
|
|
Writes one or more values to RTC user memory, starting at index `idx`.
|
|
|
|
Writing to indices outside the valid range [0,127] has no effect.
|
|
|
|
####Syntax
|
|
`rtcmem.write32(idx, val [, val2, ...])`
|
|
|
|
####Parameters
|
|
- `idx`: Index to start writing to. Auto-increments if multiple values are given. Zero-based.
|
|
- `val`: The (32bit) value to store.
|
|
- `val2...`: Additional values to store. Optional.
|
|
|
|
####Returns
|
|
`nil`
|
|
|
|
####Example
|
|
```lua
|
|
rtcmem.write32(0, 53) -- Store the value 53 in slot 0
|
|
rtcmem.write32(42, 2, 5, 7) -- Store the values 2, 5 and 7 into slots 42, 43 and 44, respectively.
|
|
```
|
|
####See also
|
|
- `rtcmem.read32()`
|
|
___
|