summaryrefslogtreecommitdiff
path: root/arch/arm/include/asm/arch-sunxi/pwm.h
blob: dca283c7a93aacb9b4f33ed558f487312c4b78d4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/* SPDX-License-Identifier: GPL-2.0+ */
/*
 * (C) Copyright 2016 Hans de Goede <hdegoede@redhat.com>
 */

#ifndef _SUNXI_PWM_H
#define _SUNXI_PWM_H

#define SUNXI_PWM_CTRL_REG		(SUNXI_PWM_BASE + 0)
#define SUNXI_PWM_CH0_PERIOD		(SUNXI_PWM_BASE + 4)

#define SUNXI_PWM_CTRL_PRESCALE0(x)	((x) & 0xf)
#define SUNXI_PWM_CTRL_PRESCALE0_MASK	0xf
#define SUNXI_PWM_CTRL_ENABLE0		(0x5 << 4)
#define SUNXI_PWM_CTRL_POLARITY0(x)	((x) << 5)
#define SUNXI_PWM_CTRL_CH0_ACT_STA	BIT(5)
#define SUNXI_PWM_CTRL_CLK_GATE		BIT(6)

#define SUNXI_PWM_CH0_PERIOD_MAX	(0xffff)
#define SUNXI_PWM_CH0_PERIOD_PRD(x)	((x & 0xffff) << 16)
#define SUNXI_PWM_CH0_PERIOD_DUTY(x)	((x) & 0xffff)

#define SUNXI_PWM_PERIOD_80PCT		0x04af03c0

#if defined CONFIG_MACH_SUN4I || defined CONFIG_MACH_SUN5I
#define SUNXI_PWM_PIN0			SUNXI_GPB(2)
#define SUNXI_PWM_MUX			SUN4I_GPB_PWM
#endif

#if defined CONFIG_MACH_SUN6I
#define SUNXI_PWM_PIN0			SUNXI_GPH(13)
#define SUNXI_PWM_MUX			SUN6I_GPH_PWM
#endif

#if defined CONFIG_MACH_SUN8I_A23 || defined CONFIG_MACH_SUN8I_A33
#define SUNXI_PWM_PIN0			SUNXI_GPH(0)
#define SUNXI_PWM_MUX			SUN8I_GPH_PWM
#endif

struct sunxi_pwm {
	u32 ctrl;
	u32 ch0_period;
};

#endif