/******************************************************************************* * Copyright (C) 2020, Huada Semiconductor Co., Ltd. All rights reserved. * * This software component is licensed by HDSC under BSD 3-Clause license * (the "License"); You may not use this file except in compliance with the * License. You may obtain a copy of the License at: * opensource.org/licenses/BSD-3-Clause */ /******************************************************************************/ /** \file hc32f460_keyscan.c ** ** A detailed description is available at ** @link KeyscanGroup Keyscan module description @endlink ** ** - 2018-10-17 CDT First version for Device Driver Library of keyscan. ** ******************************************************************************/ /******************************************************************************* * Include files ******************************************************************************/ #include "hc32f460_keyscan.h" #include "hc32f460_utility.h" #if (DDL_KEYSCAN_ENABLE == DDL_ON) /** ******************************************************************************* ** \addtogroup KeyscanGroup ******************************************************************************/ //@{ /******************************************************************************* * Local type definitions ('typedef') ******************************************************************************/ /******************************************************************************* * Local pre-processor symbols/macros ('#define') ******************************************************************************/ /*! Parameter validity check for Hiz cycle */ #define IS_VALID_HIZ_CLCYE(x) \ ( ((x) == Hiz4) || \ ((x) == Hiz8) || \ ((x) == Hiz16) || \ ((x) == Hiz32) || \ ((x) == Hiz64) || \ ((x) == Hiz256) || \ ((x) == Hiz512) || \ ((x) == Hiz1K)) /*! Parameter validity check for Low cycle */ #define IS_VALID_LOW_CLCYE(x) \ ( ((x) == Low8) || \ ((x) == Low16) || \ ((x) == Low32) || \ ((x) == Low64) || \ ((x) == Low128) || \ ((x) == Low256) || \ ((x) == Low512) || \ ((x) == Low1K) || \ ((x) == Low2K) || \ ((x) == Low4K) || \ ((x) == Low8K) || \ ((x) == Low16K) || \ ((x) == Low32K) || \ ((x) == Low64K) || \ ((x) == Low128K) || \ ((x) == Low256K) || \ ((x) == Low512K) || \ ((x) == Low1M) || \ ((x) == Low2M) || \ ((x) == Low4M) || \ ((x) == Low8M) || \ ((x) == Low16M)) /*! Parameter validity check for scan clock */ #define IS_VALID_SCAN_CLK(x) \ ( ((x) == KeyscanHclk) || \ ((x) == KeyscanLrc) || \ ((x) == KeyscanXtal32)) /*! Parameter validity check for keyout selection */ #define IS_VALID_KEY_OUT(x) \ ( ((x) == Keyout0To1) || \ ((x) == Keyout0To2) || \ ((x) == Keyout0To3) || \ ((x) == Keyout0To4) || \ ((x) == Keyout0To5) || \ ((x) == Keyout0To6) || \ ((x) == Keyout0To7)) /******************************************************************************* * Global variable definitions (declared in header file with 'extern') ******************************************************************************/ /******************************************************************************* * Local function prototypes ('static') ******************************************************************************/ /******************************************************************************* * Local variable definitions ('static') ******************************************************************************/ /******************************************************************************* * Function implementation - global ('extern') and local ('static') ******************************************************************************/ /** ******************************************************************************* ** \brief KEYSCAN initialization ** ** \param [in] pstcKeyscanConfig KEYSCAN configure structure ** ** \retval Ok KEYSCAN initialized ** ErrorInvalidMode Uninitialized, cannot configure it properly ** ******************************************************************************/ en_result_t KEYSCAN_Init(const stc_keyscan_config_t *pstcKeyscanConfig) { en_result_t enRet = Ok; DDL_ASSERT(IS_VALID_HIZ_CLCYE(pstcKeyscanConfig->enHizCycle)); DDL_ASSERT(IS_VALID_LOW_CLCYE(pstcKeyscanConfig->enLowCycle)); DDL_ASSERT(IS_VALID_SCAN_CLK(pstcKeyscanConfig->enKeyscanClk)); DDL_ASSERT(IS_VALID_KEY_OUT(pstcKeyscanConfig->enKeyoutSel)); /* cannot configure keyscan control register when running */ if (Set == M4_KEYSCAN->SER_f.SEN) { enRet = ErrorInvalidMode; } else { M4_KEYSCAN->SCR_f.T_HIZ = pstcKeyscanConfig->enHizCycle; M4_KEYSCAN->SCR_f.T_LLEVEL = pstcKeyscanConfig->enLowCycle; M4_KEYSCAN->SCR_f.CKSEL = pstcKeyscanConfig->enKeyscanClk; M4_KEYSCAN->SCR_f.KEYOUTSEL = pstcKeyscanConfig->enKeyoutSel; M4_KEYSCAN->SCR_f.KEYINSEL = pstcKeyscanConfig->u16KeyinSel; } return enRet; } /** ******************************************************************************* ** \brief KEYSCAN de-initialization ** ** \param None ** ** \retval Ok KEYSCAN de-initialized ** ******************************************************************************/ en_result_t KEYSCAN_DeInit(void) { M4_KEYSCAN->SER = 0ul; M4_KEYSCAN->SCR = 0ul; return Ok; } /** ******************************************************************************* ** \brief Start keyscan function ** ** \param None ** ** \retval Ok Keyscan function started ** ******************************************************************************/ en_result_t KEYSCAN_Start(void) { M4_KEYSCAN->SER_f.SEN = Set; return Ok; } /** ******************************************************************************* ** \brief Stop keyscan function ** ** \param None ** ** \retval Ok Keyscan function stopped ** ******************************************************************************/ en_result_t KEYSCAN_Stop(void) { M4_KEYSCAN->SER_f.SEN = Reset; return Ok; } /** ******************************************************************************* ** \brief Get Key column index ** ** \param None ** ** \retval uint8_t Index of KEYOUT ** ******************************************************************************/ uint8_t KEYSCAN_GetColIdx(void) { return (uint8_t)(M4_KEYSCAN->SSR_f.INDEX); } //@} // KeyscanGroup #endif /* DDL_KEYSCAN_ENABLE */ /******************************************************************************* * EOF (not truncated) ******************************************************************************/