danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 1 | /* |
| 2 | * This file is part of the Micro Python project, http://micropython.org/ |
| 3 | * |
| 4 | * The MIT License (MIT) |
| 5 | * |
| 6 | * Copyright (c) 2013, 2014 Damien P. George |
| 7 | * Copyright (c) 2015 Daniel Campora |
| 8 | * |
| 9 | * Permission is hereby granted, free of charge, to any person obtaining a copy |
| 10 | * of this software and associated documentation files (the "Software"), to deal |
| 11 | * in the Software without restriction, including without limitation the rights |
| 12 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
| 13 | * copies of the Software, and to permit persons to whom the Software is |
| 14 | * furnished to do so, subject to the following conditions: |
| 15 | * |
| 16 | * The above copyright notice and this permission notice shall be included in |
| 17 | * all copies or substantial portions of the Software. |
| 18 | * |
| 19 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| 20 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| 21 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
| 22 | * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| 23 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| 24 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
| 25 | * THE SOFTWARE. |
| 26 | */ |
| 27 | |
| 28 | #include <stdio.h> |
| 29 | #include <string.h> |
| 30 | |
Damien George | 4a23a01 | 2015-02-21 18:58:43 +0000 | [diff] [blame] | 31 | #include "py/mpconfig.h" |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 32 | #include "py/nlr.h" |
| 33 | #include "py/runtime.h" |
| 34 | #include "py/binary.h" |
| 35 | #include "py/gc.h" |
Damien George | 22a6344 | 2017-02-22 12:36:23 +1100 | [diff] [blame] | 36 | #include "py/mperrno.h" |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 37 | #include "bufhelper.h" |
| 38 | #include "inc/hw_types.h" |
| 39 | #include "inc/hw_adc.h" |
| 40 | #include "inc/hw_ints.h" |
| 41 | #include "inc/hw_memmap.h" |
| 42 | #include "rom_map.h" |
| 43 | #include "interrupt.h" |
| 44 | #include "pin.h" |
danicampora | d226dd2 | 2015-02-27 16:50:06 +0100 | [diff] [blame] | 45 | #include "gpio.h" |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 46 | #include "prcm.h" |
| 47 | #include "adc.h" |
| 48 | #include "pybadc.h" |
| 49 | #include "pybpin.h" |
danicampora | b761ed2 | 2015-03-11 21:49:50 +0100 | [diff] [blame] | 50 | #include "pybsleep.h" |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 51 | #include "pins.h" |
| 52 | #include "mpexception.h" |
| 53 | |
| 54 | |
danicampora | 6de1b39 | 2015-03-17 11:05:59 +0100 | [diff] [blame] | 55 | /****************************************************************************** |
| 56 | DECLARE CONSTANTS |
| 57 | ******************************************************************************/ |
| 58 | #define PYB_ADC_NUM_CHANNELS 4 |
| 59 | |
| 60 | /****************************************************************************** |
| 61 | DEFINE TYPES |
| 62 | ******************************************************************************/ |
| 63 | typedef struct { |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 64 | mp_obj_base_t base; |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 65 | bool enabled; |
| 66 | } pyb_adc_obj_t; |
| 67 | |
| 68 | typedef struct { |
| 69 | mp_obj_base_t base; |
Daniel Campora | 7027fd5 | 2015-08-10 16:44:20 +0200 | [diff] [blame] | 70 | pin_obj_t *pin; |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 71 | byte channel; |
Daniel Campora | 7027fd5 | 2015-08-10 16:44:20 +0200 | [diff] [blame] | 72 | byte id; |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 73 | bool enabled; |
| 74 | } pyb_adc_channel_obj_t; |
| 75 | |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 76 | |
danicampora | 6de1b39 | 2015-03-17 11:05:59 +0100 | [diff] [blame] | 77 | /****************************************************************************** |
Daniel Campora | 7027fd5 | 2015-08-10 16:44:20 +0200 | [diff] [blame] | 78 | DECLARE PRIVATE DATA |
| 79 | ******************************************************************************/ |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 80 | STATIC pyb_adc_channel_obj_t pyb_adc_channel_obj[PYB_ADC_NUM_CHANNELS] = { {.pin = &pin_GP2, .channel = ADC_CH_0, .id = 0, .enabled = false}, |
| 81 | {.pin = &pin_GP3, .channel = ADC_CH_1, .id = 1, .enabled = false}, |
| 82 | {.pin = &pin_GP4, .channel = ADC_CH_2, .id = 2, .enabled = false}, |
| 83 | {.pin = &pin_GP5, .channel = ADC_CH_3, .id = 3, .enabled = false} }; |
| 84 | STATIC pyb_adc_obj_t pyb_adc_obj = {.enabled = false}; |
| 85 | |
| 86 | STATIC const mp_obj_type_t pyb_adc_channel_type; |
| 87 | |
| 88 | /****************************************************************************** |
| 89 | DECLARE PRIVATE FUNCTIONS |
| 90 | ******************************************************************************/ |
| 91 | STATIC mp_obj_t adc_channel_deinit(mp_obj_t self_in); |
Daniel Campora | 7027fd5 | 2015-08-10 16:44:20 +0200 | [diff] [blame] | 92 | |
| 93 | /****************************************************************************** |
danicampora | 6de1b39 | 2015-03-17 11:05:59 +0100 | [diff] [blame] | 94 | DEFINE PUBLIC FUNCTIONS |
| 95 | ******************************************************************************/ |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 96 | STATIC void pyb_adc_init (pyb_adc_obj_t *self) { |
danicampora | b761ed2 | 2015-03-11 21:49:50 +0100 | [diff] [blame] | 97 | // enable and configure the timer |
| 98 | MAP_ADCTimerConfig(ADC_BASE, (1 << 17) - 1); |
| 99 | MAP_ADCTimerEnable(ADC_BASE); |
| 100 | // enable the ADC peripheral |
| 101 | MAP_ADCEnable(ADC_BASE); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 102 | self->enabled = true; |
| 103 | } |
| 104 | |
| 105 | STATIC void pyb_adc_check_init(void) { |
| 106 | // not initialized |
| 107 | if (!pyb_adc_obj.enabled) { |
Damien George | 22a6344 | 2017-02-22 12:36:23 +1100 | [diff] [blame] | 108 | mp_raise_OSError(MP_EPERM); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 109 | } |
| 110 | } |
| 111 | |
| 112 | STATIC void pyb_adc_channel_init (pyb_adc_channel_obj_t *self) { |
| 113 | // the ADC block must be enabled first |
| 114 | pyb_adc_check_init(); |
| 115 | // configure the pin in analog mode |
| 116 | pin_config (self->pin, -1, PIN_TYPE_ANALOG, PIN_TYPE_STD, -1, PIN_STRENGTH_2MA); |
| 117 | // enable the ADC channel |
| 118 | MAP_ADCChannelEnable(ADC_BASE, self->channel); |
| 119 | self->enabled = true; |
| 120 | } |
| 121 | |
| 122 | STATIC void pyb_adc_deinit_all_channels (void) { |
| 123 | for (int i = 0; i < PYB_ADC_NUM_CHANNELS; i++) { |
| 124 | adc_channel_deinit(&pyb_adc_channel_obj[i]); |
| 125 | } |
danicampora | b761ed2 | 2015-03-11 21:49:50 +0100 | [diff] [blame] | 126 | } |
| 127 | |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 128 | /******************************************************************************/ |
| 129 | /* Micro Python bindings : adc object */ |
| 130 | |
Damien George | 7f9d1d6 | 2015-04-09 23:56:15 +0100 | [diff] [blame] | 131 | STATIC void adc_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) { |
danicampora | 6de1b39 | 2015-03-17 11:05:59 +0100 | [diff] [blame] | 132 | pyb_adc_obj_t *self = self_in; |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 133 | if (self->enabled) { |
| 134 | mp_printf(print, "ADC(0, bits=12)"); |
| 135 | } else { |
| 136 | mp_printf(print, "ADC(0)"); |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 137 | } |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 138 | } |
| 139 | |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 140 | STATIC const mp_arg_t pyb_adc_init_args[] = { |
| 141 | { MP_QSTR_id, MP_ARG_INT, {.u_int = 0} }, |
| 142 | { MP_QSTR_bits, MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = 12} }, |
| 143 | }; |
Paul Sokolovsky | eac22e2 | 2017-01-04 16:10:42 +0300 | [diff] [blame] | 144 | STATIC mp_obj_t adc_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *all_args) { |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 145 | // parse args |
| 146 | mp_map_t kw_args; |
| 147 | mp_map_init_fixed_table(&kw_args, n_kw, all_args + n_args); |
| 148 | mp_arg_val_t args[MP_ARRAY_SIZE(pyb_adc_init_args)]; |
| 149 | mp_arg_parse_all(n_args, all_args, &kw_args, MP_ARRAY_SIZE(args), pyb_adc_init_args, args); |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 150 | |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 151 | // check the peripheral id |
| 152 | if (args[0].u_int != 0) { |
Damien George | 22a6344 | 2017-02-22 12:36:23 +1100 | [diff] [blame] | 153 | mp_raise_OSError(MP_ENODEV); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 154 | } |
| 155 | |
| 156 | // check the number of bits |
| 157 | if (args[1].u_int != 12) { |
Damien George | 50ddaaf | 2016-10-18 09:53:43 +1100 | [diff] [blame] | 158 | mp_raise_ValueError(mpexception_value_invalid_arguments); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 159 | } |
| 160 | |
| 161 | // setup the object |
| 162 | pyb_adc_obj_t *self = &pyb_adc_obj; |
| 163 | self->base.type = &pyb_adc_type; |
| 164 | |
| 165 | // initialize and register with the sleep module |
| 166 | pyb_adc_init(self); |
Daniel Campora | c92e6a4 | 2015-09-27 13:45:48 +0200 | [diff] [blame] | 167 | pyb_sleep_add ((const mp_obj_t)self, (WakeUpCB_t)pyb_adc_init); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 168 | return self; |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 169 | } |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 170 | |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 171 | STATIC mp_obj_t adc_init(mp_uint_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) { |
| 172 | // parse args |
| 173 | mp_arg_val_t args[MP_ARRAY_SIZE(pyb_adc_init_args) - 1]; |
| 174 | mp_arg_parse_all(n_args - 1, pos_args + 1, kw_args, MP_ARRAY_SIZE(args), &pyb_adc_init_args[1], args); |
| 175 | // check the number of bits |
| 176 | if (args[0].u_int != 12) { |
Damien George | 50ddaaf | 2016-10-18 09:53:43 +1100 | [diff] [blame] | 177 | mp_raise_ValueError(mpexception_value_invalid_arguments); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 178 | } |
| 179 | pyb_adc_init(pos_args[0]); |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 180 | return mp_const_none; |
| 181 | } |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 182 | STATIC MP_DEFINE_CONST_FUN_OBJ_KW(adc_init_obj, 1, adc_init); |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 183 | |
Daniel Campora | 7027fd5 | 2015-08-10 16:44:20 +0200 | [diff] [blame] | 184 | STATIC mp_obj_t adc_deinit(mp_obj_t self_in) { |
danicampora | 6de1b39 | 2015-03-17 11:05:59 +0100 | [diff] [blame] | 185 | pyb_adc_obj_t *self = self_in; |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 186 | // first deinit all channels |
| 187 | pyb_adc_deinit_all_channels(); |
| 188 | MAP_ADCDisable(ADC_BASE); |
| 189 | self->enabled = false; |
danicampora | ea43fa1 | 2015-03-16 13:18:29 +0100 | [diff] [blame] | 190 | // unregister it with the sleep module |
Daniel Campora | c92e6a4 | 2015-09-27 13:45:48 +0200 | [diff] [blame] | 191 | pyb_sleep_remove ((const mp_obj_t)self); |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 192 | return mp_const_none; |
| 193 | } |
Daniel Campora | 7027fd5 | 2015-08-10 16:44:20 +0200 | [diff] [blame] | 194 | STATIC MP_DEFINE_CONST_FUN_OBJ_1(adc_deinit_obj, adc_deinit); |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 195 | |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 196 | STATIC mp_obj_t adc_channel(mp_uint_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) { |
| 197 | STATIC const mp_arg_t pyb_adc_channel_args[] = { |
danicampora | 2e0cd20 | 2015-10-19 11:41:29 +0200 | [diff] [blame] | 198 | { MP_QSTR_id, MP_ARG_OBJ, {.u_obj = MP_OBJ_NULL} }, |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 199 | { MP_QSTR_pin, MP_ARG_KW_ONLY | MP_ARG_OBJ, {.u_obj = mp_const_none} }, |
| 200 | }; |
| 201 | |
| 202 | // parse args |
| 203 | mp_arg_val_t args[MP_ARRAY_SIZE(pyb_adc_channel_args)]; |
| 204 | mp_arg_parse_all(n_args - 1, pos_args + 1, kw_args, MP_ARRAY_SIZE(args), pyb_adc_channel_args, args); |
| 205 | |
| 206 | uint ch_id; |
danicampora | 2e0cd20 | 2015-10-19 11:41:29 +0200 | [diff] [blame] | 207 | if (args[0].u_obj != MP_OBJ_NULL) { |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 208 | ch_id = mp_obj_get_int(args[0].u_obj); |
| 209 | if (ch_id >= PYB_ADC_NUM_CHANNELS) { |
Damien George | 22a6344 | 2017-02-22 12:36:23 +1100 | [diff] [blame] | 210 | mp_raise_ValueError(mpexception_value_invalid_arguments); |
danicampora | 2e0cd20 | 2015-10-19 11:41:29 +0200 | [diff] [blame] | 211 | } else if (args[1].u_obj != mp_const_none) { |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 212 | uint pin_ch_id = pin_find_peripheral_type (args[1].u_obj, PIN_FN_ADC, 0); |
| 213 | if (ch_id != pin_ch_id) { |
Damien George | 50ddaaf | 2016-10-18 09:53:43 +1100 | [diff] [blame] | 214 | mp_raise_ValueError(mpexception_value_invalid_arguments); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 215 | } |
| 216 | } |
| 217 | } else { |
| 218 | ch_id = pin_find_peripheral_type (args[1].u_obj, PIN_FN_ADC, 0); |
| 219 | } |
| 220 | |
| 221 | // setup the object |
| 222 | pyb_adc_channel_obj_t *self = &pyb_adc_channel_obj[ch_id]; |
| 223 | self->base.type = &pyb_adc_channel_type; |
| 224 | pyb_adc_channel_init (self); |
| 225 | // register it with the sleep module |
Daniel Campora | c92e6a4 | 2015-09-27 13:45:48 +0200 | [diff] [blame] | 226 | pyb_sleep_add ((const mp_obj_t)self, (WakeUpCB_t)pyb_adc_channel_init); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 227 | return self; |
| 228 | } |
| 229 | STATIC MP_DEFINE_CONST_FUN_OBJ_KW(adc_channel_obj, 1, adc_channel); |
| 230 | |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 231 | STATIC const mp_map_elem_t adc_locals_dict_table[] = { |
Daniel Campora | 7027fd5 | 2015-08-10 16:44:20 +0200 | [diff] [blame] | 232 | { MP_OBJ_NEW_QSTR(MP_QSTR_init), (mp_obj_t)&adc_init_obj }, |
| 233 | { MP_OBJ_NEW_QSTR(MP_QSTR_deinit), (mp_obj_t)&adc_deinit_obj }, |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 234 | { MP_OBJ_NEW_QSTR(MP_QSTR_channel), (mp_obj_t)&adc_channel_obj }, |
danicampora | 868fa82 | 2015-02-19 21:03:21 +0100 | [diff] [blame] | 235 | }; |
| 236 | |
| 237 | STATIC MP_DEFINE_CONST_DICT(adc_locals_dict, adc_locals_dict_table); |
| 238 | |
| 239 | const mp_obj_type_t pyb_adc_type = { |
| 240 | { &mp_type_type }, |
| 241 | .name = MP_QSTR_ADC, |
| 242 | .print = adc_print, |
| 243 | .make_new = adc_make_new, |
| 244 | .locals_dict = (mp_obj_t)&adc_locals_dict, |
| 245 | }; |
| 246 | |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 247 | STATIC void adc_channel_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) { |
| 248 | pyb_adc_channel_obj_t *self = self_in; |
| 249 | if (self->enabled) { |
| 250 | mp_printf(print, "ADCChannel(%u, pin=%q)", self->id, self->pin->name); |
| 251 | } else { |
| 252 | mp_printf(print, "ADCChannel(%u)", self->id); |
| 253 | } |
| 254 | } |
| 255 | |
| 256 | STATIC mp_obj_t adc_channel_init(mp_obj_t self_in) { |
| 257 | pyb_adc_channel_obj_t *self = self_in; |
| 258 | // re-enable it |
| 259 | pyb_adc_channel_init(self); |
| 260 | return mp_const_none; |
| 261 | } |
| 262 | STATIC MP_DEFINE_CONST_FUN_OBJ_1(adc_channel_init_obj, adc_channel_init); |
| 263 | |
| 264 | STATIC mp_obj_t adc_channel_deinit(mp_obj_t self_in) { |
| 265 | pyb_adc_channel_obj_t *self = self_in; |
| 266 | |
| 267 | MAP_ADCChannelDisable(ADC_BASE, self->channel); |
| 268 | // unregister it with the sleep module |
Daniel Campora | c92e6a4 | 2015-09-27 13:45:48 +0200 | [diff] [blame] | 269 | pyb_sleep_remove ((const mp_obj_t)self); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 270 | self->enabled = false; |
| 271 | return mp_const_none; |
| 272 | } |
| 273 | STATIC MP_DEFINE_CONST_FUN_OBJ_1(adc_channel_deinit_obj, adc_channel_deinit); |
| 274 | |
| 275 | STATIC mp_obj_t adc_channel_value(mp_obj_t self_in) { |
| 276 | pyb_adc_channel_obj_t *self = self_in; |
| 277 | uint32_t value; |
| 278 | |
| 279 | // the channel must be enabled |
| 280 | if (!self->enabled) { |
Damien George | 22a6344 | 2017-02-22 12:36:23 +1100 | [diff] [blame] | 281 | mp_raise_OSError(MP_EPERM); |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 282 | } |
| 283 | |
| 284 | // wait until a new value is available |
| 285 | while (!MAP_ADCFIFOLvlGet(ADC_BASE, self->channel)); |
| 286 | // read the sample |
| 287 | value = MAP_ADCFIFORead(ADC_BASE, self->channel); |
| 288 | // the 12 bit sampled value is stored in bits [13:2] |
| 289 | return MP_OBJ_NEW_SMALL_INT((value & 0x3FFF) >> 2); |
| 290 | } |
| 291 | STATIC MP_DEFINE_CONST_FUN_OBJ_1(adc_channel_value_obj, adc_channel_value); |
| 292 | |
Paul Sokolovsky | eac22e2 | 2017-01-04 16:10:42 +0300 | [diff] [blame] | 293 | STATIC mp_obj_t adc_channel_call(mp_obj_t self_in, size_t n_args, size_t n_kw, const mp_obj_t *args) { |
Daniel Campora | 22b4c28 | 2015-09-14 20:03:32 +0200 | [diff] [blame] | 294 | mp_arg_check_num(n_args, n_kw, 0, 0, false); |
| 295 | return adc_channel_value (self_in); |
| 296 | } |
| 297 | |
| 298 | STATIC const mp_map_elem_t adc_channel_locals_dict_table[] = { |
| 299 | { MP_OBJ_NEW_QSTR(MP_QSTR_init), (mp_obj_t)&adc_channel_init_obj }, |
| 300 | { MP_OBJ_NEW_QSTR(MP_QSTR_deinit), (mp_obj_t)&adc_channel_deinit_obj }, |
| 301 | { MP_OBJ_NEW_QSTR(MP_QSTR_value), (mp_obj_t)&adc_channel_value_obj }, |
| 302 | }; |
| 303 | |
| 304 | STATIC MP_DEFINE_CONST_DICT(adc_channel_locals_dict, adc_channel_locals_dict_table); |
| 305 | |
| 306 | STATIC const mp_obj_type_t pyb_adc_channel_type = { |
| 307 | { &mp_type_type }, |
| 308 | .name = MP_QSTR_ADCChannel, |
| 309 | .print = adc_channel_print, |
| 310 | .call = adc_channel_call, |
| 311 | .locals_dict = (mp_obj_t)&adc_channel_locals_dict, |
| 312 | }; |