annotate Discovery/Src/logbook.c @ 411:e908b894f107 Improment_NVM

Bugfix: Limit log length in case of corrupted sample storage: In case of a sample address reset the header would have a smaler end address as the start address. As result the length becomes very long and download e.g. via Subsurface, would seem to hang. To solve this the number of sample bytes in this use case has been limited. Tested with subsurface only. After change dowload of logs is possible again. Nevertheless the sampledata will be lost. Minor change: "header" was used as global as well as as local variable => changed name for global variant to gheader.
author ideenmodellierer
date Mon, 13 Jan 2020 20:27:57 +0100
parents 8e62f4701676
children 514e6269256f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
2 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
3 * @copyright heinrichs weikamp
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
4 * @file logbook.c
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
5 * @author heinrichs weikamp gmbh and heinrichs weikamp gmbh
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
6 * @date 22-Apr-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
7 * @version V0.0.3
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
8 * @since 03-Feb-2016
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
9 * @brief Everything about creating and evaluating the logbook
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
10 * without the flash part which is included in externLogbookFlash.c
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
11 * and the USB/Bluetooth part in tComm.c
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
12 * CHANGE V0.0.3 hw: ppO2 sensor values
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
13 * CHANGE V0.0.4 hw: fix event bytes according to hwos_interface.odt dated 160610 in bitbucket hwOS
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
14 * @bug
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
15 * @warning
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
16 @verbatim
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
17 ==============================================================================
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
18 ##### Header #####
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
19 ==============================================================================
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
20 [..] SLogbookHeader
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
21 The order has changed in comparsion to OSTC3 for perfect alignment
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
22 with 16bit and 32bit. The header is 256kB as well.
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
23 DO NOT rearrange anything but add new data to a second page
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
24 beyond diveHeaderEnd. Use extraPagesWithData to indicate that there is
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
25 data available that was not available in the OSTC3 256KB
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
26 This data will be behind the diveHeaderEnd. DO NOT delete diveHeaderEnd.
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
27
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
28 [..] SLogbookHeaderOSTC3
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
29 is the format used by the OSTC3.
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
30 logbook_getHeaderOSTC3() does the job using the global headers in logbook.c
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
31
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
32 [..] SSmallHeader
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
33 - is the format used by the OSTC3
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
34
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
35 [..] Summary
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
36 The header format is not perfect and might be optimized prior to
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
37 releasing the diving computer. For now it is good to be compatible
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
38 with PC software available for checking the content of the logbook
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
39
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
40
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
41 @endverbatim
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
42 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
43 * @attention
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
44 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
45 * <h2><center>&copy; COPYRIGHT(c) 2014 heinrichs weikamp</center></h2>
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
46 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
47 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
48 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
49
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
50 /* Includes ------------------------------------------------------------------*/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
51 #include <stdint.h>
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
52 #include <string.h>
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
53 #include "logbook.h"
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
54 //#include "test_vpm.h"
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
55 #include "externLogbookFlash.h"
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
56 #include "data_exchange.h"
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
57 #include "decom.h"
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
58 #include "tHome.h" // for tHome_findNextStop()
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
59
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
60 /* Private types -------------------------------------------------------------*/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
61
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
62 #define NUM_GASES 5
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
63
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
64 #define LOGBOOK_VERSION (0x30)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
65 #define LOGBOOK_VERSION_OSTC3 (0x24)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
66
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
67 #define DEFAULT_SAMPLES (100) /* Number of sample data bytes in case of an broken header information */
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
68
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
69 typedef struct /* don't forget to adjust void clear_divisor(void) */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
70 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
71 uint8_t temperature;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
72 uint8_t deco_ndl;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
73 uint8_t gradientFactor;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
74 uint8_t ppo2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
75 uint8_t decoplan;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
76 uint8_t cns;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
77 uint8_t tank;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
78 } SDivisor;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
79
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
80 /* Exported variables --------------------------------------------------------*/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
81
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
82 /* Private variables ---------------------------------------------------------*/
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
83 static SLogbookHeader gheader;
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
84 static SLogbookHeaderOSTC3 headerOSTC3;
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
85 static SLogbookHeaderOSTC3compact headerOSTC3compact;
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
86 static SSmallHeader smallHeader;
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
87 static SDivisor divisor;
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
88 static SDivisor divisorBackup;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
89
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
90 /* Private function prototypes -----------------------------------------------*/
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
91 static void clear_divisor(void);
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
92 static void logbook_SetAverageDepth(float average_depth_meter);
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
93 static void logbook_SetMinTemperature(float min_temperature_celsius);
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
94 static void logbook_SetMaxCNS(float max_cns_percentage);
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
95 static void logbook_SetCompartmentDesaturation(const SDiveState * pStateReal);
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
96 static void logbook_SetLastStop(float last_stop_depth_bar);
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
97 static void logbook_writedata(void * data, int length_byte);
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
98 static void logbook_UpdateHeader(const SDiveState * pStateReal);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
99
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
100 /* Exported functions --------------------------------------------------------*/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
101
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
102 void logbook_EndDive(void)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
103 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
104 ext_flash_close_new_dive_log((uint8_t*) &gheader);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
105 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
106
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
107
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
108 // ===============================================================================
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
109 // logbook_last_totalDiveCount
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
110 /// @brief Fix setting issues
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
111 /// @date 04-April-2016
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
112 ///
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
113 /// @return diveNumber (totalDiveCounter) of latest log entry, 0 if not a valid header
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
114 // ===============================================================================
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
115 uint16_t logbook_lastDive_diveNumber(void)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
116 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
117 SLogbookHeader tempLogbookHeader;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
118 if(logbook_getHeader(0, &tempLogbookHeader))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
119 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
120 return tempLogbookHeader.diveNumber;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
121 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
122 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
123 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
124 return 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
125 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
126 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
127
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
128
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
129 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
130 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
131 * @brief logbook_getCurrentHeader. /
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
132 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
133 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
134 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
135 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
136 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
137 * @return SLogbookHeader*:
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
138 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
139 SLogbookHeader* logbook_getCurrentHeader(void)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
140 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
141 return &gheader;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
142 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
143
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
144 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
145 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
146 * @brief logbook_getNumberOfHeaders. /
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
147 * @author heinrichs weikamp gmbh
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
148 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
149 * @date 18-May-2016
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
150 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
151 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
152 * @return uint8_t : number of valid headers (0xFAFA) found.
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
153 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
154 uint8_t logbook_getNumberOfHeaders(void)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
155 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
156 return ext_flash_count_dive_headers();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
157 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
158
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
159
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
160 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
161 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
162 * @brief logbook_getHeader. /
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
163 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
164 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
165 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
166 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
167 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
168 * @param StepBackwards : 0 Last lokbook entry, 1 second to last entry, etc.
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
169 * @param SSLogbookHeader* pLogbookHeader: Output found LogbookHeader
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
170 * @return uint8_t : 1 = success
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
171 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
172 uint8_t logbook_getHeader(uint8_t StepBackwards,SLogbookHeader* pLogbookHeader)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
173 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
174 ext_flash_read_dive_header((uint8_t *)pLogbookHeader, StepBackwards);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
175 if(pLogbookHeader->diveHeaderStart != 0xFAFA)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
176 return 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
177 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
178 return 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
179 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
180
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
181 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
182 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
183 * @brief logbook_initNewdiveProfile. /
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
184 * creates header and smallHeader from diveState and global Settings
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
185 * and writes new lookboock entry on flash device
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
186 * diveState
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
187 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
188 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
189 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
190 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
191 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
192 * @param SDiveState* pInfo: Input
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
193 * @param SSettings* pSettings: Input
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
194 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
195
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
196 void logbook_initNewdiveProfile(const SDiveState* pInfo, SSettings* pSettings)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
197 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
198 RTC_DateTypeDef Sdate;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
199 RTC_TimeTypeDef Stime;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
200
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
201 for(int i = 0; i < sizeof(SLogbookHeader); i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
202 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
203 ((uint8_t*)(&gheader))[i] = 0;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
204 }
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
205 gheader.diveHeaderStart = 0xFAFA;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
206 gheader.diveHeaderEnd = 0xFBFB;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
207 gheader.samplingRate = 2;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
208 if(pInfo->diveSettings.diveMode == DIVEMODE_OC)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
209 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
210 for(int i = 0; i < 5; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
211 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
212 gheader.gasordil[i].oxygen_percentage = pSettings->gas[i+1].oxygen_percentage;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
213 gheader.gasordil[i].helium_percentage = pSettings->gas[i+1].helium_percentage;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
214 gheader.gasordil[i].note.uw = pSettings->gas[i+1].note.uw;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
215 gheader.gasordil[i].depth_meter = pSettings->gas[i+1].depth_meter;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
216 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
217 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
218 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
219 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
220 for(int i = 0; i < 5; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
221 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
222 gheader.gasordil[i].oxygen_percentage = pSettings->gas[i+6].oxygen_percentage;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
223 gheader.gasordil[i].helium_percentage = pSettings->gas[i+6].helium_percentage;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
224 gheader.gasordil[i].note.uw = pSettings->gas[i+6].note.uw;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
225 gheader.gasordil[i].depth_meter = pSettings->gas[i+6].depth_meter;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
226 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
227
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
228 for(int i = 0; i < 5; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
229 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
230 gheader.setpoint[i].setpoint_cbar = pSettings->setpoint[i+1].setpoint_cbar;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
231 gheader.setpoint[i].depth_meter = pSettings->setpoint[i+1].depth_meter;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
232 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
233 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
234 // header.gasordil[pInfo->lifeData.actualGas.GasIdInSettings].depth_meter = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
235
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
236 translateDate(pInfo->lifeData.dateBinaryFormat, &Sdate);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
237 translateTime(pInfo->lifeData.timeBinaryFormat, &Stime);
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
238 gheader.dateYear = Sdate.Year;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
239 gheader.dateMonth = Sdate.Month;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
240 gheader.dateDay = Sdate.Date;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
241 gheader.timeHour = Stime.Hours;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
242 gheader.timeMinute = Stime.Minutes;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
243 gheader.cnsAtBeginning = (uint16_t)pInfo->lifeData.cns;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
244 gheader.surfacePressure_mbar = (uint16_t)(pInfo->lifeData.pressure_surface_bar * 1000);
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
245 gheader.firmwareVersionHigh = firmwareVersion_16bit_high();
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
246 gheader.firmwareVersionLow = firmwareVersion_16bit_low();
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
247 gheader.logbookProfileVersion = LOGBOOK_VERSION;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
248 gheader.salinity = pSettings->salinity;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
249 gheader.diveNumber = pSettings->totalDiveCounter;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
250 gheader.personalDiveCount = pSettings->personalDiveCount;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
251
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
252 gheader.diveMode = pInfo->diveSettings.diveMode;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
253 gheader.CCRmode = pInfo->diveSettings.CCR_Mode;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
254 gheader.lastDecostop_m = pSettings->last_stop_depth_meter;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
255
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
256 if(pInfo->diveSettings.deco_type.ub.standard == GF_MODE)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
257 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
258 gheader.decoModel = 1;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
259 gheader.gfLow_or_Vpm_conservatism = pInfo->diveSettings.gf_low;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
260 gheader.gfHigh = pInfo->diveSettings.gf_high;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
261 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
262 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
263 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
264 gheader.decoModel = 2;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
265 gheader.gfLow_or_Vpm_conservatism = pInfo->diveSettings.vpm_conservatism;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
266 gheader.gfHigh = 0;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
267 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
268
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
269 memcpy(gheader.n2Compartments, pInfo->lifeData.tissue_nitrogen_bar, 64);
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
270 memcpy(gheader.heCompartments, pInfo->lifeData.tissue_helium_bar, 64);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
271
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
272 logbook_SetCompartmentDesaturation(pInfo);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
273
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
274 ext_flash_start_new_dive_log_and_set_actualPointerSample((uint8_t*)&gheader);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
275
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
276 smallHeader.profileLength[0] = 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
277 smallHeader.profileLength[1] = 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
278 smallHeader.profileLength[2] = 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
279 smallHeader.samplingRate_seconds = 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
280 smallHeader.numDivisors = 7;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
281
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
282 smallHeader.tempType = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
283 smallHeader.tempLength = 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
284 smallHeader.tempDivisor = 6;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
285
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
286 smallHeader.deco_ndlType = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
287 smallHeader.deco_ndlLength = 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
288 smallHeader.deco_ndlDivisor = 6; //= 6;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
289
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
290 /* GF in % at actual position */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
291 smallHeader.gfType = 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
292 smallHeader.gfLength = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
293 smallHeader.gfDivisor = 0; //12;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
294
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
295 /* 3 Sensors: 8bit ppO2 in 0.01bar, 16bit voltage in 0,1mV */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
296 smallHeader.ppo2Type = 3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
297 smallHeader.ppo2Length = 9;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
298 smallHeader.ppo2Divisor = 2; //2
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
299
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
300 /* last 15 stops in minutes (last, second_to_last, ... */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
301 /* last stop depth is defined in header */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
302 smallHeader.decoplanType = 4;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
303 smallHeader.decoplanLength = 15;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
304 smallHeader.decoplanDivisor = 12;//12;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
305
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
306 smallHeader.cnsType = 5;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
307 smallHeader.cnsLength = 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
308 smallHeader.cnsDivisor = 12;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
309
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
310 smallHeader.tankType = 6;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
311 smallHeader.tankLength = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
312 smallHeader.tankDivisor = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
313
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
314 logbook_writedata((void *) &smallHeader,sizeof(smallHeader));
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
315
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
316 clear_divisor();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
317 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
318
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
319 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
320 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
321 * @brief clear_divisor / clears divisor struct
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
322 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
323 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
324 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
325 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
326 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
327 */
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
328 static void clear_divisor(void)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
329 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
330 divisor.cns = smallHeader.cnsDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
331 divisor.decoplan = smallHeader.decoplanDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
332 divisor.deco_ndl = smallHeader.deco_ndlDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
333 divisor.gradientFactor = smallHeader.gfDivisor -1 ;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
334 divisor.ppo2 = smallHeader.ppo2Divisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
335 divisor.tank = smallHeader.tankDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
336 divisor.temperature = smallHeader.tempDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
337 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
338
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
339
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
340 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
341 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
342 * @brief add16. / adds 16 bit variable to 8 bit array
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
343 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
344 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
345 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
346 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
347 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
348 * @param uint8_t *pos: Output 8 bit array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
349 * @param uint16_t var: 16 bit variable
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
350 */
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
351 static void addU16(uint8_t *pos, uint16_t var)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
352 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
353 *((uint16_t*)pos) = var;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
354 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
355
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
356 static void addS16(uint8_t *pos, int16_t var)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
357 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
358 *((int16_t*)pos) = var;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
359 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
360
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
361 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
362 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
363 * @brief logbook_writeSample. / Writes one logbook sampl
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
364 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
365 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
366 * @version V0.0.2
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
367 * @since 20-June-2016
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
368 * @bug Deco/NDL Status fixed in V0.0.2
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
369
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
370
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
371 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
372 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
373 * @param SDiveState state:
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
374 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
375
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
376 void logbook_writeSample(const SDiveState *state)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
377 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
378 uint8_t sample[256];
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
379 // int position = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
380 int length = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
381 // _Bool bEvent = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
382 uint8_t nextstopDepthMeter = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
383 uint16_t nextstopLengthSeconds = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
384 uint8_t nextstopLengthMinutes = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
385 bit8_Type eventByte1, eventByte2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
386 bit8_Type profileByteFlag;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
387 int i = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
388 for(i = 0; i <256 ;i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
389 sample[i] = 0;
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
390 addU16(sample, (uint16_t)(state->lifeData.depth_meter * 100));
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
391 length += 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
392 sample[2] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
393 length++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
394 eventByte1.uw = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
395 eventByte2.uw = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
396 //uint16_t tmpU16 = 0;
130
b7689d9e888a Minor changes to improved code quality and to eliminate warnings
Ideenmodellierer
parents: 38
diff changeset
397 const SDecoinfo * pDecoinfo; // new hw 160620
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
398
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
399 //BuildEevntyte 1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
400 // sub old 0-3 only one at a time
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
401 if(state->events.manualMarker)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
402 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
403 eventByte1.uw = 6;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
404 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
405 else
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
406 if(state->warnings.decoMissed)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
407 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
408 eventByte1.uw = 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
409 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
410 else
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
411 if(state->warnings.ppO2Low)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
412 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
413 eventByte1.uw = 4;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
414 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
415 else
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
416 if(state->warnings.ppO2High)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
417 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
418 eventByte1.uw = 5;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
419 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
420 else
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
421 if(state->warnings.lowBattery)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
422 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
423 eventByte1.uw = 7;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
424 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
425 else
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
426 if(state->warnings.slowWarning)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
427 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
428 eventByte1.uw = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
429 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
430 // sub bit 4 to 7
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
431 if(state->events.manualGasSet)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
432 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
433 eventByte1.ub.bit4 = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
434 }
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
435 if(state->events.gasChange)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
436 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
437 eventByte1.ub.bit5 = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
438 }
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
439 if(state->events.setpointChange)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
440 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
441 eventByte1.ub.bit6 = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
442 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
443 // sub bit 7 + eventbyte2
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
444 if(state->events.bailout)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
445 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
446 eventByte1.ub.bit7 = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
447 eventByte2.ub.bit0 = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
448 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
449 //Add EventByte 1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
450 if(eventByte1.uw > 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
451 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
452 sample[length] = eventByte1.uw;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
453 length++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
454 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
455 if(eventByte2.uw > 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
456 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
457 sample[length] = eventByte2.uw;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
458 length++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
459 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
460 //Add EventInfos
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
461 if(state->events.manualGasSet)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
462 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
463 //manual gas in %O2 & %He
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
464 sample[length] = state->events.info_manualGasSetO2;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
465 length += 1;
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
466 sample[length] = state->events.info_manualGasSetHe;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
467 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
468 }
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
469 if(state->events.gasChange)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
470 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
471 //Current gas (gasid)
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
472 sample[length] = state->events.info_GasChange;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
473 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
474 }
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
475 if(state->events.setpointChange)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
476 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
477 //New setpoint in cbar
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
478 sample[length] = state->events.info_SetpointChange;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
479 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
480 }
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
481 if(state->events.bailout)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
482 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
483 //bailout gas in % O2 & %He
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
484 sample[length] = state->events.info_bailoutO2;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
485 length += 1;
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
486 sample[length] = state->events.info_bailoutHe;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
487 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
488 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
489
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
490
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
491 if(divisor.temperature == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
492 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
493 divisor.temperature = smallHeader.tempDivisor - 1;
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
494 addS16(&sample[length], (int16_t)((state->lifeData.temperature_celsius * 10.0f) + 0.5f));
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
495 length += 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
496 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
497 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
498 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
499 divisor.temperature--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
500 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
501
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
502
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
503 if(smallHeader.deco_ndlDivisor > 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
504 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
505 if(divisor.deco_ndl == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
506 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
507 divisor.deco_ndl = smallHeader.deco_ndlDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
508
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
509 if(stateUsed->diveSettings.deco_type.ub.standard == GF_MODE)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
510 pDecoinfo = &stateUsed->decolistBuehlmann;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
511 else if(stateUsed->diveSettings.deco_type.ub.standard == VPM_MODE)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
512 pDecoinfo = &stateUsed->decolistVPM;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
513 else // should not happen as only GF and VPM at the moment
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
514 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
515 sample[length] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
516 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
517 sample[length] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
518 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
519 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
520
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
521 if(pDecoinfo->output_ndl_seconds > 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
522 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
523 sample[length] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
524 length += 1;
283
04cdeff80254 Bugfix: write NDL in logbook correctly
Jan Mulder <jlmulder@xs4all.nl>
parents: 281
diff changeset
525 sample[length] = (uint8_t)(pDecoinfo->output_ndl_seconds / 60);
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
526
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
527 // Limit stored sample within 0 to 240 mins (Since it's 8bit UINT only)
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
528 if ((pDecoinfo->output_ndl_seconds / 60) > 240) sample[length] = 240;
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
529 if ((pDecoinfo->output_ndl_seconds / 60) < 0) sample[length] = 0;
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
530
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
531 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
532 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
533 else if(pDecoinfo->output_time_to_surface_seconds)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
534 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
535 tHome_findNextStop(pDecoinfo->output_stop_length_seconds, &nextstopDepthMeter, &nextstopLengthSeconds);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
536 nextstopLengthMinutes = (nextstopLengthSeconds +59 ) / 60;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
537
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
538 sample[length] = nextstopDepthMeter;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
539 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
540 sample[length] = nextstopLengthMinutes;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
541 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
542 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
543 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
544 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
545 sample[length] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
546 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
547 sample[length] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
548 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
549 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
550 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
551 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
552 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
553 divisor.deco_ndl --;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
554 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
555 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
556
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
557
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
558 if(smallHeader.ppo2Divisor)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
559 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
560 if(divisor.ppo2 == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
561 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
562 divisor.ppo2 = smallHeader.ppo2Divisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
563
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
564 for(int i = 0; i <3; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
565 {
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
566 sample[length] = (uint8_t)(state->lifeData.ppO2Sensor_bar[i] * 100.0f + 0.5f);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
567 length += 1;
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
568 addU16(&sample[length], (uint16_t)(state->lifeData.sensorVoltage_mV[i] * 10.0f + 0.5f));
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
569 length += 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
570 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
571 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
572 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
573 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
574 divisor.ppo2--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
575 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
576 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
577
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
578
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
579 if(smallHeader.decoplanDivisor)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
580 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
581 if(divisor.decoplan == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
582 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
583 divisor.decoplan = smallHeader.decoplanDivisor - 1;
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
584 if(state->diveSettings.deco_type.ub.standard == VPM_MODE)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
585 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
586 for(int i = 0; i <15; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
587 {
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
588 sample[length] = state->decolistVPM.output_stop_length_seconds[i] / 60;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
589 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
590 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
591 }
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
592 else if(state->diveSettings.deco_type.ub.standard == GF_MODE)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
593 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
594 for(int i = 0; i <15; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
595 {
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
596 sample[length] = state->decolistBuehlmann.output_stop_length_seconds[i] / 60;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
597 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
598 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
599 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
600 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
601 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
602 for(int i = 0; i <15; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
603 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
604 sample[length] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
605 length += 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
606 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
607 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
608 // add16(&sample[length], state.temperature);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
609 //length += 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
610 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
611 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
612 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
613 divisor.decoplan --;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
614 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
615 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
616 if(divisor.cns == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
617 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
618 divisor.cns = smallHeader.cnsDivisor - 1;
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
619 addU16(&sample[length], (uint16_t)state->lifeData.cns);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
620 length += 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
621 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
622 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
623 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
624 divisor.cns--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
625 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
626
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
627 profileByteFlag.uw = length - 3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
628 if(eventByte1.uw)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
629 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
630 profileByteFlag.ub.bit7 = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
631 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
632 sample[2] = profileByteFlag.uw;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
633 logbook_writedata((void *) sample,length);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
634
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
635 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
636
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
637 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
638 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
639 * @brief readSample. / Reads data of one logbook sample
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
640 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
641 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
642 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
643 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
644 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
645 * @param int32_t* depth: output Value
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
646 * @param int16_t * gasid: output Value
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
647 * @param int32_t* temperature: output Value
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
648 * @param int32_t* sensor1, sensor2, sensor3: output Value
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
649 * @param int32_t* cns: output Value
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
650 * @return bytes read / 0 = reading Error
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
651 */
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
652 static uint16_t readSample(int32_t* depth, int16_t * gasid, int16_t* setpoint_cbar, int32_t* temperature, int32_t* sensor1, int32_t* sensor2, int32_t* sensor3, int32_t* cns, SManualGas* manualGas, int16_t* bailout, int16_t* decostopDepth)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
653 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
654 int length = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
655 _Bool bEvent = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
656 bit8_Type eventByte1, eventByte2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
657 bit8_Type profileByteFlag;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
658
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
659 eventByte1.uw = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
660 eventByte2.uw = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
661 uint8_t tempU8 = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
662 uint16_t temp = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
663 uint16_t bytesRead = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
664
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
665 if(gasid)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
666 *gasid = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
667 if(temperature)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
668 *temperature = -1000;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
669 if(sensor1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
670 *sensor1 = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
671 if(sensor2)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
672 *sensor2 = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
673 if(sensor3)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
674 *sensor3 = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
675 if(cns)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
676 *cns = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
677 if(setpoint_cbar)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
678 *setpoint_cbar = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
679 if(bailout)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
680 *bailout = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
681 if(manualGas)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
682 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
683 manualGas->percentageO2 =-1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
684 manualGas->percentageHe =-1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
685 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
686 if(decostopDepth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
687 *decostopDepth = -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
688
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
689 ext_flash_read_next_sample_part( (uint8_t*)&temp, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
690 if(depth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
691 *depth = (int32_t)temp;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
692 bytesRead += 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
693
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
694 ext_flash_read_next_sample_part( &profileByteFlag.uw, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
695 bytesRead ++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
696
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
697 bEvent = profileByteFlag.ub.bit7;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
698 profileByteFlag.ub.bit7 = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
699 length = profileByteFlag.uw;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
700
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
701 if(bEvent)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
702 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
703 ext_flash_read_next_sample_part( &eventByte1.uw, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
704 bytesRead ++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
705
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
706 length--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
707
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
708 //second event byte
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
709 if(eventByte1.ub.bit7)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
710 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
711 ext_flash_read_next_sample_part( &eventByte2.uw, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
712 bytesRead ++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
713 length--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
714 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
715 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
716 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
717 eventByte2.uw = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
718 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
719
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
720 //manual Gas Set
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
721 if( eventByte1.ub.bit4)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
722 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
723 //Evaluate manual Gas
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
724 ext_flash_read_next_sample_part( (uint8_t*)&tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
725 bytesRead +=1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
726 length -= 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
727 manualGas->percentageO2 = tempU8;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
728 ext_flash_read_next_sample_part( (uint8_t*)&tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
729 bytesRead +=1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
730 length -= 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
731 manualGas->percentageHe = tempU8;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
732 if(gasid)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
733 *gasid = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
734 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
735 //gas change
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
736 if( eventByte1.ub.bit5)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
737 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
738 ext_flash_read_next_sample_part( &tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
739 bytesRead +=1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
740 length -= 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
741 if(gasid)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
742 *gasid = (uint16_t)tempU8;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
743 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
744 //SetpointChange
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
745 if( eventByte1.ub.bit6)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
746 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
747 ext_flash_read_next_sample_part( &tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
748 *setpoint_cbar = tempU8;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
749 bytesRead +=1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
750 length -= 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
751 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
752
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
753 // second event Byte
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
754 //bailout
298
50c26a4442af Bugfix: fix drawing of CCR bailout profile
Jan Mulder <jlmulder@xs4all.nl>
parents: 283
diff changeset
755 if(eventByte2.ub.bit0)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
756 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
757 //evaluate bailout gas Gas
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
758 *bailout = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
759
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
760 ext_flash_read_next_sample_part( (uint8_t*)&tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
761 bytesRead +=1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
762 length -= 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
763 manualGas->percentageO2 = tempU8;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
764 ext_flash_read_next_sample_part( (uint8_t*)&tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
765 bytesRead +=1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
766 length -= 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
767 manualGas->percentageHe = tempU8;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
768
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
769 if(gasid)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
770 *gasid = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
771 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
772 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
773
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
774 if(divisor.temperature == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
775 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
776 divisor.temperature = smallHeader.tempDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
777 ext_flash_read_next_sample_part( (uint8_t*)&temp, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
778 bytesRead +=2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
779 length -= 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
780 if(temperature)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
781 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
782 *temperature = (int32_t)temp;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
783 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
784 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
785 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
786 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
787 divisor.temperature--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
788 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
789
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
790 if(smallHeader.deco_ndlDivisor > 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
791 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
792 if(divisor.deco_ndl == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
793 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
794 divisor.deco_ndl = smallHeader.deco_ndlDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
795 ext_flash_read_next_sample_part( &tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
796 if(decostopDepth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
797 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
798 *decostopDepth = tempU8 * 100;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
799 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
800 ext_flash_read_next_sample_part( &tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
801 bytesRead += 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
802 length -= 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
803 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
804 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
805 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
806 divisor.deco_ndl--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
807 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
808 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
809
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
810 if(divisor.ppo2 == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
811 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
812 int32_t ppO2Tmp = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
813 divisor.ppo2 = smallHeader.ppo2Divisor -1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
814 for(int i = 0; i <3 ; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
815 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
816 ext_flash_read_next_sample_part( &tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
817 ppO2Tmp += tempU8;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
818 bytesRead +=1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
819 length -= 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
820 ext_flash_read_next_sample_part( (uint8_t*)&temp, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
821 bytesRead +=2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
822 length -= 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
823 if(sensor1 && (i==0))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
824 *sensor1 = (((int32_t)tempU8) * 0xFFFF) + temp;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
825 if(sensor2 && (i==1))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
826 *sensor2 = (((int32_t)tempU8) * 0xFFFF) + temp;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
827 if(sensor3 && (i==2))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
828 *sensor3 = (((int32_t)tempU8) * 0xFFFF) + temp;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
829 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
830 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
831 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
832 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
833 divisor.ppo2--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
834 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
835
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
836 if(smallHeader.decoplanDivisor > 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
837 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
838 if(divisor.decoplan == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
839 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
840 divisor.decoplan = smallHeader.decoplanDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
841 for(int i = 0; i <15; i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
842 ext_flash_read_next_sample_part( &tempU8, 1);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
843 bytesRead += 15;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
844 length -= 15;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
845 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
846 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
847 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
848 divisor.decoplan--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
849 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
850 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
851
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
852
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
853
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
854 if(divisor.cns == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
855 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
856 divisor.cns = smallHeader.cnsDivisor - 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
857
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
858 ext_flash_read_next_sample_part( (uint8_t*)&temp, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
859 bytesRead +=2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
860 length -= 2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
861 if(cns)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
862 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
863 *cns = (int32_t)temp;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
864 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
865 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
866 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
867 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
868 divisor.cns--;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
869 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
870
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
871 if (length != 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
872 return 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
873
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
874 return bytesRead;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
875 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
876 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
877 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
878 * @brief logbook_readSampleData. / Reads sample data of whole logbook entry
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
879 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
880 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
881 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
882 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
883 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
884 * @param uint8_t StepBackwards: witch lookbook entry?
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
885 * @param uint16_t length : maxlength of output arrays
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
886 * @param int32_t* depth : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
887 * @param int16_t * gasid : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
888 * @param int32_t* temperature : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
889 * @param int32_t* ppo2 : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
890 * @param int32_t* cns : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
891 * @return length of output
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
892 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
893 uint16_t logbook_readSampleData(uint8_t StepBackwards, uint16_t length,uint16_t* depth, uint8_t* gasid, int16_t* temperature, uint16_t* ppo2, uint16_t* setpoint, uint16_t* sensor1, uint16_t* sensor2, uint16_t* sensor3, uint16_t* cns, uint8_t* bailout, uint16_t* decostopDepth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
894 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
895 //Test read
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
896 //SLogbookHeader header;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
897
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
898 //logbook_getHeader(&header);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
899 SLogbookHeader header;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
900 int iNum;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
901 int firstgasid = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
902 int retVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
903 int compression = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
904 int i;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
905 // uint32_t diveTime_seconds;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
906 int32_t depthVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
907 int16_t gasidVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
908 int16_t setPointVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
909 int16_t bailoutVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
910 int16_t bailoutLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
911 uint16_t setPointLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
912 int32_t temperatureVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
913 int32_t sensor1Val = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
914 int32_t sensor2Val = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
915 int32_t sensor3Val = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
916 int32_t sensor1Last = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
917 int32_t sensor2Last = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
918 int32_t sensor3Last = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
919 int32_t cnsVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
920 int32_t depthLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
921 int16_t gasidLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
922 int32_t temperatureLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
923 int32_t temperatureFirst = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
924 int32_t cnsLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
925 int16_t decostepDepthVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
926 int16_t decostepDepthLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
927
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
928 SManualGas manualGasVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
929 SManualGas manualGasLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
930 manualGasLast.percentageO2 = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
931 manualGasLast.percentageHe = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
932
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
933 float ambiant_pressure_bar = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
934 float ppO2 = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
935 ext_flash_read_dive_header((uint8_t*)&header, StepBackwards);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
936 for(i = 0;i< 5;i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
937 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
938 if(header.gasordil[i].note.ub.first)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
939 break;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
940 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
941 firstgasid = i + 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
942 if(header.diveMode == DIVEMODE_CCR)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
943 setPointLast = header.setpoint[0].setpoint_cbar;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
944 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
945 setPointLast = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
946 //diveTime_seconds = header.diveTime_seconds ;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
947 for(compression = 1; compression < 100; compression ++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
948 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
949 if((header.total_diveTime_seconds / header.samplingRate)/compression <= length)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
950 break;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
951 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
952
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
953
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
954 for(i = 0;i< length;i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
955 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
956 if(depth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
957 depth[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
958 if(temperature)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
959 temperature[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
960 if(gasid)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
961 gasid[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
962 if(ppo2)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
963 ppo2[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
964 if(setpoint)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
965 setpoint[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
966 if(sensor1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
967 sensor1[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
968 if(sensor2)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
969 sensor2[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
970 if(sensor3)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
971 sensor3[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
972 if(cns)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
973 cns[i] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
974 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
975 //We start with fist gasid
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
976 gasidLast = firstgasid;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
977
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
978
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
979 //uint16_t* ppo2, uint16_t* cns#
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
980 uint32_t totalNumberOfBytes = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
981 uint32_t bytesRead = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
982 ext_flash_open_read_sample( StepBackwards,&totalNumberOfBytes);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
983 ext_flash_read_next_sample_part((uint8_t*)&smallHeader, sizeof(SSmallHeader));
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
984 bytesRead += sizeof(SSmallHeader);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
985
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
986 clear_divisor();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
987
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
988 iNum = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
989 int counter = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
990 temperatureLast = -1000;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
991 while ((bytesRead < totalNumberOfBytes) && (iNum < length))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
992 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
993 ext_flash_set_entry_point();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
994 divisorBackup = divisor;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
995 retVal = readSample(&depthVal,&gasidVal, &setPointVal, &temperatureVal, &sensor1Val, &sensor2Val, &sensor3Val, &cnsVal, &manualGasVal, &bailoutVal, &decostepDepthVal);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
996
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
997 if(retVal == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
998 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
999 //Error try to read again!!!
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1000 ext_flash_reopen_read_sample_at_entry_point();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1001 divisor = divisorBackup;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1002 retVal = readSample(&depthVal,&gasidVal,&setPointVal, &temperatureVal, &sensor1Val, &sensor2Val, &sensor3Val, &cnsVal, &manualGasVal, &bailoutVal, &decostepDepthVal);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1003
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1004 if(retVal == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1005 break;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1006 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1007 bytesRead +=retVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1008
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1009 //if for some variable no new value is in the sample for (z.B. gasidVal = -1), we take the last value
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1010 if(depthVal == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1011 depthVal = depthLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1012 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1013 depthLast = depthVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1015 if(gasidVal == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1016 gasidVal = gasidLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1017 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1018 gasidLast = gasidVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1019
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1020 if(temperatureVal == -1000)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1021 temperatureVal = temperatureLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1022 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1023 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1024 if(temperatureLast == -1000)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1025 temperatureFirst = temperatureVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1026 temperatureLast = temperatureVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1027 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1028
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1029 if(setPointVal == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1030 setPointVal = setPointLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1031 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1032 setPointLast = setPointVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1033
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1034 if(sensor1Val == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1035 sensor1Val = sensor1Last;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1036 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1037 sensor1Last = sensor1Val;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1038
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1039 if(sensor2Val == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1040 sensor2Val = sensor2Last;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1041 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1042 sensor2Last = sensor2Val;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1043
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1044 if(sensor3Val == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1045 sensor3Val = sensor3Last;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1046 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1047 sensor3Last = sensor3Val;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1048
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1049 if(cnsVal == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1050 cnsVal = cnsLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1051 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1052 cnsLast = cnsVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1053
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1054 if(manualGasVal.percentageO2 == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1055 manualGasVal = manualGasLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1056 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1057 manualGasLast = manualGasVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1058
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1059 if(bailoutVal == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1060 bailoutVal = bailoutLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1061 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1062 bailoutLast = bailoutVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1063
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1064 if(decostepDepthVal == -1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1065 decostepDepthVal = decostepDepthLast;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1066 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1067 decostepDepthLast = decostepDepthVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1068
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1069 counter++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1070 // Heed compression
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1071 // Write here to arrays
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1072 if(counter == compression)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1073 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1074 if(depth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1075 depth[iNum] = depthVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1076 if(gasid)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1077 gasid[iNum] = gasidVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1078 if(temperature)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1079 temperature[iNum] = temperatureVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1080 if(cns)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1081 cns[iNum] = cnsVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1082 if(bailout)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1083 bailout[iNum] = bailoutVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1084 if(decostopDepth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1085 decostopDepth[iNum] = decostepDepthVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1086
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1087 if(ppo2)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1088 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1089 //Calc ppo2 - Values
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1090 SGas gas;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1091 gas.setPoint_cbar = setPointVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1092 if(gasidVal > 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1093 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1094 gas.helium_percentage = header.gasordil[gasidVal - 1].helium_percentage;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1095 gas.nitrogen_percentage = 100 - gas.helium_percentage - header.gasordil[gasidVal - 1].oxygen_percentage;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1096 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1097 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1098 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1099 gas.helium_percentage = manualGasVal.percentageHe;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1100 gas.nitrogen_percentage = 100 - gas.helium_percentage - manualGasVal.percentageO2;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1101 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1102 ambiant_pressure_bar =((float)(depthVal + header.surfacePressure_mbar))/1000;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1103 ppO2 = decom_calc_ppO2(ambiant_pressure_bar, &gas );
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1104 ppo2[iNum] = (uint16_t) ( ppO2 * 100);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1105 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1106
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1107 if(setpoint)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1108 setpoint[iNum] = setPointVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1109
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1110 if(sensor1)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1111 sensor1[iNum] = (sensor1Val / 0xFFFF) & 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1112 if(sensor2)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1113 sensor2[iNum] = (sensor2Val / 0xFFFF) & 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1114 if(sensor3)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1115 sensor3[iNum] = (sensor3Val / 0xFFFF) & 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1116 iNum++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1117 counter = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1118 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1119 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1120
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1121 // Fix first Temperature Entries 150930 hw
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1122 if(temperature)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1123 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1124 int i = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1125 while((temperature[i] == -1000) && (i < iNum))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1126 temperature[i++] = temperatureFirst;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1127 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1128
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1129 ext_flash_close_read_sample();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1130 return iNum;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1131 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1132
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1133
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1134 /********************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1135 * @brief logbook_InitAndWrite. / Controls writing of logbook
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1136 * Should be called ten times per second
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1137 * Automatically Initializes logbook at beginning of dive,
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1138 * write samples every 2 seconds
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1139 * and finishes logbook after end of dive
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1140 *********************************************************************************/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1141
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
1142 void logbook_InitAndWrite(const SDiveState *pStateReal)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1143 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1144 SSettings *pSettings = settingsGetPointer();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1145 static uint8_t bDiveMode = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1146 static uint32_t tickstart = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1147 uint32_t ticksdiff = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1148 uint32_t lasttick = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1149 static float min_temperature_float_celsius = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1150
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1151 if(!bDiveMode)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1152 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1153 if((pStateReal->mode == MODE_DIVE) && (pStateReal->diveSettings.diveMode != DIVEMODE_Apnea) && (pStateReal->lifeData.dive_time_seconds >= 5))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1154 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1155 //InitdiveProfile
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1156 pSettings->totalDiveCounter++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1157 logbook_initNewdiveProfile(pStateReal,settingsGetPointer());
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1158 min_temperature_float_celsius = pStateReal->lifeData.temperature_celsius;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1159 //Write logbook sample
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
1160 logbook_writeSample(pStateReal);
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
1161 resetEvents(pStateReal);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1162 tickstart = HAL_GetTick();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1163 bDiveMode = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1164 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1165 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1166 else if((pStateReal->mode == MODE_DIVE) && (pStateReal->diveSettings.diveMode != DIVEMODE_Apnea))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1167 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1168 lasttick = HAL_GetTick();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1169 ticksdiff = time_elapsed_ms(tickstart,lasttick);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1170 //
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1171 if(ticksdiff >= 2000)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1172 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1173 //Write logbook sample
269
6e78137952af cleanup: do not pass large struct by value
Jan Mulder <jlmulder@xs4all.nl>
parents: 225
diff changeset
1174 logbook_writeSample(pStateReal);
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
1175 resetEvents(pStateReal);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1176 if(min_temperature_float_celsius > pStateReal->lifeData.temperature_celsius)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1177 min_temperature_float_celsius = pStateReal->lifeData.temperature_celsius;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1178 tickstart = lasttick;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1179 if((bDiveMode == 1) && (pStateReal->lifeData.dive_time_seconds >= pSettings->divetimeToCreateLogbook))
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1180 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1181 ext_flash_create_new_dive_log((uint8_t*)&gheader);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1182 /** save settings
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1183 * with new lastDiveLogId and time and day
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1184 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1185 pSettings->personalDiveCount++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1186 if(pSettings->logbookOffset)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1187 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1188 pSettings->logbookOffset++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1189 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1190 ext_flash_write_settings();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1191 ext_flash_disable_protection_for_logbook();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1192 bDiveMode = 3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1193 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1194 if(bDiveMode == 3)
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
1195 logbook_UpdateHeader(pStateReal);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1196 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1197 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1198 else if(bDiveMode == 3)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1199 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1200 //End of Dive
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1201 logbook_SetAverageDepth(pStateReal->lifeData.average_depth_meter);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1202 logbook_SetMinTemperature(min_temperature_float_celsius);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1203 logbook_SetMaxCNS(pStateReal->lifeData.cns);
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
1204 logbook_SetCompartmentDesaturation(pStateReal);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1205 logbook_SetLastStop(pStateReal->diveSettings.last_stop_depth_bar);
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1206 gheader.batteryVoltage = pStateReal->lifeData.battery_voltage * 1000;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1207 logbook_EndDive();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1208 bDiveMode = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1209 } else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1210 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1211 ext_flash_enable_protection();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1212 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1213 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1214
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1215
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1216 /* Private functions ---------------------------------------------------------*/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1217
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1218 /********************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1219 * @brief logbook_UpdateHeader. /
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1220 * set date, time, max depth. etc. pp.
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1221 * the internal pointer to the end of profile and length will be set by
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1222 ext_flash_close_new_dive_log() in externLogbookFlash.c
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1223 * @author heinrichs weikamp gmbh
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1224 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1225 * @date 27-Nov-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1226 *********************************************************************************/
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
1227 static void logbook_UpdateHeader(const SDiveState *pStateReal)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1228 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1229 // uint16_t secondsAtShallow = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1230 RTC_DateTypeDef Sdate;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1231 RTC_TimeTypeDef Stime;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1232 uint32_t time1_u32, time2_u32;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1233 uint32_t divetimeHelper;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1234
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1235 /* time and day */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1236 /* don't update CHANGE 160224 hw, maybe save actual time and date at other place
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1237 translateDate(pStateReal->lifeData.dateBinaryFormat, &Sdate);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1238 translateTime(pStateReal->lifeData.timeBinaryFormat, &Stime);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1239
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1240 header.dateYear = Sdate.Year;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1241 header.dateMonth = Sdate.Month;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1242 header.dateDay = Sdate.Date;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1243 header.timeHour = Stime.Hours;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1244 header.timeMinute = Stime.Minutes;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1245 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1246 /// 160315 Quick fix for empty date problem
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1247 if((!(gheader.dateYear)) || (!(gheader.dateMonth)) || (!(gheader.dateDay)))
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1248 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1249 translateDate(pStateReal->lifeData.dateBinaryFormat, &Sdate);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1250 translateTime(pStateReal->lifeData.timeBinaryFormat, &Stime);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1251
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1252 gheader.dateYear = Sdate.Year;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1253 gheader.dateMonth = Sdate.Month;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1254 gheader.dateDay = Sdate.Date;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1255
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1256 time1_u32 = (uint32_t)gheader.timeMinute + (uint32_t)(gheader.timeHour * 60);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1257 time2_u32 = (uint32_t)Stime.Minutes + (uint32_t)(Stime.Hours * 60);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1258 if(time2_u32 < time1_u32)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1259 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1260 if(gheader.dateDay > 1)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1261 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1262 gheader.dateDay -= 1;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1263 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1264 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1265 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1266 gheader.dateMonth --;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1267 if(!gheader.dateMonth)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1268 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1269 gheader.dateYear--;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1270 gheader.dateMonth = 12;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1271 gheader.dateDay = 31;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1272 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1273 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1274 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1275 if(gheader.dateMonth == 2)
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1276 gheader.dateDay = 28;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1277 else
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1278 if((gheader.dateMonth == 4) || (gheader.dateMonth == 6) || (gheader.dateMonth == 9) || (gheader.dateMonth == 11))
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1279 gheader.dateDay = 30;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1280 else
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1281 gheader.dateDay = 31;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1282 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1283 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1284 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1285 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1286
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1287 /* duration */
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1288 gheader.total_diveTime_seconds = pStateReal->lifeData.dive_time_seconds;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1289 gheader.maxDepth = pStateReal->lifeData.max_depth_meter * 100;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1290
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1291 /* old:
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1292
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1293 secondsAtShallow = pSettings->timeoutDiveReachedZeroDepth;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1294 if(pStateReal->lifeData.dive_time_seconds <= secondsAtShallow)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1295 secondsAtShallow = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1296 header.diveTimeMinutes = (header.total_diveTime_seconds - secondsAtShallow )/ 60;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1297 header.diveTimeSeconds = header.total_diveTime_seconds - secondsAtShallow - (header.diveTimeMinutes * 60);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1298 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1299 divetimeHelper = pStateReal->lifeData.dive_time_seconds_without_surface_time;
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1300 gheader.diveTimeMinutes = (uint16_t)(divetimeHelper/60);
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1301 divetimeHelper -= 60 * (uint32_t)gheader.diveTimeMinutes;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1302 gheader.diveTimeSeconds = (uint16_t)divetimeHelper;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1303
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1304 /* deco algorithm (final) */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1305 if(pStateReal->diveSettings.deco_type.ub.standard == GF_MODE)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1306 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1307 gheader.decoModel = 1;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1308 gheader.gfLow_or_Vpm_conservatism = pStateReal->diveSettings.gf_low;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1309 gheader.gfHigh = pStateReal->diveSettings.gf_high;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1310 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1311 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1312 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1313 gheader.decoModel = 2;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1314 gheader.gfLow_or_Vpm_conservatism = pStateReal->diveSettings.vpm_conservatism;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1315 gheader.gfHigh = 0;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1316 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1317
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1318 /* tissue load */
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1319 memcpy(gheader.n2Compartments, pStateReal->lifeData.tissue_nitrogen_bar, 64);
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1320 memcpy(gheader.heCompartments, pStateReal->lifeData.tissue_helium_bar, 64);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1321
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1322 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1323
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1324
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
1325 static void logbook_SetAverageDepth(float average_depth_meter)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1326 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1327 gheader.averageDepth_mbar = (uint16_t)(average_depth_meter * 100);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1328 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1329
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1330
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
1331 static void logbook_SetMinTemperature(float min_temperature_celsius)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1332 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1333 gheader.minTemp = (int16_t)((min_temperature_celsius * 10.0f) + 0.5f);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1334 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1335
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1336
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
1337 static void logbook_SetMaxCNS(float max_cns_percentage)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1338 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1339 if(max_cns_percentage < 9999)
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1340 gheader.maxCNS = (uint16_t)(max_cns_percentage);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1341 else
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1342 gheader.maxCNS = 9999;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1343 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1344
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1345
270
2e58a4094770 feature, debug: make simulator write a logbook entry
Jan Mulder <jlmulder@xs4all.nl>
parents: 269
diff changeset
1346 static void logbook_SetCompartmentDesaturation(const SDiveState * pStateReal)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1347 {
225
2bb1db22b5f5 cleanup: random set of cleanups
Jan Mulder <jlmulder@xs4all.nl>
parents: 199
diff changeset
1348 SLifeData2 secondaryInformation = { 0 };
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1349
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1350 decom_tissues_desaturation_time(&pStateReal->lifeData, &secondaryInformation);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1351 for(int i=0;i<16;i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1352 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1353 if(secondaryInformation.tissue_nitrogen_desaturation_time_minutes[i] <= (15 * 255))
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1354 gheader.n2CompartDesatTime_min[i] = (uint8_t)((secondaryInformation.tissue_nitrogen_desaturation_time_minutes[i] + 14) / 15);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1355 else
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1356 gheader.n2CompartDesatTime_min[i] = 255;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1357 if(secondaryInformation.tissue_helium_desaturation_time_minutes[i] <= (15 * 255))
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1358 gheader.heCompartDesatTime_min[i] = (uint8_t)((secondaryInformation.tissue_helium_desaturation_time_minutes[i] + 14 )/ 15);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1359 else
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1360 gheader.heCompartDesatTime_min[i] = 255;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1361 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1362 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1363
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
1364 static void logbook_SetLastStop(float last_stop_depth_bar)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1365 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1366 gheader.lastDecostop_m = (uint8_t)(last_stop_depth_bar / 10.0f);
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1367 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1368
194
f23b9055436f cleanup: more trivial cleanup (logbook.c/h)
Jan Mulder <jlmulder@xs4all.nl>
parents: 149
diff changeset
1369 static void logbook_writedata(void * data, int length_byte)
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1370 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1371 ext_flash_write_sample(data, length_byte);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1372 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1373
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1374 /********************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1375 * @brief logbook_build_ostc3header. /
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1376 * @author heinrichs weikamp gmbh
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1377 * @version V0.0.2
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1378 * @date 27-Nov-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1379 *********************************************************************************/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1380 SLogbookHeaderOSTC3 * logbook_build_ostc3header(SLogbookHeader* pHead)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1381 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1382 convert_Type data,data2;
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1383
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1384 memcpy(headerOSTC3.diveHeaderStart, &pHead->diveHeaderStart, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1385 memcpy(headerOSTC3.pBeginProfileData, &pHead->pBeginProfileData, 3);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1386 memcpy(headerOSTC3.pEndProfileData, &pHead->pEndProfileData, 3);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1387
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1388
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1389 data.u8bit.byteHigh = 0;
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1390 data.u8bit.byteLow = pHead->pBeginProfileData[0];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1391 data.u8bit.byteMidLow = pHead->pBeginProfileData[1];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1392 data.u8bit.byteMidHigh = pHead->pBeginProfileData[2];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1393
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1394 data2.u8bit.byteHigh = 0;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1395 data2.u8bit.byteLow = pHead->pEndProfileData[0];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1396 data2.u8bit.byteMidLow = pHead->pEndProfileData[1];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1397 data2.u8bit.byteMidHigh = pHead->pEndProfileData[2];
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1398
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1399 /* check if sample address information are corrupted by address range. */
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1400 /* TODO: Workaround. Better solution would be to check end of ring for 0xFF pattern */
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1401 if((data.u32bit > data2.u32bit) && (data.u32bit < (SAMPLESTOP - 0x9000)))
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1402 {
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1403 data2.u32bit = data.u32bit + DEFAULT_SAMPLES;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1404 pHead->pEndProfileData[0] = data2.u8bit.byteLow;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1405 pHead->pEndProfileData[1] = data2.u8bit.byteMidLow;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1406 pHead->pEndProfileData[2] = data2.u8bit.byteMidHigh;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1407 data.u32bit = DEFAULT_SAMPLES;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1408 }
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1409 else
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1410 {
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1411 data.u8bit.byteHigh = 0;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1412 data.u8bit.byteLow = pHead->profileLength[0];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1413 data.u8bit.byteMidLow = pHead->profileLength[1];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1414 data.u8bit.byteMidHigh = pHead->profileLength[2];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1415 }
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1416 if(data.u32bit != 0xFFFFFF)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1417 data.u32bit += 3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1418
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1419 headerOSTC3.profileLength[0] = data.u8bit.byteLow;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1420 headerOSTC3.profileLength[1] = data.u8bit.byteMidLow;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1421 headerOSTC3.profileLength[2] = data.u8bit.byteMidHigh;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1422
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1423 memcpy(headerOSTC3.gasordil, pHead->gasordil, 20);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1424
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1425 if(pHead->logbookProfileVersion == LOGBOOK_VERSION)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1426 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1427 headerOSTC3.logbookProfileVersion = LOGBOOK_VERSION_OSTC3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1428 memcpy(headerOSTC3.personalDiveCount, &pHead->personalDiveCount, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1429 headerOSTC3.safetyDistance_10cm = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1430
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1431 for(int i=0;i<5;i++)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1432 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1433 if(!pHead->gasordil[i].note.ub.active)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1434 headerOSTC3.gasordil[3 + (i*4)] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1435 else if(pHead->gasordil[i].note.ub.first)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1436 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1437 /* depth = 0, note = 1 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1438 headerOSTC3.gasordil[2 + (i*4)] = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1439 headerOSTC3.gasordil[3 + (i*4)] = 1;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1440 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1441 else if( pHead->gasordil[i].depth_meter)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1442 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1443 /* note = 3 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1444 headerOSTC3.gasordil[3 + (i*4)] = 3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1445 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1446 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1447 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1448 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1449 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1450 headerOSTC3.logbookProfileVersion = 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1451 headerOSTC3.personalDiveCount[0] = 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1452 headerOSTC3.personalDiveCount[1] = 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1453 headerOSTC3.safetyDistance_10cm = 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1454 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1455
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1456 headerOSTC3.dateYear = pHead->dateYear;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1457 headerOSTC3.dateMonth = pHead->dateMonth;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1458 headerOSTC3.dateDay = pHead->dateDay;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1459 headerOSTC3.timeHour = pHead->timeHour;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1460 headerOSTC3.timeMinute = pHead->timeMinute;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1461
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1462
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1463 memcpy(headerOSTC3.maxDepth, &pHead->maxDepth, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1464 memcpy(headerOSTC3.diveTimeMinutes, &pHead->diveTimeMinutes, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1465
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1466 headerOSTC3.diveTimeSeconds = pHead->diveTimeSeconds;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1467
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1468 memcpy(headerOSTC3.minTemp, &pHead->minTemp, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1469 memcpy(headerOSTC3.surfacePressure_mbar,&pHead->surfacePressure_mbar, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1470 memcpy(headerOSTC3.desaturationTime, &pHead->desaturationTime, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1471
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1472 headerOSTC3.firmwareVersionHigh = pHead->firmwareVersionHigh;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1473 headerOSTC3.firmwareVersionLow = pHead->firmwareVersionLow;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1474
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1475 memcpy(headerOSTC3.batteryVoltage, &pHead->batteryVoltage, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1476
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1477 headerOSTC3.samplingRate = pHead->samplingRate;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1478
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1479 memcpy(headerOSTC3.cnsAtBeginning, &pHead->cnsAtBeginning, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1480
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1481 headerOSTC3.gfAtBeginning = pHead->gfAtBeginning;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1482 headerOSTC3.gfAtEnd = pHead->gfAtEnd;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1483
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1484 memcpy(headerOSTC3.setpoint, pHead->setpoint, 10);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1485
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1486 headerOSTC3.salinity = pHead->salinity;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1487
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1488 memcpy(headerOSTC3.maxCNS, &pHead->maxCNS, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1489 memcpy(headerOSTC3.averageDepth_mbar, &pHead->averageDepth_mbar, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1490 memcpy(headerOSTC3.total_diveTime_seconds,&pHead->total_diveTime_seconds, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1491
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1492 headerOSTC3.gfLow_or_Vpm_conservatism = pHead->gfLow_or_Vpm_conservatism;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1493 headerOSTC3.gfHigh = pHead->gfHigh;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1494 headerOSTC3.decoModel = pHead->decoModel;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1495
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1496 memcpy(headerOSTC3.diveNumber, &pHead->diveNumber, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1497
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1498 headerOSTC3.diveMode = pHead->diveMode;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1499 headerOSTC3.CCRmode = pHead->CCRmode;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1500
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1501 memcpy(headerOSTC3.n2CompartDesatTime_min,pHead->n2CompartDesatTime_min, 16);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1502 memcpy(headerOSTC3.n2Compartments, pHead->n2Compartments, 64);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1503 memcpy(headerOSTC3.heCompartDesatTime_min,pHead->heCompartDesatTime_min, 16);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1504 memcpy(headerOSTC3.heCompartments, pHead->heCompartments, 64);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1505
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1506 headerOSTC3.lastDecostop_m = pHead->lastDecostop_m;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1507
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1508 memcpy(headerOSTC3.hwHudBattery_mV, &pHead->hwHudBattery_mV, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1509
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1510 headerOSTC3.hwHudLastStatus = pHead->hwHudLastStatus;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1511
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1512 memcpy(headerOSTC3.batteryGaugeRegisters,&pHead->batteryGaugeRegisters, 6);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1513
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1514
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1515 memcpy(headerOSTC3.diveHeaderEnd, &pHead->diveHeaderEnd, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1516
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1517 return &headerOSTC3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1518 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1519
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1520
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1521 /********************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1522 * @brief logbook_build_ostc3header_compact. /
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1523 * @author heinrichs weikamp gmbh
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1524 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1525 * @date 31-Juli-2015
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1526 *********************************************************************************/
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1527 SLogbookHeaderOSTC3compact * logbook_build_ostc3header_compact(SLogbookHeader* pHead)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1528 {
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1529 convert_Type data, data2;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1530
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1531
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1532 data.u8bit.byteHigh = 0;
411
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1533 data.u8bit.byteLow = pHead->pBeginProfileData[0];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1534 data.u8bit.byteMidLow = pHead->pBeginProfileData[1];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1535 data.u8bit.byteMidHigh = pHead->pBeginProfileData[2];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1536
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1537 data2.u8bit.byteHigh = 0;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1538 data2.u8bit.byteLow = pHead->pEndProfileData[0];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1539 data2.u8bit.byteMidLow = pHead->pEndProfileData[1];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1540 data2.u8bit.byteMidHigh = pHead->pEndProfileData[2];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1541
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1542 /* check if sample address information are corrupted by address range. */
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1543 /* TODO: Workaround. Better solution would be to check end of ring for 0xFF pattern */
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1544 if((data.u32bit > data2.u32bit) && (data.u32bit < (SAMPLESTOP - 0x9000)))
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1545 {
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1546 data2.u32bit = data.u32bit + DEFAULT_SAMPLES;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1547 pHead->pEndProfileData[0] = data2.u8bit.byteLow;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1548 pHead->pEndProfileData[1] = data2.u8bit.byteMidLow;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1549 pHead->pEndProfileData[2] = data2.u8bit.byteMidHigh;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1550 data.u32bit = DEFAULT_SAMPLES;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1551 }
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1552 else
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1553 {
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1554 data.u8bit.byteHigh = 0;
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1555 data.u8bit.byteLow = pHead->profileLength[0];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1556 data.u8bit.byteMidLow = pHead->profileLength[1];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1557 data.u8bit.byteMidHigh = pHead->profileLength[2];
e908b894f107 Bugfix: Limit log length in case of corrupted sample storage:
ideenmodellierer
parents: 325
diff changeset
1558 }
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1559
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1560 if(data.u32bit != 0xFFFFFF)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1561 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1562 data.u32bit += 3;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1563
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1564 headerOSTC3compact.profileLength[0] = data.u8bit.byteLow;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1565 headerOSTC3compact.profileLength[1] = data.u8bit.byteMidLow;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1566 headerOSTC3compact.profileLength[2] = data.u8bit.byteMidHigh;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1567
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1568 headerOSTC3compact.dateYear = pHead->dateYear;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1569 headerOSTC3compact.dateMonth = pHead->dateMonth;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1570 headerOSTC3compact.dateDay = pHead->dateDay;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1571 headerOSTC3compact.timeHour = pHead->timeHour;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1572 headerOSTC3compact.timeMinute = pHead->timeMinute;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1573
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1574 memcpy(headerOSTC3compact.maxDepth, &pHead->maxDepth, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1575 memcpy(headerOSTC3compact.diveTimeMinutes, &pHead->diveTimeMinutes, 2);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1576
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1577 headerOSTC3compact.diveTimeSeconds = pHead->diveTimeSeconds;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1578
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1579
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1580 headerOSTC3compact.totalDiveNumberLow = pHead->diveNumber & 0xFF;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1581 headerOSTC3compact.totalDiveNumberHigh = (uint8_t)(pHead->diveNumber/256);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1582 headerOSTC3compact.profileVersion = 0x24; // Logbook-Profile version, 0x24 = date and time is start not end
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1583 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1584 else
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1585 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1586 memset(&headerOSTC3compact, 0xFF, sizeof(SLogbookHeaderOSTC3compact));
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1587 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1588 return &headerOSTC3compact;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1589 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1590
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1591
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1592 /**
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1593 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1594 * @brief logbook_readSampleData. / Reads sample data of whole logbook entry
281
54d14bc2083c Fix typos (There are still many...)
heinrichsweikamp
parents: 270
diff changeset
1595 * @author heinrichs weikamp
38
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1596 * @version V0.0.1
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1597 * @date 22-April-2014
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1598 ******************************************************************************
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1599 *
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1600 * @param uint8_t StepBackwards: witch lookbook entry?
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1601 * @param uint16_t length : maxlength of output arrays
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1602 * @param int32_t* depth : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1603 * @param int16_t * gasid : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1604 * @param int32_t* temperature : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1605 * @param int32_t* ppo2 : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1606 * @param int32_t* cns : output array
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1607 * @return length of output
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1608 */
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1609 void logbook_recover_brokenlog(uint8_t headerId)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1610 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1611 int16_t retVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1612 int32_t depthVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1613 int16_t gasidVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1614 int16_t setPointVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1615 int16_t bailoutVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1616 int32_t temperatureVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1617 int32_t sensor1Val = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1618 int32_t sensor2Val = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1619 int32_t sensor3Val = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1620 int32_t cnsVal = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1621 SManualGas manualGasVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1622
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1623 //uint16_t* ppo2, uint16_t* cns#
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1624 uint32_t bytesRead = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1625
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1626 ext_flash_read_block_start();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1627 ext_flash_read_next_sample_part((uint8_t*)&smallHeader, sizeof(SSmallHeader));
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1628 bytesRead += sizeof(SSmallHeader);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1629
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1630 clear_divisor();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1631
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1632
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1633 int sampleCounter = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1634 int maxdepth = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1635 uint32_t avrdepth = 0;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1636 while (true)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1637 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1638
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1639 ext_flash_set_entry_point();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1640 divisorBackup = divisor;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1641 retVal = readSample(&depthVal,&gasidVal, &setPointVal, &temperatureVal, &sensor1Val, &sensor2Val, &sensor3Val, &cnsVal, &manualGasVal, &bailoutVal, NULL);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1642 if(retVal == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1643 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1644 //Error try to read again!!!
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1645 ext_flash_reopen_read_sample_at_entry_point();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1646 divisor = divisorBackup;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1647 retVal = readSample(&depthVal,&gasidVal, &setPointVal, &temperatureVal, &sensor1Val, &sensor2Val, &sensor3Val, &cnsVal, &manualGasVal, &bailoutVal, NULL);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1648
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1649 if(retVal == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1650 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1651 //Error try to read again!!!
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1652 ext_flash_reopen_read_sample_at_entry_point();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1653 divisor = divisorBackup;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1654 retVal = readSample(&depthVal,&gasidVal, &setPointVal, &temperatureVal, &sensor1Val, &sensor2Val, &sensor3Val, &cnsVal, &manualGasVal, &bailoutVal, NULL);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1655
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1656 if(retVal == 0)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1657 {
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1658 ext_flash_reopen_read_sample_at_entry_point();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1659 break;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1660 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1661
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1662 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1663 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1664 if(depthVal > maxdepth)
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1665 maxdepth = depthVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1666 avrdepth += depthVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1667 sampleCounter++;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1668 bytesRead +=retVal;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1669 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1670 avrdepth/= sampleCounter;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1671 ext_flash_close_read_sample();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1672 SLogbookHeader header;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1673
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1674 ext_flash_read_dive_header2((uint8_t*) &header, headerId, false);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1675 header.total_diveTime_seconds = sampleCounter * header.samplingRate;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1676 header.diveTimeMinutes = header.total_diveTime_seconds /60;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1677 header.diveTimeSeconds = header.total_diveTime_seconds - header.diveTimeMinutes * 60;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1678 header.maxDepth = maxdepth;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1679 header.averageDepth_mbar = avrdepth;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1680 SSettings * settings = settingsGetPointer();
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1681 settings->lastDiveLogId = headerId;
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1682 ext_flash_close_new_dive_log((uint8_t *)&header);
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1683 }
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1684
5f11787b4f42 include in ostc4 repository
heinrichsweikamp
parents:
diff changeset
1685 /************************ (C) COPYRIGHT heinrichs weikamp *****END OF FILE****/