Statistics
| Branch: | Tag: | Revision:

amiro-os / test / periphery-lld / TPS6211x_v1_INA219_v1 / aos_test_TPS6211x_INA219.c @ b23ca7cc

History | View | Annotate | Download (4.278 KB)

1
/*
2
AMiRo-OS is an operating system designed for the Autonomous Mini Robot (AMiRo) platform.
3
Copyright (C) 2016..2019  Thomas Schöpping et al.
4

5
This program is free software: you can redistribute it and/or modify
6
it under the terms of the GNU General Public License as published by
7
the Free Software Foundation, either version 3 of the License, or
8
(at your option) any later version.
9

10
This program is distributed in the hope that it will be useful,
11
but WITHOUT ANY WARRANTY; without even the implied warranty of
12
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
GNU General Public License for more details.
14

15
You should have received a copy of the GNU General Public License
16
along with this program.  If not, see <http://www.gnu.org/licenses/>.
17
*/
18

    
19
#include <amiroos.h>
20
#include <aos_test_TPS6211x_INA219.h>
21

    
22
#if (AMIROOS_CFG_TESTS_ENABLE == true) || defined(__DOXYGEN__)
23

    
24
/******************************************************************************/
25
/* LOCAL DEFINITIONS                                                          */
26
/******************************************************************************/
27

    
28
/******************************************************************************/
29
/* EXPORTED VARIABLES                                                         */
30
/******************************************************************************/
31

    
32
/******************************************************************************/
33
/* LOCAL TYPES                                                                */
34
/******************************************************************************/
35

    
36
/******************************************************************************/
37
/* LOCAL VARIABLES                                                            */
38
/******************************************************************************/
39

    
40
/******************************************************************************/
41
/* LOCAL FUNCTIONS                                                            */
42
/******************************************************************************/
43

    
44
/******************************************************************************/
45
/* EXPORTED FUNCTIONS                                                         */
46
/******************************************************************************/
47

    
48
aos_testresult_t aosTestTps6211xIna219Func(BaseSequentialStream *stream, const aos_test_t* test)
49
{
50
  aosDbgCheck(test->data != NULL && ((aos_test_tps6211xina219data_t*)test->data)->tps6211x != NULL && ((aos_test_tps6211xina219data_t*)test->data)->ina219 != NULL);
51

    
52
  // local variables
53
  aos_testresult_t result = {0, 0};
54
  int32_t status;
55
  tps6211x_lld_power_en_t power;
56
  uint32_t v_buson, v_busoff;
57

    
58
  chprintf(stream, "read pin...\n");
59
  status = tps6211x_lld_get_power_en(((aos_test_tps6211xina219data_t*)test->data)->tps6211x, &power);
60
  aosThdSSleep(1);
61
  status |= ina219_lld_read_bus_voltage(((aos_test_tps6211xina219data_t*)test->data)->ina219, &v_buson, ((aos_test_tps6211xina219data_t*)test->data)->timeout);
62
  if (status == APAL_STATUS_SUCCESS && power == TPS6211x_LLD_POWER_ENABLED) {
63
    aosTestPassedMsg(stream, &result, "enabled, %fV\n", (float)v_buson / 1000000.0f);
64
  } else {
65
    aosTestFailedMsg(stream, &result, "0x%08X\n", status);
66
  }
67

    
68
  chprintf(stream, "write pin...\n");
69
  status = tps6211x_lld_set_power_en(((aos_test_tps6211xina219data_t*)test->data)->tps6211x, TPS6211x_LLD_POWER_DISABLED);
70
  status |= tps6211x_lld_get_power_en(((aos_test_tps6211xina219data_t*)test->data)->tps6211x, &power);
71
  aosThdSSleep(1);
72
  status |= ina219_lld_read_bus_voltage(((aos_test_tps6211xina219data_t*)test->data)->ina219, &v_busoff, ((aos_test_tps6211xina219data_t*)test->data)->timeout);
73
  status |= tps6211x_lld_set_power_en(((aos_test_tps6211xina219data_t*)test->data)->tps6211x, TPS6211x_LLD_POWER_ENABLED);
74
  if (status == APAL_STATUS_SUCCESS && power == TPS6211x_LLD_POWER_DISABLED) {
75
    chprintf(stream, "\tdisabled, %fV\n", (float)v_busoff / 1000000.0f);
76
    if (v_buson > v_busoff) {
77
      aosTestPassed(stream, &result);
78
    } else {
79
      aosTestFailedMsg(stream, &result, "on: %fV; off: %fV\n", (float)v_buson / 1000000.0f, (float)v_busoff / 1000000.0f);
80
    }
81
  } else {
82
    aosTestFailedMsg(stream, &result, "0x%08X\n", status);
83
  }
84

    
85
  return result;
86
}
87

    
88
#endif /* (AMIROOS_CFG_TESTS_ENABLE == true) */