Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add hearbeat register #45

Open
wants to merge 6 commits into
base: main
Choose a base branch
from
Open
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
68 changes: 65 additions & 3 deletions Device.md
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ gantt
```


#### **`R_OPERATION_CTRL` (U16) – Operation mode configuration**
#### **`R_OPERATION_CTRL` (U8) – Operation mode configuration**

Address: `010`

Expand Down Expand Up @@ -221,7 +221,7 @@ a) Standby Mode and Active Mode are mandatory. Speed Mode is optional.
| 1 | Speed Mode. |
| 0.1 | A critical error occurred. Only a hardware reset or a new power up can remove the device from this Mode. |

* **ALIVE_EN [Bit 7]:** If set to 1, the device sends an `Event` Message with the `R_TIMESTAMP_SECONDS` content each second (i.e. Heartbeat). This allows the host to check that the device is alive. Although this is an optional feature, it’s strongly recommended to be implemented.
* **ALIVE_EN [Bit 7]:** If set to 1, the device sends an `Event` Message with the `R_HEARTBEAT` content each second. This allows the host to check that the status of the device periodically. Although this is an optional feature, it’s strongly recommended to be implemented.
bruno-f-cruz marked this conversation as resolved.
Show resolved Hide resolved



Expand Down Expand Up @@ -407,6 +407,64 @@ gantt
```
When the value of this register is above 0 (zero), the device’s timestamp will be offset by this amount. The register is sensitive to 500 microsecond increments. This register is non-volatile.


#### **`R_HEARTBEAT` (U16) – Heartbeat register reporting the current status of the device**

Address: `018`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we fix this address now? Or do we need to wait for merging #39 and #38 beforehand?

In general I guess this is an interesting question regarding numbering of newly proposed common registers, should the address be part of the proposal, or should we number them incrementally as they get merged on a first-come, first-served basis?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I dont think there is any requirement for registers to be sequential right now. Or at least in the protocol. I think that in general we should honor the "reserved" register of the PR in case people implemented a proof-of-concept already. But maybe there is a stronger reason to follow the sequence?


```mermaid
---
displayMode: compact
---
gantt
title R_HEARTBEAT (018)
dateFormat X
axisFormat %

section Bit
15 :bit15, 0, 1
14 :bit14, after bit15 , 2
13 :bit13, after bit14 , 3
12 :bit12, after bit13 , 4
11 :bit11, after bit12 , 5
10 :bit10, after bit11 , 6
9 :bit9, after bit10 , 7
9 :bit8, after bit9 , 8
7 :bit7, after bit8 , 9
6 :bit6, after bit7 , 10
5 :bit5, after bit6 , 11
4 :bit4, after bit5 , 12
3 :bit3, after bit4 , 13
2 :bit2, after bit3 , 14
1 :bit1, after bit2 , 15
0 :bit0, after bit1 , 16

section Id
IS_ACTIVE :id0, 15, 16
IS_ERROR_STATE :id1, 14, 15
IS_SYNCHRONIZED :id2, 13, 14

section Default
- :d7, 15, 16
- :d6, 14 , 15
- :d5, 13 , 14
```

> **Note**
>
> This register is read-only and is used to provide status information about the device. The bits are set by the device and sent through a period event. If enabled (via `R_OPERATION_CTRL` bit `ALIVE_EN`), the event will be periodically emitted at a rate of 1Hz, triggered by updates to the `R_TIMESTAMP_SECOND` register.


The status of the device is given by the following bits:


* **IS_STANDBY [Bit 0]:** If 1, the device will be in Standby Mode. Any other modes will be coded as 0. (See `R_OPERATION_CTRL` bit `OP_MODE` for more information).

* **IS_ERROR_STATE [Bit 1]:** This bit will be read as 1 if the device is in an error state. The implementation of an error state is expected largely implementation specific, however this state should be entered when the device is in a state where it cannot recover without manual intervention.
bruno-f-cruz marked this conversation as resolved.
Show resolved Hide resolved

* **IS_SYNCHRONIZED [Bit 3]:** If set to 1, the device is synchronized with the Harp Synchronization Clock. If the device is a clock generator (see `R_CLOCK_CONFIG` bit `CLK_GEN`), by definition, this bit will always be set to 1.


## Release notes:

- v0.2
Expand Down Expand Up @@ -452,4 +510,8 @@ When the value of this register is above 0 (zero), the device’s timestamp will

- v1.9.1
* Remove table of contents to avoid redundancy with doc generators.
* Minor improvements to clarity of introduction.
* Minor improvements to clarity of introduction.

- v1.9.2
* Add heartbeat register providing status information
* Fix typo in `OPERATION_CTRL` register data type (U16 -> U8)