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