ipd2015 2.1.0.0
ipd2015.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 IPD2015_H
29#define IPD2015_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 IPD2015_NONE_PIN_MASK 0x00
54#define IPD2015_OUT1_PIN_MASK 0x01
55#define IPD2015_OUT2_PIN_MASK 0x02
56#define IPD2015_OUT3_PIN_MASK 0x04
57#define IPD2015_OUT4_PIN_MASK 0x08
58#define IPD2015_ALL_PIN_MASK 0x0F
59
64#define IPD2015_PIN_STATE_HIGH 0x01
65#define IPD2015_PIN_STATE_LOW 0x00
66 // ipd2015_set
68
83#define IPD2015_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 // ipd2015_map // ipd2015
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} ipd2015_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 IPD2015_ERROR = -1
128
130
147
162
173
184
197err_t iod2015_set_out_level ( ipd2015_t *ctx, uint8_t out_sel, uint8_t state );
198
208
209#ifdef __cplusplus
210}
211#endif
212#endif // IPD2015_H
213 // ipd2015
215
216// ------------------------------------------------------------------------ END
uint8_t iod2015_get_out_state(ipd2015_t *ctx)
IPD 2015 get output level function.
void ipd2015_cfg_setup(ipd2015_cfg_t *cfg)
IPD 2015 configuration object setup function.
void ipd2015_all_pins_clear(ipd2015_t *ctx)
IPD 2015 pin clearing function.
void ipd2015_all_pins_set(ipd2015_t *ctx)
IPD 2015 pin setting function.
err_t ipd2015_init(ipd2015_t *ctx, ipd2015_cfg_t *cfg)
IPD 2015 initialization function.
err_t iod2015_set_out_level(ipd2015_t *ctx, uint8_t out_sel, uint8_t state)
IPD 2015 set output level function.
ipd2015_return_value_t
IPD 2015 Click return value data.
Definition: ipd2015.h:125
@ IPD2015_OK
Definition: ipd2015.h:126
@ IPD2015_ERROR
Definition: ipd2015.h:127
IPD 2015 Click configuration object.
Definition: ipd2015.h:112
pin_name_t in2
Definition: ipd2015.h:114
pin_name_t in1
Definition: ipd2015.h:113
pin_name_t in4
Definition: ipd2015.h:116
pin_name_t in3
Definition: ipd2015.h:115
IPD 2015 Click context object.
Definition: ipd2015.h:97
uint8_t state
Definition: ipd2015.h:103
digital_out_t in2
Definition: ipd2015.h:99
digital_out_t in3
Definition: ipd2015.h:100
digital_out_t in4
Definition: ipd2015.h:101
digital_out_t in1
Definition: ipd2015.h:98