nRF5 SDK for Mesh v5.0.0
health_client.h
1 /* Copyright (c) 2010 - 2020, Nordic Semiconductor ASA
2  * All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without modification,
5  * are permitted provided that the following conditions are met:
6  *
7  * 1. Redistributions of source code must retain the above copyright notice, this
8  * list of conditions and the following disclaimer.
9  *
10  * 2. Redistributions in binary form, except as embedded into a Nordic
11  * Semiconductor ASA integrated circuit in a product or a software update for
12  * such product, must reproduce the above copyright notice, this list of
13  * conditions and the following disclaimer in the documentation and/or other
14  * materials provided with the distribution.
15  *
16  * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
17  * contributors may be used to endorse or promote products derived from this
18  * software without specific prior written permission.
19  *
20  * 4. This software, with or without modification, must only be used with a
21  * Nordic Semiconductor ASA integrated circuit.
22  *
23  * 5. Any software provided in binary form under this license must not be reverse
24  * engineered, decompiled, modified and/or disassembled.
25  *
26  * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
27  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
28  * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
29  * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
30  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
32  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
33  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
35  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  */
37 
38 #ifndef HEALTH_CLIENT_H__
39 #define HEALTH_CLIENT_H__
40 
41 #include <stdbool.h>
42 #include <stdint.h>
43 
44 #include "access.h"
45 #include "device_state_manager.h"
46 #include "health_common.h"
47 
56 #ifndef HEALTH_CLIENT_ACKED_TRANSACTION_TIMEOUT
57 #define HEALTH_CLIENT_ACKED_TRANSACTION_TIMEOUT (SEC_TO_US(60))
58 #endif
59 
61 typedef struct __health_client_t health_client_t;
62 
64 typedef enum
65 {
73 
75 typedef struct
76 {
77  uint8_t test_id;
78  uint16_t company_id;
80  const uint8_t * p_fault_array;
83 
85 typedef struct
86 {
93 
95 typedef struct
96 {
97  uint8_t attention;
99 
101 typedef struct
102 {
105  union {
109  } data;
111 
120 typedef void (*health_client_evt_cb_t)(const health_client_t * p_client, const health_client_evt_t * p_event);
121 
124 {
128  uint8_t * p_buffer;
129 };
130 
142 uint32_t health_client_fault_get(health_client_t * p_client, uint16_t company_id);
143 
156 uint32_t health_client_fault_clear(health_client_t * p_client, uint16_t company_id, bool acked);
157 
171 uint32_t health_client_fault_test(health_client_t * p_client, uint16_t company_id, uint8_t test_id, bool acked);
172 
183 uint32_t health_client_period_get(health_client_t * p_client);
184 
197 uint32_t health_client_period_set(health_client_t * p_client, uint8_t fast_period_divisor, bool acked);
198 
209 uint32_t health_client_attention_get(health_client_t * p_client);
210 
223 uint32_t health_client_attention_set(health_client_t * p_client, uint8_t attention_timer, bool acked);
224 
238 uint32_t health_client_init(health_client_t * p_client, uint16_t element_index, health_client_evt_cb_t evt_handler);
239 
245 void health_client_pending_msg_cancel(health_client_t * p_client);
246 
249 #endif
250 
health_client_evt_period_status_t period_status
Period status data for the Period Status message.
const uint8_t * p_fault_array
Fault array.
Definition: health_client.h:80
A Health Current Status message was received.
Definition: health_client.h:66
uint16_t access_model_handle_t
Access layer handle type.
Definition: access.h:162
health_client_evt_type_t
Message types for messages received by the health client.
Definition: health_client.h:64
A Health Attention Status message was received.
Definition: health_client.h:69
uint8_t attention
Attention timer.
Definition: health_client.h:97
uint8_t fault_array_length
Length of the fault array.
Definition: health_client.h:79
uint16_t company_id
Company ID.
Definition: health_client.h:78
uint8_t fast_period_divisor
Divisor for the publishing interval of the Current Status message in a server.
Definition: health_client.h:91
uint32_t health_client_init(health_client_t *p_client, uint16_t element_index, health_client_evt_cb_t evt_handler)
Initializes a health client instance.
A Health Fault Status message was received.
Definition: health_client.h:67
bool waiting_for_reply
Set to true if the client is currently waiting for a reply to a transmitted message.
uint32_t health_client_period_get(health_client_t *p_client)
Gets the current health period state of an element.
uint8_t * p_buffer
Buffer used to hold an outbound message.
void health_client_pending_msg_cancel(health_client_t *p_client)
Cancel any ongoing reliable message transfer.
health_client_evt_fault_status_t fault_status
Fault status data for the Current Status and Fault Status messages.
health_client_evt_cb_t event_handler
Event handler.
A reliable transfer timed out.
Definition: health_client.h:70
Attention status event.
Definition: health_client.h:95
A reliable transfer has been cancelled.
Definition: health_client.h:71
health_client_evt_type_t type
Type of the event.
uint32_t health_client_fault_test(health_client_t *p_client, uint16_t company_id, uint8_t test_id, bool acked)
Requests a server to run a self-test.
Metadata for received messages.
Definition: access.h:196
Health client instance structure.
uint32_t health_client_fault_clear(health_client_t *p_client, uint16_t company_id, bool acked)
Clears the fault array for a specified company ID.
const access_message_rx_meta_t * p_meta_data
Meta data for the received message.
health_client_evt_attention_status_t attention_status
Attention status data for the Attention Status message.
void(* health_client_evt_cb_t)(const health_client_t *p_client, const health_client_evt_t *p_event)
Event callback function type.
Attention status event.
uint32_t health_client_period_set(health_client_t *p_client, uint8_t fast_period_divisor, bool acked)
Sets the health period state of an element.
A Health Period Status message was received.
Definition: health_client.h:68
uint8_t test_id
Most recent test run by the peer device.
Definition: health_client.h:77
uint32_t health_client_attention_get(health_client_t *p_client)
Gets the attention timer from a server.
const access_message_rx_meta_t * p_meta_data
Meta data for the incoming Fault Status or Current Status message.
Definition: health_client.h:81
uint32_t health_client_attention_set(health_client_t *p_client, uint8_t attention_timer, bool acked)
Sets the attention timer on a server.
access_model_handle_t model_handle
Model handle.
uint32_t health_client_fault_get(health_client_t *p_client, uint16_t company_id)
Requests the current fault status from a server.

Documentation feedback | Developer Zone | Subscribe | Updated