• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# HiCollie Development
2
3
4## Overview
5
6HiCollie provides the software watchdog function. It provides a unified framework for fault detection and fault log generation to help you locate software timeout faults resulting from system service deadlock, application main thread blocking, and service process timeout.
7
8
9## Available APIs
10
11  **Table 1** Description of XCollieChecker APIs
12
13| API| Description|
14| -------- | -------- |
15| virtual void CheckBlock() | Provides the callback of the suspension detection result.<br>Input arguments: none<br>Output arguments: none<br>Return value: none|
16| virtual void CheckThreadBlock() | Provides the callback of the thread suspension detection result.<br>Input arguments: none<br>Output arguments: none<br>Return value: none|
17
18
19  **Table 2** Description of XCollie APIs
20
21| API| Description|
22| -------- | -------- |
23| void RegisterXCollieChecker(const sptr&lt;XCollieChecker&gt; &amp;checker, unsigned int type) | Registers the callback of the thread suspension detection result.<br>Input arguments:<br>- **checker**: pointer to the XCollieChecker instance.<br>- **type**: suspension detection type. Set it to **XCOLLIE_THREAD**.<br>Output arguments: none<br>Return value: none|
24| int SetTimer(const std::string &amp;name, unsigned int timeout, std::function&lt;void(void*)&gt; func, void *arg, unsigned int flag) | Adds timers.<br>Input arguments:<br>- **name**: timer name.<br>- **timeout**: timeout duration, in seconds.<br>- **func**: timeout callback.<br>- **arg**: pointer to the timeout callback.<br>- **flag**: timer operation type.<br>    - **XCOLLIE_FLAG_DEFAULT**: default flag, which is the combination of the other three options.<br>    - **XCOLLIE_FLAG_NOOP**: Calls only the timeout callback.<br>    - **XCOLLIE_FLAG_LOG**: Generates a timeout fault log.<br>    - **XCOLLIE_FLAG_RECOVERY**: Exits the process.<br>Output arguments: none<br>Return value: timer ID if the operation is successful; **-1** otherwise.|
25| bool UpdateTimer(int id, unsigned int timeout) | Updates timers.<br>Input arguments:<br>- **id**: timer ID.<br>- **timeout**: timeout duration, in seconds.<br>Output arguments: none<br>Return value: **true** if the operation is successful; **false** otherwise.|
26| void CancelTimer(int id) | Cancels a timer.<br>Input arguments:<br>- **id**: timer ID.<br>Output arguments: none<br>Return value: none|
27
28
29## How to Develop
30
31
32### Thread Suspension Monitoring
33
34This function requires you to implement two callback functions: **CheckBlock** and **CheckThreadBlock** of the **XCollieChecker** class. After the callbacks are implemented, you need to use the **RegisterXCollieChecker** function of the **XCollie** class to register their instances. The suspension monitoring thread periodically executes all successfully registered callbacks, checks the thread logic completion flag, and determines whether the service logic of any registered thread is suspended.
35
361. Develop the source code.
37     Include the **xcollie** header file in the source file.
38
39   ```
40   #include "xcollie.h"
41   ```
42
43   Add the following code to the service code:
44
45
46   ```
47   void MyXCollieChecker::CheckLock()
48   {
49       /* time consuming job */
50   }
51
52   void MyXCollieChecker::CheckThreadBlock()
53   {
54       /* time consuming job */
55   }
56
57   sptr<XCollieChecker> checker = new MyXCollieChecker("MyXCollieChecker");
58   XCollie::GetInstance().RegisterXCollieChecker(checker,
59       (XCOLLIE_LOCK | XCOLLIE_THREAD));
60   ......
61   ```
62
632. Configure compilation information. Specifically, add the subsystem SDK dependency to **BUILD.gn**.
64
65   ```
66   external_deps = [ "hiviewdfx:libxcollie" ]
67   ```
68
69
70### Timeout Monitoring
71
72You can add a maximum of 128 timers for a single process by using the **SetTimer** function. Adding timers will fail if the number of timers has reached the upper limit.
73
741. Develop the source code.
75     Include the **xcollie** header file in the source file.
76
77   ```
78   #include "xcollie.h"
79   ```
80
81     Add the code to add, update, and cancel timers.
82
83   ```
84   std::function<void(void *)> callback = [](void *args)
85   {
86       /* dump helpful information */
87   };
88
89   int id = XCollie::GetInstance().SetTimer("MyXCollieTimer", 10, callback ,nullptr, XCOLLIE_FLAG_LOG);
90   /* time consuming job */
91   XCollie::GetInstance().UpdateTimer(id, 5);
92   /* time consuming job */
93   XCollie::GetInstance().CancelTimer(id);
94   ......
95   ```
96
972. Configure compilation information. Specifically, add the subsystem SDK dependency to **BUILD.gn**.
98
99   ```
100   external_deps = [ "hiviewdfx:libxcollie" ]
101   ```
102