RTEMS  5.1
grpwm.h
1 /*
2  * GRPWM PWM Driver interface.
3  *
4  * COPYRIGHT (c) 2009.
5  * Cobham Gaisler AB.
6  *
7  * The license and distribution terms for this file may be
8  * found in the file LICENSE in this distribution or at
9  * http://www.rtems.org/license/LICENSE.
10  */
11 
12 #ifndef __GRPWM_H__
13 #define __GRPWM_H__
14 
15 #ifdef __cplusplus
16 extern "C" {
17 #endif
18 
19 extern void grpwm_register_drv (void);
20 
21 #define GRPWM_IOCTL_GET_CAP 1 /* Get Capabilities */
22 #define GRPWM_IOCTL_SET_CONFIG 2 /* Configure one PWM Channel */
23 #define GRPWM_IOCTL_SET_SCALER 3 /* Set one scaler */
24 #define GRPWM_IOCTL_UPDATE 4 /* Set current period and compare value */
25 #define GRPWM_IOCTL_IRQ 5 /* Set up IRQ handling */
26 
27 /*** Argument for GRPWM_IOCTL_GET_CAP ***/
28 
29 /* The Capability of the PWM core */
31  int channel_cnt; /* Number of channels */
32  unsigned int pwm; /* Capability1 register */
33  unsigned int wave; /* Capability2 register, Wave form capabilities of last PWM channel, otherwise 0 */
34 };
35 
36 /*** Argument for GRPWM_IOCTL_GET_CONFIG and GRPWM_IOCTL_SET_CONFIG ***/
37 
38 /* Config One PWM */
40  unsigned int channel; /* Select channel to configure */
41 
42  /* Specific for one PWM channel */
43  unsigned int options; /* PWM options */
44  unsigned char dbscaler; /* value greater than 15 disable Dead band */
45  unsigned char scaler_index; /* Select scaler used by PWM channel */
46 
47  /* IRQ Setup */
48  unsigned char irqscaler; /* IRQ scaler */
49  void *isr_arg; /* Argument of IRQ handler */
50  void (*isr)(int channel, void *arg); /* Interrupt service routine for this PWM Channel */
51 
52  /* Waveform set up */
53  int wave_activate; /* Enables Waveform functionality */
54  unsigned int wave_synccfg; /* Bits [29,30,31] is written into Wave-Config register */
55  unsigned int wave_sync; /* Sets sync compare register */
56  unsigned int *wave_data; /* If not NULL, the Wave RAM is filled with data */
57  unsigned int wave_data_length; /* Length of Wave RAM Data, Also used for wstopaddr */
58 };
59 
60 #define GRPWM_CONFIG_OPTION_FLIP 0x04000000 /* Set this to Flip PWM output pair */
61 #define GRPWM_CONFIG_OPTION_DEAD_BAND 0x00200000 /* Dead Band enable */
62 #define GRPWM_CONFIG_OPTION_SYMMETRIC 0x00000040 /* If not defined, asymmetric */
63 #define GRPWM_CONFIG_OPTION_ASYMMERTIC 0
64 #define GRPWM_CONFIG_OPTION_DUAL 0x00000020 /* Dual Compare Enable */
65 #define GRPWM_CONFIG_OPTION_PAIR 0x00000004 /* PWM Pair Enable */
66 #define GRPWM_CONFIG_OPTION_SINGLE 0x00000000 /* PWM Pair Disable */
67 #define GRPWM_CONFIG_OPTION_POLARITY_HIGH 0x00000002 /* PWM Polarity HIGH */
68 #define GRPWM_CONFIG_OPTION_POLARITY_LOW 0x00000000 /* PWM Polarity LOW */
69 
70 #define GRPWM_CONFIG_OPTION_MASK ( \
71  GRPWM_CONFIG_OPTION_DEAD_BAND | GRPWM_CONFIG_OPTION_SYMMETRIC | \
72  GRPWM_CONFIG_OPTION_DUAL | GRPWM_CONFIG_OPTION_PAIR | \
73  GRPWM_CONFIG_OPTION_POLARITY_HIGH \
74  )
75 
76 /*** Argument for GPPWM_IOCTL_SET_SCALER ***/
77 
79  unsigned int index_mask;/* Scaler update index mask, bit 0 = Scaler 0, bit 1 = Scaler 1 */
80  unsigned int values[8]; /* Scaler update values, values[N] is stored into scaler N, if mask & 1<<N is set */
81 };
82 
83 /*** Argument for GRPWM_IOCTL_UPDATE ***/
84 
85 #define GRPWM_UPDATE_OPTION_ENABLE 0x01 /* Enable the PWM core */
86 #define GRPWM_UPDATE_OPTION_DISABLE 0x02 /* Disable the PWM core */
87 #define GRPWM_UPDATE_OPTION_PERIOD 0x04 /* Update period register */
88 #define GRPWM_UPDATE_OPTION_COMP 0x08 /* Update Compare register */
89 #define GRPWM_UPDATE_OPTION_DBCOMP 0x10 /* Update Dead band register */
90 #define GRPWM_UPDATE_OPTION_FIX 0x20 /* Update fix output pins (bypass PWM) */
91 
92 /* FIX PIN bit-mask */
93 #define GRPWM_UPDATE_FIX_ENABLE 1 /* Enable force ouput */
94 #define GRPWM_UPDATE_FIX_DISABLE 0 /* Disable force ouput */
95 #define GRPWM_UPDATE_FIX_0_LOW 0 /* PIN 0 OUPUT: LOW */
96 #define GRPWM_UPDATE_FIX_0_HIGH 2 /* PIN 0 OUPUT: HIGH */
97 #define GRPWM_UPDATE_FIX_1_LOW 0 /* PIN 1 OUPUT: LOW */
98 #define GRPWM_UPDATE_FIX_1_HIGH 4 /* PIN 1 OUPUT: HIGH */
99 
101  unsigned int options; /* Select what is updated */
102  unsigned int period; /* Period register content */
103  unsigned int compare; /* Compare register content */
104  unsigned int dbcomp; /* Dead band register content */
105  unsigned char fix; /* Bit-mask that select output on one or two PWM
106  * output pins. Depends on PAIR config value.
107  */
108 };
110  unsigned char chanmask; /* Bit Mask select channels */
111  struct grpwm_ioctl_update_chan channels[8]; /* */
112 };
113 
114 /*** Argument for GPPWM_IOCTL_IRQ ***/
115 
116 #define GRPWM_IRQ_DISABLE 0 /* Disable IRQ */
117 #define GRPWM_IRQ_PERIOD 1 /* Enable IRQ on period match */
118 #define GRPWM_IRQ_COMPARE 3 /* Enable IRQ on Compare Match */
119 #define GRPWM_IRQ_CLEAR 0x10 /* Clear any pending IRQ on GRPWM and IRQ controller */
120 
121 #define GRPWM_IRQ_CHAN 0x100 /* Channel N is selected, by adding 0x100*N */
122 
123 #ifdef __cplusplus
124 }
125 #endif
126 
127 #endif
Definition: grpwm.h:39
Definition: grpwm.h:100
Definition: grpwm.h:78
Definition: grpwm.h:109
Definition: grpwm.h:30