11bd4fe43Sopenharmony_ci/* 21bd4fe43Sopenharmony_ci * Copyright (c) 2021 HiSilicon (Shanghai) Technologies CO., LIMITED. 31bd4fe43Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 41bd4fe43Sopenharmony_ci * you may not use this file except in compliance with the License. 51bd4fe43Sopenharmony_ci * You may obtain a copy of the License at 61bd4fe43Sopenharmony_ci * 71bd4fe43Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 81bd4fe43Sopenharmony_ci * 91bd4fe43Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 101bd4fe43Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 111bd4fe43Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 121bd4fe43Sopenharmony_ci * See the License for the specific language governing permissions and 131bd4fe43Sopenharmony_ci * limitations under the License. 141bd4fe43Sopenharmony_ci */ 151bd4fe43Sopenharmony_ci 161bd4fe43Sopenharmony_ci#ifndef ADC_HI35XX_H 171bd4fe43Sopenharmony_ci#define ADC_HI35XX_H 181bd4fe43Sopenharmony_ci 191bd4fe43Sopenharmony_ci#ifdef __cplusplus 201bd4fe43Sopenharmony_ci#if __cplusplus 211bd4fe43Sopenharmony_ciextern "C" { 221bd4fe43Sopenharmony_ci#endif /* __cplusplus */ 231bd4fe43Sopenharmony_ci#endif /* __cplusplus */ 241bd4fe43Sopenharmony_ci 251bd4fe43Sopenharmony_ci/* 261bd4fe43Sopenharmony_ci * Adc Register Offsets 271bd4fe43Sopenharmony_ci */ 281bd4fe43Sopenharmony_ci 291bd4fe43Sopenharmony_ci#define HI35XX_ADC_CONFIG 0x0 301bd4fe43Sopenharmony_ci#define HI35XX_ADC_GLITCH_SAMPLE 0x4 311bd4fe43Sopenharmony_ci#define HI35XX_ADC_TIME_SCAN 0x8 321bd4fe43Sopenharmony_ci#define HI35XX_ADC_INTR_EN 0x10 331bd4fe43Sopenharmony_ci#define HI35XX_ADC_INTR_STATUS 0x14 341bd4fe43Sopenharmony_ci#define HI35XX_ADC_INTR_CLEAR 0x18 351bd4fe43Sopenharmony_ci#define HI35XX_ADC_START 0x1c 361bd4fe43Sopenharmony_ci#define HI35XX_ADC_STOP 0x20 371bd4fe43Sopenharmony_ci#define HI35XX_ADC_ACCURACY 0x24 381bd4fe43Sopenharmony_ci#define HI35XX_ADC_ZERO 0x28 391bd4fe43Sopenharmony_ci#define HI35XX_ADC_DATA0 0x2c 401bd4fe43Sopenharmony_ci#define HI35XX_ADC_DATA1 0x30 411bd4fe43Sopenharmony_ci 421bd4fe43Sopenharmony_ci#define HI35XX_ADC_IO_CONFIG_BASE 0x111f0030 431bd4fe43Sopenharmony_ci#define HI35XX_ADC_IO_CONFIG_SIZE 0x8 441bd4fe43Sopenharmony_ci#define HI35XX_ADC_IO_CONFIG_0 0x0 451bd4fe43Sopenharmony_ci#define HI35XX_ADC_IO_CONFIG_1 0x4 461bd4fe43Sopenharmony_ci 471bd4fe43Sopenharmony_ci#define CYCLE_SCAN_MODE 1 481bd4fe43Sopenharmony_ci#define DEFAULT_DATA_WIDTH 8 491bd4fe43Sopenharmony_ci#define MAX_DATA_WIDTH 10 501bd4fe43Sopenharmony_ci#define DEFAULT_GLITCHSAMPLE 5000 511bd4fe43Sopenharmony_ci#define TIME_SCAN_MINIMUM 20 521bd4fe43Sopenharmony_ci#define TIME_SCAN_CALCULATOR (1000000 * 3) 531bd4fe43Sopenharmony_ci 541bd4fe43Sopenharmony_ci#define DELTA_OFFSET 20 551bd4fe43Sopenharmony_ci#define DEGLITCH_OFFSET 17 561bd4fe43Sopenharmony_ci#define SCAN_MODE_OFFSET 13 571bd4fe43Sopenharmony_ci#define VALID_CHANNEL_OFFSET 8 581bd4fe43Sopenharmony_ci 591bd4fe43Sopenharmony_ci#define DATA_WIDTH_MASK 0x3ff 601bd4fe43Sopenharmony_ci#define DELTA_MASK 0xf 611bd4fe43Sopenharmony_ci#define VALID_CHANNEL_MASK 0x3 621bd4fe43Sopenharmony_ci#define CONFIG_REG_RESET_VALUE 0x80ff 631bd4fe43Sopenharmony_ci#define PINCTRL_MASK 0xf 641bd4fe43Sopenharmony_ci 651bd4fe43Sopenharmony_cienum ScanMode { 661bd4fe43Sopenharmony_ci CYCLE_MODE = 0, 671bd4fe43Sopenharmony_ci SINGLE_MODE, 681bd4fe43Sopenharmony_ci}; 691bd4fe43Sopenharmony_ci 701bd4fe43Sopenharmony_ci#ifdef __cplusplus 711bd4fe43Sopenharmony_ci#if __cplusplus 721bd4fe43Sopenharmony_ci} 731bd4fe43Sopenharmony_ci#endif /* __cplusplus */ 741bd4fe43Sopenharmony_ci#endif /* __cplusplus */ 751bd4fe43Sopenharmony_ci#endif /* ADC_HI35XX_H */ 76