ipd2017 2.1.0.0
ipd2017.h
Go to the documentation of this file.
1/****************************************************************************
2** Copyright (C) 2020 MikroElektronika d.o.o.
3** Contact: https://www.mikroe.com/contact
4**
5** Permission is hereby granted, free of charge, to any person obtaining a copy
6** of this software and associated documentation files (the "Software"), to deal
7** in the Software without restriction, including without limitation the rights
8** to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9** copies of the Software, and to permit persons to whom the Software is
10** furnished to do so, subject to the following conditions:
11** The above copyright notice and this permission notice shall be
12** included in all copies or substantial portions of the Software.
13**
14** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
16** OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
17** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
18** DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT
19** OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20** USE OR OTHER DEALINGS IN THE SOFTWARE.
21****************************************************************************/
22
28#ifndef IPD2017_H
29#define IPD2017_H
30
31#ifdef __cplusplus
32extern "C"{
33#endif
34
35#include "drv_digital_out.h"
36#include "drv_digital_in.h"
37
53#define IPD2017_NONE_PIN_MASK 0x00
54#define IPD2017_OUT1_PIN_MASK 0x01
55#define IPD2017_OUT2_PIN_MASK 0x02
56#define IPD2017_OUT3_PIN_MASK 0x04
57#define IPD2017_OUT4_PIN_MASK 0x08
58#define IPD2017_ALL_PIN_MASK 0x0F
59
64#define IPD2017_PIN_STATE_HIGH 0x01
65#define IPD2017_PIN_STATE_LOW 0x00
66 // ipd2017_set
68
83#define IPD2017_MAP_MIKROBUS( cfg, mikrobus ) \
84 cfg.in1 = MIKROBUS( mikrobus, MIKROBUS_AN ); \
85 cfg.in2 = MIKROBUS( mikrobus, MIKROBUS_RST ); \
86 cfg.in3 = MIKROBUS( mikrobus, MIKROBUS_PWM ); \
87 cfg.in4 = MIKROBUS( mikrobus, MIKROBUS_INT )
88 // ipd2017_map // ipd2017
91
96typedef struct
97{
98 digital_out_t in1;
99 digital_out_t in2;
100 digital_out_t in3;
101 digital_out_t in4;
103 uint8_t state;
105} ipd2017_t;
106
111typedef struct
112{
113 pin_name_t in1;
114 pin_name_t in2;
115 pin_name_t in3;
116 pin_name_t in4;
119
124typedef enum
125{
127 IPD2017_ERROR = -1
128
130
147
162
173
184
197err_t ipd2017_set_out_level ( ipd2017_t *ctx, uint8_t out_sel, uint8_t state );
198
208
209#ifdef __cplusplus
210}
211#endif
212#endif // IPD2017_H
213 // ipd2017
215
216// ------------------------------------------------------------------------ END
void ipd2017_all_pins_set(ipd2017_t *ctx)
IPD 2017 pin setting function.
err_t ipd2017_set_out_level(ipd2017_t *ctx, uint8_t out_sel, uint8_t state)
IPD 2017 set output level function.
void ipd2017_cfg_setup(ipd2017_cfg_t *cfg)
IPD 2017 configuration object setup function.
void ipd2017_all_pins_clear(ipd2017_t *ctx)
IPD 2017 pin clearing function.
uint8_t ipd2017_get_out_state(ipd2017_t *ctx)
IPD 2017 get output level function.
err_t ipd2017_init(ipd2017_t *ctx, ipd2017_cfg_t *cfg)
IPD 2017 initialization function.
ipd2017_return_value_t
IPD 2017 Click return value data.
Definition: ipd2017.h:125
@ IPD2017_ERROR
Definition: ipd2017.h:127
@ IPD2017_OK
Definition: ipd2017.h:126
IPD 2017 Click configuration object.
Definition: ipd2017.h:112
pin_name_t in2
Definition: ipd2017.h:114
pin_name_t in1
Definition: ipd2017.h:113
pin_name_t in4
Definition: ipd2017.h:116
pin_name_t in3
Definition: ipd2017.h:115
IPD 2017 Click context object.
Definition: ipd2017.h:97
uint8_t state
Definition: ipd2017.h:103
digital_out_t in2
Definition: ipd2017.h:99
digital_out_t in3
Definition: ipd2017.h:100
digital_out_t in4
Definition: ipd2017.h:101
digital_out_t in1
Definition: ipd2017.h:98