nRF5 SDK for Mesh v1.0.1
health_client.h
1 /* Copyright (c) 2010 - 2017, 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 typedef struct __health_client_t health_client_t;
57 
59 typedef enum
60 {
67 
69 typedef struct
70 {
71  uint8_t test_id;
72  uint16_t company_id;
74  const uint8_t * p_fault_array;
77 
79 typedef struct
80 {
87 
89 typedef struct
90 {
91  uint8_t attention;
93 
95 typedef struct
96 {
99  union {
103  } data;
105 
114 typedef void (*health_client_evt_cb_t)(const health_client_t * p_client, const health_client_evt_t * p_event);
115 
118 {
122  uint8_t * p_buffer;
123 };
124 
134 uint32_t health_client_fault_get(health_client_t * p_client, uint16_t company_id);
135 
146 uint32_t health_client_fault_clear(health_client_t * p_client, uint16_t company_id, bool acked);
147 
159 uint32_t health_client_fault_test(health_client_t * p_client, uint16_t company_id, uint8_t test_id, bool acked);
160 
169 uint32_t health_client_period_get(health_client_t * p_client);
170 
181 uint32_t health_client_period_set(health_client_t * p_client, uint8_t fast_period_divisor, bool acked);
182 
191 uint32_t health_client_attention_get(health_client_t * p_client);
192 
203 uint32_t health_client_attention_set(health_client_t * p_client, uint8_t attention_timer, bool acked);
204 
218 uint32_t health_client_init(health_client_t * p_client, uint16_t element_index, health_client_evt_cb_t evt_handler);
219 
222 #endif
223 
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:74
A Health Current Status message was received.
Definition: health_client.h:61
uint16_t access_model_handle_t
Access layer handle type.
Definition: access.h:155
health_client_evt_type_t
Message types for messages received by the health client.
Definition: health_client.h:59
A Health Attention Status message was received.
Definition: health_client.h:64
uint8_t attention
Attention timer.
Definition: health_client.h:91
uint8_t fault_array_length
Length of the fault array.
Definition: health_client.h:73
uint16_t company_id
Company ID.
Definition: health_client.h:72
uint8_t fast_period_divisor
Divisor for the publishing interval of the Current Status message in a server.
Definition: health_client.h:85
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:62
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.
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:65
Attention status event.
Definition: health_client.h:89
health_client_evt_type_t type
Type of the event.
Definition: health_client.h:97
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:189
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.
Definition: health_client.h:98
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.
Definition: health_client.h:95
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:63
uint8_t test_id
Most recent test run by the peer device.
Definition: health_client.h:71
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:75
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