guo ecf2d82159
sync branch rt-smart. (#6641)
* Synchronize the code of the rt mart branch to the master branch.
  * TTY device
  * Add lwP code from rt-smart
  * Add vnode in DFS, but DFS will be re-write for rt-smart
  * There are three libcpu for rt-smart:
    * arm/cortex-a, arm/aarch64
    * riscv64

Co-authored-by: Rbb666 <zhangbingru@rt-thread.com>
Co-authored-by: zhkag <zhkag@foxmail.com>
2022-12-03 12:07:44 +08:00

129 lines
4.9 KiB
C
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/* Copyright (c) 2019-2025 Allwinner Technology Co., Ltd. ALL rights reserved.
* Allwinner is a trademark of Allwinner Technology Co.,Ltd., registered in
* the the People's Republic of China and other countries.
* All Allwinner Technology Co.,Ltd. trademarks are used with permission.
* DISCLAIMER
* THIRD PARTY LICENCES MAY BE REQUIRED TO IMPLEMENT THE SOLUTION/PRODUCT.
* IF YOU NEED TO INTEGRATE THIRD PARTYS TECHNOLOGY (SONY, DTS, DOLBY, AVS OR MPEGLA, ETC.)
* IN ALLWINNERSSDK OR PRODUCTS, YOU SHALL BE SOLELY RESPONSIBLE TO OBTAIN
* ALL APPROPRIATELY REQUIRED THIRD PARTY LICENCES.
* ALLWINNER SHALL HAVE NO WARRANTY, INDEMNITY OR OTHER OBLIGATIONS WITH RESPECT TO MATTERS
* COVERED UNDER ANY REQUIRED THIRD PARTY LICENSE.
* YOU ARE SOLELY RESPONSIBLE FOR YOUR USAGE OF THIRD PARTYS TECHNOLOGY.
* THIS SOFTWARE IS PROVIDED BY ALLWINNER"AS IS" AND TO THE MAXIMUM EXTENT
* PERMITTED BY LAW, ALLWINNER EXPRESSLY DISCLAIMS ALL WARRANTIES OF ANY KIND,
* WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING WITHOUT LIMITATION REGARDING
* THE TITLE, NON-INFRINGEMENT, ACCURACY, CONDITION, COMPLETENESS, PERFORMANCE
* OR MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
* IN NO EVENT SHALL ALLWINNER BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS, OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef __PWM_SUN8IW19_H__
#define __PWM_SUN8IW19_H__
/*****************************************************************************
* define register offset
*****************************************************************************/
#define PWM_BASE 0x0300a000
#define PWM_PIER 0x00 /*PWM IRQ enable register 0x00*/
#define PWM_PISR 0x04 /*PWM IRQ status register 0x04*/
#define PWM_CIER 0x10 /*PWM capture IRQ enable register 0x10*/
#define PWM_CISR 0X14 /*PWM capture IRQ status register 0X14*/
#define PWM_PCCR_BASE 0x20
#define PWM_PCCR01 0x20 /*PWM01 clock configuration register*/
#define PWM_PCCR23 0x24 /*PWM23 clock configuration register */
#define PWM_PCCR45 0x28 /*PWM45 clock configuration register */
#define PWM_PCCR67 0x2C /*PWM67 clock configuration register */
#define PWM_PCCR8 0x30 /*PWM8 clock configuration register */
#define PWM_PCGR 0X40 /*PWM CLOCK Gating Register 0X40*/
#define PWM_PDZCR_BASE 0X60
#define PWM_PDZCR01 0X60 /*PWM01 Dead Zone Contol Register 0X60*/
#define PWM_PDZCR23 0X64 /*PWM23 Dead Zone Contol Register 0X64*/
#define PWM_PDZCR45 0X68 /*PWM45 Dead Zone Contol Register 0X68*/
#define PWM_PDZCR67 0X6C /*PWM67 Dead Zone Contol Register 0X6C*/
#define PWM_PDZCR89 0X70 /*PWM89 Dead Zone Contol Register 0X70*/
#define PWM_PER 0x80 /*enable register 0x80*/
#define PWM_PGR0 0X90 /*PWM Group0 Register 0X90*/
#define PWM_PGR1 0X94 /*PWM Group0 Register 0X94*/
#define PWM_CER 0xc0 /*PWM Capture Enable Register */
#define PWM_PCR 0x0100/*PWM Contorl Register */
/* offset: 0x0100+0x0000+N*0x0020 N=0~8 */
#define PWM_PPR 0x0104/*PWM Period Register */
/* offset: 0x0100+0x00004+N*0x0020 N=0~8 */
#define PWM_PCNTR 0x0108/*PWM Counter Register */
/* offset: 0x0100+0x0008+N*0x0020 N=0~8 */
#define PWM_PPCNTR 0x010C/*PWM Pulse Counter Register */
/* offset: 0x0100+0x000c+N*0x0020 N=0~8 */
#define PWM_CCR 0x0110/*Capture Control Register */
/* offset: 0x0100+0x0010+N*0x0020 N=0~8 */
#define PWM_CRLR 0x0114/*Capture RIse Lock Register */
/* offset: 0x0100+0x0014+N*0x0020 N=0~8 */
#define PWM_CFLR 0x0118/*Capture Control Register */
/* offset: 0x0100+0x0018+N*0x0020 N=0~8 */
#define PWM_VR 0x03f0/*PWM Version Register */
/*****************************************************************************
* define PWM SET
*****************************************************************************/
#define PWM_CLK_SRC_SHIFT 0x7
#define PWM_CLK_SRC_WIDTH 0x2
#define PWM_DIV_M_SHIFT 0x0
#define PWM_DIV_M_WIDTH 0x4
#define PWM_PRESCAL_SHIFT 0x0
#define PWM_PRESCAL_WIDTH 0x8
#define PWM_ACTIVE_CYCLES_SHIFT 0x0
#define PWM_ACTIVE_CYCLES_WIDTH 0x10
#define PWM_PERIOD_SHIFT 0x10
#define PWM_PERIOD_WIDTH 0x10
#define PWM_CLK_GATING_SHIFT 0x0
#define PWM_CLK_GATING_WIDTH 0x1
#define PWM_EN_CONTROL_SHIFT 0x0
#define PWM_EN_CONTORL_WIDTH 0x1
#define PWM_ACT_STA_SHIFT 0x8
#define PWM_ACT_STA_WIDTH 0x1
#define PWM_NUM 10
#endif /* __PWM-SUN8IW19_H__ */