1 /* main.c - Application main entry point */
2 
3 /*
4  * Copyright (c) 2017 Intel Corporation
5  *
6  * SPDX-License-Identifier: Apache-2.0
7  */
8 
9 #include <zephyr/sys/printk.h>
10 
11 #include <zephyr/bluetooth/bluetooth.h>
12 #include <zephyr/bluetooth/mesh.h>
13 
14 #define MAX_FAULT 24
15 
16 static bool has_reg_fault = true;
17 
fault_get_cur(const struct bt_mesh_model * model,uint8_t * test_id,uint16_t * company_id,uint8_t * faults,uint8_t * fault_count)18 static int fault_get_cur(const struct bt_mesh_model *model, uint8_t *test_id,
19 			 uint16_t *company_id, uint8_t *faults, uint8_t *fault_count)
20 {
21 	uint8_t reg_faults[MAX_FAULT] = { [0 ... (MAX_FAULT - 1)] = 0xff };
22 
23 	printk("fault_get_cur() has_reg_fault %u\n", has_reg_fault);
24 
25 	*test_id = 0x00;
26 	*company_id = BT_COMP_ID_LF;
27 	memcpy(faults, reg_faults, sizeof(reg_faults));
28 	*fault_count = sizeof(reg_faults);
29 
30 	return 0;
31 }
32 
fault_get_reg(const struct bt_mesh_model * model,uint16_t company_id,uint8_t * test_id,uint8_t * faults,uint8_t * fault_count)33 static int fault_get_reg(const struct bt_mesh_model *model, uint16_t company_id,
34 			 uint8_t *test_id, uint8_t *faults, uint8_t *fault_count)
35 {
36 	if (company_id != BT_COMP_ID_LF) {
37 		return -EINVAL;
38 	}
39 
40 	printk("fault_get_reg() has_reg_fault %u\n", has_reg_fault);
41 
42 	*test_id = 0x00;
43 
44 	if (has_reg_fault) {
45 		uint8_t reg_faults[MAX_FAULT] = { [0 ... (MAX_FAULT - 1)] = 0xff };
46 
47 		memcpy(faults, reg_faults, sizeof(reg_faults));
48 		*fault_count = sizeof(reg_faults);
49 	} else {
50 		*fault_count = 0U;
51 	}
52 
53 	return 0;
54 }
55 
fault_clear(const struct bt_mesh_model * model,uint16_t company_id)56 static int fault_clear(const struct bt_mesh_model *model, uint16_t company_id)
57 {
58 	if (company_id != BT_COMP_ID_LF) {
59 		return -EINVAL;
60 	}
61 
62 	has_reg_fault = false;
63 
64 	return 0;
65 }
66 
fault_test(const struct bt_mesh_model * model,uint8_t test_id,uint16_t company_id)67 static int fault_test(const struct bt_mesh_model *model, uint8_t test_id,
68 		      uint16_t company_id)
69 {
70 	if (company_id != BT_COMP_ID_LF) {
71 		return -EINVAL;
72 	}
73 
74 	has_reg_fault = true;
75 	bt_mesh_health_srv_fault_update(bt_mesh_model_elem(model));
76 
77 	return 0;
78 }
79 
80 static const struct bt_mesh_health_srv_cb health_srv_cb = {
81 	.fault_get_cur = fault_get_cur,
82 	.fault_get_reg = fault_get_reg,
83 	.fault_clear = fault_clear,
84 	.fault_test = fault_test,
85 };
86 
87 static struct bt_mesh_health_srv health_srv = {
88 	.cb = &health_srv_cb,
89 };
90 
91 BT_MESH_HEALTH_PUB_DEFINE(health_pub, MAX_FAULT);
92 
93 static const struct bt_mesh_model root_models[] = {
94 	BT_MESH_MODEL_CFG_SRV,
95 	BT_MESH_MODEL_HEALTH_SRV(&health_srv, &health_pub),
96 };
97 
vnd_publish(const struct bt_mesh_model * mod)98 static int vnd_publish(const struct bt_mesh_model *mod)
99 {
100 	printk("Vendor publish\n");
101 	return 0;
102 }
103 
104 BT_MESH_MODEL_PUB_DEFINE(vnd_pub, vnd_publish, 4);
105 
106 BT_MESH_MODEL_PUB_DEFINE(vnd_pub2, NULL, 4);
107 
108 static const struct bt_mesh_model_op vnd_ops[] = {
109 	BT_MESH_MODEL_OP_END,
110 };
111 
112 static const struct bt_mesh_model vnd_models[] = {
113 	BT_MESH_MODEL_VND(BT_COMP_ID_LF, 0x1234, vnd_ops, &vnd_pub, NULL),
114 	BT_MESH_MODEL_VND(BT_COMP_ID_LF, 0x4321, vnd_ops, &vnd_pub2, NULL),
115 };
116 
117 static const struct bt_mesh_elem elements[] = {
118 	BT_MESH_ELEM(0, root_models, vnd_models),
119 };
120 
121 static const struct bt_mesh_comp comp = {
122 	.cid = BT_COMP_ID_LF,
123 	.elem = elements,
124 	.elem_count = ARRAY_SIZE(elements),
125 };
126 
127 #if 0
128 static int output_number(bt_mesh_output_action_t action, uint32_t number)
129 {
130 	printk("OOB Number: %u\n", number);
131 
132 	board_output_number(action, number);
133 
134 	return 0;
135 }
136 #endif
137 
prov_complete(uint16_t net_idx,uint16_t addr)138 static void prov_complete(uint16_t net_idx, uint16_t addr)
139 {
140 	if (IS_ENABLED(CONFIG_BT_MESH_IV_UPDATE_TEST)) {
141 		bt_mesh_iv_update_test(true);
142 	}
143 }
144 
prov_reset(void)145 static void prov_reset(void)
146 {
147 	bt_mesh_prov_enable(BT_MESH_PROV_ADV | BT_MESH_PROV_GATT);
148 }
149 
150 static const uint8_t dev_uuid[16] = { 0xdd, 0xdd };
151 
152 static const struct bt_mesh_prov prov = {
153 	.uuid = dev_uuid,
154 #if 0
155 	.output_size = 4,
156 	.output_actions = BT_MESH_DISPLAY_NUMBER,
157 	.output_number = output_number,
158 #endif
159 	.complete = prov_complete,
160 	.reset = prov_reset,
161 };
162 
bt_ready(int err)163 static void bt_ready(int err)
164 {
165 	if (err) {
166 		printk("Bluetooth init failed (err %d)\n", err);
167 		return;
168 	}
169 
170 	printk("Bluetooth initialized\n");
171 
172 	err = bt_mesh_init(&prov, &comp);
173 	if (err) {
174 		printk("Initializing mesh failed (err %d)\n", err);
175 		return;
176 	}
177 
178 	/* Initialize publication messages with dummy data */
179 	net_buf_simple_add_le32(vnd_pub.msg, UINT32_MAX);
180 	net_buf_simple_add_le32(vnd_pub2.msg, UINT32_MAX);
181 
182 	bt_mesh_prov_enable(BT_MESH_PROV_ADV | BT_MESH_PROV_GATT);
183 
184 	printk("Mesh initialized\n");
185 }
186 
main(void)187 int main(void)
188 {
189 	int err;
190 
191 	printk("Initializing...\n");
192 
193 	/* Initialize the Bluetooth Subsystem */
194 	err = bt_enable(bt_ready);
195 	if (err) {
196 		printk("Bluetooth init failed (err %d)\n", err);
197 	}
198 	return 0;
199 }
200