xref: /nrf52832-nimble/packages/NimBLE-latest/porting/examples/linux/main.c (revision 042d53a763ad75cb1465103098bb88c245d95138)
1*042d53a7SEvalZero /*
2*042d53a7SEvalZero  * Licensed to the Apache Software Foundation (ASF) under one
3*042d53a7SEvalZero  * or more contributor license agreements.  See the NOTICE file
4*042d53a7SEvalZero  * distributed with this work for additional information
5*042d53a7SEvalZero  * regarding copyright ownership.  The ASF licenses this file
6*042d53a7SEvalZero  * to you under the Apache License, Version 2.0 (the
7*042d53a7SEvalZero  * "License"); you may not use this file except in compliance
8*042d53a7SEvalZero  * with the License.  You may obtain a copy of the License at
9*042d53a7SEvalZero  *
10*042d53a7SEvalZero  *  http://www.apache.org/licenses/LICENSE-2.0
11*042d53a7SEvalZero  *
12*042d53a7SEvalZero  * Unless required by applicable law or agreed to in writing,
13*042d53a7SEvalZero  * software distributed under the License is distributed on an
14*042d53a7SEvalZero  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15*042d53a7SEvalZero  * KIND, either express or implied.  See the License for the
16*042d53a7SEvalZero  * specific language governing permissions and limitations
17*042d53a7SEvalZero  * under the License.
18*042d53a7SEvalZero  */
19*042d53a7SEvalZero 
20*042d53a7SEvalZero #include <stdbool.h>
21*042d53a7SEvalZero #include <stdint.h>
22*042d53a7SEvalZero 
23*042d53a7SEvalZero #include <pthread.h>
24*042d53a7SEvalZero #include "nimble/nimble_npl.h"
25*042d53a7SEvalZero #include "nimble/nimble_port.h"
26*042d53a7SEvalZero 
27*042d53a7SEvalZero #include "services/gap/ble_svc_gap.h"
28*042d53a7SEvalZero #include "services/gatt/ble_svc_gatt.h"
29*042d53a7SEvalZero #include "services/ans/ble_svc_ans.h"
30*042d53a7SEvalZero #include "services/ias/ble_svc_ias.h"
31*042d53a7SEvalZero #include "services/lls/ble_svc_lls.h"
32*042d53a7SEvalZero #include "services/tps/ble_svc_tps.h"
33*042d53a7SEvalZero 
34*042d53a7SEvalZero static struct ble_npl_task s_task_host;
35*042d53a7SEvalZero static struct ble_npl_task s_task_hci;
36*042d53a7SEvalZero 
37*042d53a7SEvalZero void nimble_host_task(void *param);
38*042d53a7SEvalZero void ble_hci_sock_ack_handler(void *param);
39*042d53a7SEvalZero void ble_hci_sock_init(void);
40*042d53a7SEvalZero 
41*042d53a7SEvalZero #define TASK_DEFAULT_PRIORITY       1
42*042d53a7SEvalZero #define TASK_DEFAULT_STACK          NULL
43*042d53a7SEvalZero #define TASK_DEFAULT_STACK_SIZE     400
44*042d53a7SEvalZero 
ble_hci_sock_task(void * param)45*042d53a7SEvalZero void *ble_hci_sock_task(void *param)
46*042d53a7SEvalZero {
47*042d53a7SEvalZero     ble_hci_sock_ack_handler(param);
48*042d53a7SEvalZero     return NULL;
49*042d53a7SEvalZero }
50*042d53a7SEvalZero 
ble_host_task(void * param)51*042d53a7SEvalZero void *ble_host_task(void *param)
52*042d53a7SEvalZero {
53*042d53a7SEvalZero     nimble_host_task(param);
54*042d53a7SEvalZero     return NULL;
55*042d53a7SEvalZero }
56*042d53a7SEvalZero 
main(void)57*042d53a7SEvalZero int main(void)
58*042d53a7SEvalZero {
59*042d53a7SEvalZero     ble_hci_sock_init();
60*042d53a7SEvalZero     nimble_port_init();
61*042d53a7SEvalZero 
62*042d53a7SEvalZero     /* This example provides GATT Alert service */
63*042d53a7SEvalZero     ble_svc_gap_init();
64*042d53a7SEvalZero     ble_svc_gatt_init();
65*042d53a7SEvalZero     ble_svc_ans_init();
66*042d53a7SEvalZero     ble_svc_ias_init();
67*042d53a7SEvalZero     ble_svc_lls_init();
68*042d53a7SEvalZero     ble_svc_tps_init();
69*042d53a7SEvalZero 
70*042d53a7SEvalZero     /* XXX Need to have template for store */
71*042d53a7SEvalZero     ble_store_ram_init();
72*042d53a7SEvalZero 
73*042d53a7SEvalZero     ble_npl_task_init(&s_task_hci, "hci_sock", ble_hci_sock_task,
74*042d53a7SEvalZero                       NULL, TASK_DEFAULT_PRIORITY, BLE_NPL_WAIT_FOREVER,
75*042d53a7SEvalZero                       TASK_DEFAULT_STACK, TASK_DEFAULT_STACK_SIZE);
76*042d53a7SEvalZero 
77*042d53a7SEvalZero     /* Create task which handles default event queue for host stack. */
78*042d53a7SEvalZero     ble_npl_task_init(&s_task_host, "ble_host", ble_host_task,
79*042d53a7SEvalZero                       NULL, TASK_DEFAULT_PRIORITY, BLE_NPL_WAIT_FOREVER,
80*042d53a7SEvalZero                       TASK_DEFAULT_STACK, TASK_DEFAULT_STACK_SIZE);
81*042d53a7SEvalZero 
82*042d53a7SEvalZero     int ret = 0;
83*042d53a7SEvalZero     pthread_exit(&ret);
84*042d53a7SEvalZero 
85*042d53a7SEvalZero     while (true)
86*042d53a7SEvalZero     {
87*042d53a7SEvalZero         pthread_yield();
88*042d53a7SEvalZero     }
89*042d53a7SEvalZero }
90