annotate Discovery/Src/tInfoLogger.c @ 1033:5f66e44d69f0 Puls_Integration

Added functionality needed for subscription of standard Bluetooth pulse service notifications
author Ideenmodellierer
date Sat, 02 Aug 2025 22:42:51 +0200
parents cd4561c33758
children 195bfbdf961d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1031
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
1 ///////////////////////////////////////////////////////////////////////////////
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
2 /// -*- coding: UTF-8 -*-
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
3 ///
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
4 /// \file Discovery/Src/tInfoLogger.c
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
5 /// \brief Show data which is received / send through UART interface
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
6 /// \author heinrichs weikamp gmbh
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
7 /// \date 23-Feb-2015
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
8 ///
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
9 /// \details
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
10 ///
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
11 /// $Id$
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
12 ///////////////////////////////////////////////////////////////////////////////
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
13 /// \par Copyright (c) 2014-2018 Heinrichs Weikamp gmbh
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
14 ///
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
15 /// This program is free software: you can redistribute it and/or modify
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
16 /// it under the terms of the GNU General Public License as published by
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
17 /// the Free Software Foundation, either version 3 of the License, or
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
18 /// (at your option) any later version.
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
19 ///
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
20 /// This program is distributed in the hope that it will be useful,
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
21 /// but WITHOUT ANY WARRANTY; without even the implied warranty of
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
22 /// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
23 /// GNU General Public License for more details.
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
24 ///
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
25 /// You should have received a copy of the GNU General Public License
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
26 /// along with this program. If not, see <http://www.gnu.org/licenses/>.
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
27 //////////////////////////////////////////////////////////////////////////////
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
28
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
29 /* Includes ------------------------------------------------------------------*/
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
30
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
31 #include "gfx_engine.h"
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
32 #include "gfx_fonts.h"
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
33 #include "tHome.h"
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
34 #include "tInfo.h"
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
35 #include "tInfoLogger.h"
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
36 #include "tMenuEdit.h"
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
37 #include "data_exchange_main.h"
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
38
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
39 #include <string.h>
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
40 #include <inttypes.h>
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
41
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
42
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
43 /* Private variables ---------------------------------------------------------*/
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
44 static uint8_t lines[MAX_LOGGER_LINES][MAX_CHAR_PER_LINE + LINE_HEADER_BYTES];
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
45 static uint8_t lineWriteIndex = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
46 static uint8_t lineReadIndex = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
47 static uint32_t receivedLinesCount = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
48
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
49 static uint32_t loggerUpdateTime = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
50 static uint32_t previousGlobalState = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
51
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
52 /* Exported functions --------------------------------------------------------*/
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
53
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
54
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
55 void InfoLogger_writeLine(uint8_t* pLine,uint8_t lineLength,uint8_t direction)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
56 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
57 uint8_t LogIndex = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
58
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
59 if(lineLength <= MAX_CHAR_PER_LINE)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
60 {
1033
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
61 memset(&lines[lineWriteIndex][0],0, (MAX_CHAR_PER_LINE + LINE_HEADER_BYTES));
1031
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
62 if(direction == LOG_TX_LINE)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
63 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
64 lines[lineWriteIndex][LogIndex] = '\002'; /* align right */
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
65 LogIndex++;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
66 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
67 memcpy(&lines[lineWriteIndex][LogIndex],pLine,lineLength);
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
68 lineWriteIndex++;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
69 if(lineWriteIndex == MAX_LOGGER_LINES)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
70 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
71 lineWriteIndex = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
72 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
73 receivedLinesCount++;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
74 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
75 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
76
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
77 uint8_t InfoLogger_isUpdated()
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
78 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
79 uint8_t ret = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
80 if(lineReadIndex != lineWriteIndex)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
81 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
82 ret = 1;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
83 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
84 return ret;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
85 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
86
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
87 void openInfo_Logger()
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
88 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
89 previousGlobalState = get_globalState();
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
90 set_globalState(StILOGGER);
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
91
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
92 loggerUpdateTime = HAL_GetTick();
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
93
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
94 // lineWriteIndex = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
95 // receivedLinesCount = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
96 // memset(lines,0,sizeof(lines));
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
97 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
98
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
99 extern void refresh_Heartbeat(void);
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
100 void refreshInfo_Logger(GFX_DrawCfgScreen s)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
101 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
102 uint8_t index = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
103 char text[31];
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
104 uint8_t displayLine = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
105 uint8_t color = CLUT_Font020;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
106
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
107 text[0] = '\001';
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
108 text[1] = TXT_PreDive;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
109 text[2] = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
110
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
111 tInfo_write_content_simple( 30, 770, ME_Y_LINE_BASE, &FontT48, text, CLUT_MenuPageHardware);
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
112
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
113
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
114 if(InfoLogger_isUpdated())
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
115 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
116 loggerUpdateTime = HAL_GetTick();
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
117 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
118 if(receivedLinesCount > MAX_LOGGER_LINES)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
119 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
120 displayLine = MAX_LOGGER_LINES-1;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
121 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
122 else
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
123 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
124 displayLine = lineWriteIndex;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
125 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
126
1033
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
127 if(lineReadIndex != lineWriteIndex) /* needed for isUpdated function */
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
128 {
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
129 lineReadIndex++;
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
130 if(lineReadIndex == MAX_LOGGER_LINES)
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
131 {
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
132 lineReadIndex = 0;
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
133 }
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
134 }
1031
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
135 while (index < displayLine)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
136 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
137 color = CLUT_Font020;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
138 if(lines[index][0] == '\002')
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
139 {
1033
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
140 color = CLUT_NiceGreen;
1031
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
141 }
1033
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
142 if(lineReadIndex == index)
1031
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
143 {
1033
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
144 color = CLUT_NiceBlue;
1031
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
145 }
1033
5f66e44d69f0 Added functionality needed for subscription of standard Bluetooth pulse service notifications
Ideenmodellierer
parents: 1031
diff changeset
146 tInfo_write_content_simple( 30, 770, 60 + (index * 30), &FontT24, (char*)lines[index], color);
1031
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
147
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
148 if(lineReadIndex != lineWriteIndex) /* needed for isUpdated function */
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
149 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
150 lineReadIndex++;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
151 if(lineReadIndex == MAX_LOGGER_LINES)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
152 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
153 lineReadIndex = 0;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
154 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
155 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
156 index++;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
157 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
158
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
159
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
160 if((time_elapsed_ms(loggerUpdateTime, HAL_GetTick()) > 20000))
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
161 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
162 set_globalState(previousGlobalState); /* restore state which was active before log data was received */
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
163 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
164 refresh_Heartbeat();
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
165 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
166
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
167 void sendActionToInfoLogger(uint8_t sendAction)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
168 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
169 switch(sendAction)
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
170 {
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
171 case ACTION_BUTTON_BACK:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
172 // exitInfo();
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
173 exitMenuEdit_to_Menu_with_Menu_Update();
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
174 break;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
175
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
176 case ACTION_BUTTON_ENTER:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
177 break;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
178 case ACTION_BUTTON_NEXT:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
179 break;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
180 case ACTION_TIMEOUT:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
181 case ACTION_MODE_CHANGE:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
182 case ACTION_IDLE_TICK:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
183 case ACTION_IDLE_SECOND:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
184 default:
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
185 break;
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
186 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
187 }
cd4561c33758 New Logger View:
Ideenmodellierer
parents:
diff changeset
188