VSF Documented
pwm.h
Go to the documentation of this file.
1/*****************************************************************************
2 * Copyright(C)2009-2022 by VSF Team *
3 * *
4 * Licensed under the Apache License, Version 2.0 (the "License"); *
5 * you may not use this file except in compliance with the License. *
6 * You may obtain a copy of the License at *
7 * *
8 * http://www.apache.org/licenses/LICENSE-2.0 *
9 * *
10 * Unless required by applicable law or agreed to in writing, software *
11 * distributed under the License is distributed on an "AS IS" BASIS, *
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
13 * See the License for the specific language governing permissions and *
14 * limitations under the License. *
15 * *
16 ****************************************************************************/
17
18#ifndef __HAL_DRIVER_RP2040_PWM_H__
19#define __HAL_DRIVER_RP2040_PWM_H__
20
21/*============================ INCLUDES ======================================*/
22
23#include "hal/vsf_hal_cfg.h"
24
25#if VSF_HAL_USE_PWM == ENABLED
26
27#include "../__device.h"
28
29/*============================ MACROS ========================================*/
30
31/* RP2040 PWM: 8 slices, each with 2 channels (A/B).
32 * VSF models each slice as one PWM instance with 2 channels.
33 *
34 * Hardware reference:
35 * - pwm_hw->slice[0..7].csr : control (EN, PH_CORRECT, A_INV, B_INV)
36 * - pwm_hw->slice[0..7].div : clock divider (INT[11:4] + FRAC[3:0])
37 * - pwm_hw->slice[0..7].ctr : counter
38 * - pwm_hw->slice[0..7].cc : compare (A[15:0], B[31:16])
39 * - pwm_hw->slice[0..7].top : wrap value
40 * - pwm_hw->en : alias of all CSR.EN bits
41 *
42 * Clock: runs from clk_sys (125 MHz default).
43 */
44
45/*============================ MACROFIED FUNCTIONS ===========================*/
46/*============================ TYPES =========================================*/
47
48/*============================ INCLUDES ======================================*/
49/*============================ PROTOTYPES ====================================*/
50
51#endif /* VSF_HAL_USE_PWM */
52#endif /* __HAL_DRIVER_RP2040_PWM_H__ */
53/* EOF */
Generated from commit: vsfteam/vsf@66b3c4c