Data_AirPressure.c 12.8 KB
Newer Older
hu's avatar
hu committed
1 2 3 4 5
#include "Data_AirPressure.h"
#include "Gauges.h"
#include "CAN_Communication_Matrix.h"
#include "RTE_ADC.h"

hu's avatar
hu committed
6
#include "Common_Interface.h"
hu's avatar
hu committed
7
#include "kwp2000_service.h"
hu's avatar
hu committed
8

9 10 11
DataStruct DataStrGas1;
DataStruct DataStrGas2;
DataStruct DataStrWET;
hu's avatar
hu committed
12 13 14

/*-------------------------------------------------------------------------
 * Function Name  : AirPressure_KL30_Init
hu's avatar
hu committed
15
 * Description    :
hu's avatar
hu committed
16 17 18 19 20 21
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : Table固化 斜率同时固化
 --------------------------------------------------------------------------*/
void AirPressure_KL30_Init(void)
hu's avatar
hu committed
22 23
{
}
24
void AirPressure_KL15_ON_Init(void)
hu's avatar
hu committed
25
{
26 27 28 29
    uint8_t i = 0u;
    /*气压1结构体初始化*/
    DataStrGas1.Count = 0u;
    for (i = 0; i < 15u; i++)
hu's avatar
hu committed
30
    {
31
        DataStrGas1.DataBuf[i] = 0u;
hu's avatar
hu committed
32
    }
33 34 35 36 37 38 39 40
    DataStrGas1.DataDisplay = 0u;
    DataStrGas1.Valid = 0u;
    DataStrGas1.LostTimer = 0u;
    DataStrGas1.Status = 0u;

    /*气压2结构体初始化*/
    DataStrGas2.Count = 0u;
    for (i = 0; i < 15u; i++)
hu's avatar
hu committed
41
    {
42
        DataStrGas2.DataBuf[i] = 0u;
hu's avatar
hu committed
43
    }
44 45 46 47 48 49 50 51 52 53 54 55 56 57
    DataStrGas2.DataDisplay = 0u;
    DataStrGas2.Valid = 0u;
    DataStrGas2.LostTimer = 0u;
    DataStrGas2.Status = 0u;

    /*wet 气压结构体初始化*/
    DataStrWET.Count = 0u;
    for (i = 0; i < 15u; i++)
    {
        DataStrWET.DataBuf[i] = 0u;
    }
    DataStrWET.DataDisplay = 0u;
    DataStrWET.Valid = 0u;
    DataStrWET.LostTimer = 0u;
hu's avatar
hu committed
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
}
void AirPressure_KL15_OFF_Init(void)
{
}
void AirPressure_Wakeup_Init(void)
{
}
void AirPressure_Sleep_Init(void)
{
}
/*-------------------------------------------------------------------------
 * Function Name  : AirPressure_Processing_Service
 * Description    : 主函数周期调用
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
void AirPressure_Processing_Service(void)
{
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
    Data_Gas1_Processing_Service();
    Data_Gas2_Processing_Service();
    Data_WET_Processing_Service();

    SetGaugesPara(PRIGasGauges, DataStrGas1.DataDisplay);
    SetGaugesPara(SECGasGauges, DataStrGas2.DataDisplay);
    SetGaugesPara(WETGasGauges, DataStrWET.DataDisplay);
}

/*-------------------------------------------------------------------------
 * Function Name  : Data_Gas1_Processing_Service
 * Description    : 气压1
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
void Data_Gas1_Processing_Service(void)
{
    uint32_t Gas_Value = 0u;
    uint32_t data = 0u;
hu's avatar
hu committed
99

100 101 102 103 104 105 106 107
    if ((K_Line_Set.K_Line_LID42 == 0x00) || (K_Line_Set.K_Line_LID42 == 0x02))
    {
        Gas_Value = RTE_Read_PRIMARY_AIR_Voltage();
    }
    else if ((K_Line_Set.K_Line_LID42 == 0x01) || (K_Line_Set.K_Line_LID42 == 0x03))
    {
        Gas_Value = RTE_Read_SECONDARY_AIR_Voltage();
    }
hu's avatar
hu committed
108

109
    if ((Common_Get_IG_Sts_Valid() == 1u) && (Common_Get_IG_Sts() == COMMON_POWER_ON))
hu's avatar
hu committed
110
    {
hu's avatar
hu committed
111
        if ((Gas_Value < 250u) || (Gas_Value > 4250u))
hu's avatar
hu committed
112
        {
113
            if (DataStrGas1.LostTimer < 200u)
hu's avatar
hu committed
114
            {
115 116 117 118 119 120 121 122 123 124
                if (DataStrGas1.Valid == 1u)
                {
                    DataStrGas1.LostTimer++;
                }
                else
                {
                    DataStrGas1.Count = 0u;
                    DataStrGas1.DataDisplay = 0u;
                    DataStrGas1.LostTimer = 200u;
                }
hu's avatar
hu committed
125 126 127
            }
            else
            {
128 129 130 131
                DataStrGas1.Valid = 0u;
                DataStrGas1.Count = 0u;
                DataStrGas1.DataDisplay = 0u;
                DataStrGas1.Status = 1u;
hu's avatar
hu committed
132 133 134 135
            }
        }
        else
        {
136 137 138
            DataStrGas1.Status = 0u;
            DataStrGas1.LostTimer = 0u;
            if (DataStrGas1.Valid == 0u)
hu's avatar
hu committed
139
            {
140 141
                DataStrGas1.DataDisplay = Gas_Value;
                DataStrGas1.Valid = 1u;
hu's avatar
hu committed
142 143 144
            }
            else
            {
145 146 147 148 149 150 151 152 153 154 155 156 157 158 159
                if (DataStrGas1.Count >= 15)
                {
                    DataStrGas1.Count = 0u;
                    App_SortNByte(DataStrGas1.DataBuf, 5u);
                    App_SortNByte(DataStrGas1.DataBuf + 5u, 5u);
                    App_SortNByte(DataStrGas1.DataBuf + 10u, 5u);
                    data = (DataStrGas1.DataBuf[2u] + DataStrGas1.DataBuf[7u] + DataStrGas1.DataBuf[12u]);
                    data = data / 3u;
                    DataStrGas1.DataDisplay = (uint16_t)data;
                }
                else
                {
                    DataStrGas1.Count++;
                    DataStrGas1.DataBuf[DataStrGas1.Count - 1u] = Gas_Value;
                }
hu's avatar
hu committed
160 161
            }
        }
162 163 164 165 166 167 168 169
    }
    else
    {
        DataStrGas1.Count = 0u;
        DataStrGas1.DataDisplay = 0u;
        DataStrGas1.Valid = 0u;
        DataStrGas1.LostTimer = 0u;
        DataStrGas1.Status = 0u;
hu's avatar
hu committed
170
    }
hu's avatar
hu committed
171
}
172

hu's avatar
hu committed
173
/*-------------------------------------------------------------------------
174 175
 * Function Name  : Data_Gas2_Processing_Service
 * Description    : 气压2
hu's avatar
hu committed
176 177 178 179 180
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
181
void Data_Gas2_Processing_Service(void)
hu's avatar
hu committed
182
{
183 184
    uint32_t Gas_Value = 0u;
    uint32_t data = 0u;
hu's avatar
hu committed
185

186
    if ((K_Line_Set.K_Line_LID42 == 0x00) || (K_Line_Set.K_Line_LID42 == 0x02))
hu's avatar
hu committed
187
    {
188
        Gas_Value = RTE_Read_SECONDARY_AIR_Voltage();
hu's avatar
hu committed
189
    }
190
    else if ((K_Line_Set.K_Line_LID42 == 0x01) || (K_Line_Set.K_Line_LID42 == 0x03))
hu's avatar
hu committed
191
    {
192
        Gas_Value = RTE_Read_PRIMARY_AIR_Voltage();
hu's avatar
hu committed
193
    }
194 195

    if ((Common_Get_IG_Sts_Valid() == 1u) && (Common_Get_IG_Sts() == COMMON_POWER_ON))
hu's avatar
hu committed
196
    {
hu's avatar
hu committed
197
        if ((Gas_Value < 250u) || (Gas_Value > 4250u))
hu's avatar
hu committed
198
        {
199 200 201 202 203 204 205 206 207 208 209 210 211 212
            if (DataStrGas2.LostTimer < 200u)
            {
                if (DataStrGas2.Valid == 1u)
                {
                    DataStrGas2.LostTimer++;
                }
                else
                {
                    DataStrGas2.Count = 0u;
                    DataStrGas2.DataDisplay = 0u;
                    DataStrGas2.LostTimer = 200u;
                }
            }
            else
hu's avatar
hu committed
213
            {
214 215 216 217
                DataStrGas2.Valid = 0u;
                DataStrGas2.Count = 0u;
                DataStrGas2.DataDisplay = 0u;
                DataStrGas2.Status = 1u;
hu's avatar
hu committed
218 219
            }
        }
220
        else
hu's avatar
hu committed
221
        {
222 223 224 225 226 227 228 229
            DataStrGas2.Status = 0u;
            DataStrGas2.LostTimer = 0u;
            if (DataStrGas2.Valid == 0u)
            {
                DataStrGas2.DataDisplay = Gas_Value;
                DataStrGas2.Valid = 1u;
            }
            else
hu's avatar
hu committed
230
            {
231 232 233 234 235 236 237 238 239 240 241 242 243 244 245
                if (DataStrGas2.Count >= 15)
                {
                    DataStrGas2.Count = 0u;
                    App_SortNByte(DataStrGas2.DataBuf, 5u);
                    App_SortNByte(DataStrGas2.DataBuf + 5u, 5u);
                    App_SortNByte(DataStrGas2.DataBuf + 10u, 5u);
                    data = (DataStrGas2.DataBuf[2u] + DataStrGas2.DataBuf[7u] + DataStrGas2.DataBuf[12u]);
                    data = data / 3u;
                    DataStrGas2.DataDisplay = (uint16_t)data;
                }
                else
                {
                    DataStrGas2.Count++;
                    DataStrGas2.DataBuf[DataStrGas2.Count - 1u] = Gas_Value;
                }
hu's avatar
hu committed
246 247 248 249 250
            }
        }
    }
    else
    {
251 252 253 254 255
        DataStrGas2.Count = 0u;
        DataStrGas2.DataDisplay = 0u;
        DataStrGas2.Valid = 0u;
        DataStrGas2.LostTimer = 0u;
        DataStrGas2.Status = 0u;
hu's avatar
hu committed
256
    }
hu's avatar
hu committed
257
}
258

hu's avatar
hu committed
259
/*-------------------------------------------------------------------------
260 261
 * Function Name  : Data_WET_Processing_Service
 * Description    : WET 气压
hu's avatar
hu committed
262 263 264 265 266
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
267
void Data_WET_Processing_Service(void)
hu's avatar
hu committed
268
{
269 270
    uint32_t Gas_Value = 0u;
    uint32_t data = 0u;
hu's avatar
hu committed
271

hu's avatar
hu committed
272 273
    if ((K_Line_Set.K_Line_LID42 == 0x00) || (K_Line_Set.K_Line_LID42 == 0x02))
    {
274
        Gas_Value = RTE_Read_WET_AIR_Voltage();
hu's avatar
hu committed
275 276 277
    }
    else if ((K_Line_Set.K_Line_LID42 == 0x01) || (K_Line_Set.K_Line_LID42 == 0x03))
    {
278
        Gas_Value = RTE_Read_WET_AIR_Voltage();
hu's avatar
hu committed
279 280
    }

281
    if ((Common_Get_IG_Sts_Valid() == 1u) && (Common_Get_IG_Sts() == COMMON_POWER_ON))
hu's avatar
hu committed
282
    {
hu's avatar
hu committed
283
        if ((Gas_Value < 500u) || (Gas_Value > 4500u))
hu's avatar
hu committed
284
        {
285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303
            if (DataStrWET.LostTimer < 200u)
            {
                if (DataStrWET.Valid == 1u)
                {
                    DataStrWET.LostTimer++;
                }
                else
                {
                    DataStrWET.Count = 0u;
                    DataStrWET.DataDisplay = 0u;
                    DataStrWET.LostTimer = 200u;
                }
            }
            else
            {
                DataStrWET.Valid = 0u;
                DataStrWET.Count = 0u;
                DataStrWET.DataDisplay = 0u;
            }
hu's avatar
hu committed
304 305 306
        }
        else
        {
307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330
            DataStrWET.LostTimer = 0u;
            if (DataStrWET.Valid == 0u)
            {
                DataStrWET.DataDisplay = Gas_Value;
                DataStrWET.Valid = 1u;
            }
            else
            {
                if (DataStrWET.Count >= 15)
                {
                    DataStrWET.Count = 0u;
                    App_SortNByte(DataStrWET.DataBuf, 5u);
                    App_SortNByte(DataStrWET.DataBuf + 5u, 5u);
                    App_SortNByte(DataStrWET.DataBuf + 10u, 5u);
                    data = (DataStrWET.DataBuf[2u] + DataStrWET.DataBuf[7u] + DataStrWET.DataBuf[12u]);
                    data = data / 3u;
                    DataStrWET.DataDisplay = (uint16_t)data;
                }
                else
                {
                    DataStrWET.Count++;
                    DataStrWET.DataBuf[DataStrWET.Count - 1u] = Gas_Value;
                }
            }
hu's avatar
hu committed
331 332 333 334
        }
    }
    else
    {
335 336 337 338
        DataStrWET.Count = 0u;
        DataStrWET.DataDisplay = 0u;
        DataStrWET.Valid = 0u;
        DataStrWET.LostTimer = 0u;
hu's avatar
hu committed
339
    }
hu's avatar
hu committed
340
}
hu's avatar
hu committed
341

hu's avatar
hu committed
342
/*-------------------------------------------------------------------------
343 344
 * Function Name  : Common_Get_Air1_Valid
 * Description    : 获取气压 1 的有效性
hu's avatar
hu committed
345 346 347 348 349
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
350
uint8_t Common_Get_Air1_Valid(void)
hu's avatar
hu committed
351
{
352
    return DataStrGas1.Valid;
hu's avatar
hu committed
353
}
354

hu's avatar
hu committed
355
/*-------------------------------------------------------------------------
356 357
 * Function Name  : Common_Get_Air2_Valid
 * Description    : 获取气压 2 的有效性
hu's avatar
hu committed
358 359 360 361 362
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
363
uint8_t Common_Get_Air2_Valid(void)
hu's avatar
hu committed
364
{
365
    return DataStrGas2.Valid;
hu's avatar
hu committed
366
}
367

hu's avatar
hu committed
368
/*-------------------------------------------------------------------------
369 370
 * Function Name  : Common_Get_WET_Valid
 * Description    : 获取 WET 有效性
hu's avatar
hu committed
371 372 373 374 375
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
376
uint8_t Common_Get_WET_Valid(void)
hu's avatar
hu committed
377
{
378
    return DataStrWET.Valid;
hu's avatar
hu committed
379 380
}

381 382 383 384 385 386 387 388
/*-------------------------------------------------------------------------
 * Function Name  : Common_Get_Air1_Data
 * Description    : 获取
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
hu's avatar
hu committed
389 390 391 392 393
uint16_t Common_Get_Air1_Data(void)
{
    return DataStrGas1.DataDisplay;
}

394 395 396 397 398 399 400 401
/*-------------------------------------------------------------------------
 * Function Name  : Common_Get_Air2_Data
 * Description    : 获取
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
hu's avatar
hu committed
402 403 404 405 406
uint16_t Common_Get_Air2_Data(void)
{
    return DataStrGas2.DataDisplay;
}

407 408 409 410 411 412 413 414
/*-------------------------------------------------------------------------
 * Function Name  : Common_Get_WET_Data
 * Description    : 获取
 * Input          : None
 * Output         : None
 * Return         : None
 * onther         : None
 --------------------------------------------------------------------------*/
hu's avatar
hu committed
415 416 417 418
uint16_t Common_Get_WET_Data(void)
{
    return DataStrWET.DataDisplay;
}