OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [freertos-6.1.1/] [Demo/] [CORTEX_STM32F103_GCC_Rowley/] [ST Library/] [inc/] [stm32f10x_can.h] - Blame information for rev 582

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 582 jeremybenn
/******************** (C) COPYRIGHT 2008 STMicroelectronics ********************
2
* File Name          : stm32f10x_can.h
3
* Author             : MCD Application Team
4
* Version            : V2.0.1
5
* Date               : 06/13/2008
6
* Description        : This file contains all the functions prototypes for the
7
*                      CAN firmware library.
8
********************************************************************************
9
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
10
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
11
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
12
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
13
* CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
14
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
15
*******************************************************************************/
16
 
17
/* Define to prevent recursive inclusion -------------------------------------*/
18
#ifndef __STM32F10x_CAN_H
19
#define __STM32F10x_CAN_H
20
 
21
/* Includes ------------------------------------------------------------------*/
22
#include "stm32f10x_map.h"
23
 
24
/* Exported types ------------------------------------------------------------*/
25
/* CAN init structure definition */
26
typedef struct
27
{
28
  FunctionalState CAN_TTCM;
29
  FunctionalState CAN_ABOM;
30
  FunctionalState CAN_AWUM;
31
  FunctionalState CAN_NART;
32
  FunctionalState CAN_RFLM;
33
  FunctionalState CAN_TXFP;
34
  u8 CAN_Mode;
35
  u8 CAN_SJW;
36
  u8 CAN_BS1;
37
  u8 CAN_BS2;
38
  u16 CAN_Prescaler;
39
} CAN_InitTypeDef;
40
 
41
/* CAN filter init structure definition */
42
typedef struct
43
{
44
  u8 CAN_FilterNumber;
45
  u8 CAN_FilterMode;
46
  u8 CAN_FilterScale;
47
  u16 CAN_FilterIdHigh;
48
  u16 CAN_FilterIdLow;
49
  u16 CAN_FilterMaskIdHigh;
50
  u16 CAN_FilterMaskIdLow;
51
  u16 CAN_FilterFIFOAssignment;
52
  FunctionalState CAN_FilterActivation;
53
} CAN_FilterInitTypeDef;
54
 
55
/* CAN Tx message structure definition */
56
typedef struct
57
{
58
  u32 StdId;
59
  u32 ExtId;
60
  u8 IDE;
61
  u8 RTR;
62
  u8 DLC;
63
  u8 Data[8];
64
} CanTxMsg;
65
 
66
/* CAN Rx message structure definition */
67
typedef struct
68
{
69
  u32 StdId;
70
  u32 ExtId;
71
  u8 IDE;
72
  u8 RTR;
73
  u8 DLC;
74
  u8 Data[8];
75
  u8 FMI;
76
} CanRxMsg;
77
 
78
/* Exported constants --------------------------------------------------------*/
79
 
80
/* CAN sleep constants */
81
#define CANINITFAILED              ((u8)0x00) /* CAN initialization failed */
82
#define CANINITOK                  ((u8)0x01) /* CAN initialization failed */
83
 
84
/* CAN operating mode */
85
#define CAN_Mode_Normal             ((u8)0x00)  /* normal mode */
86
#define CAN_Mode_LoopBack           ((u8)0x01)  /* loopback mode */
87
#define CAN_Mode_Silent             ((u8)0x02)  /* silent mode */
88
#define CAN_Mode_Silent_LoopBack    ((u8)0x03)  /* loopback combined with silent mode */
89
 
90
#define IS_CAN_MODE(MODE) (((MODE) == CAN_Mode_Normal) || ((MODE) == CAN_Mode_LoopBack)|| \
91
                           ((MODE) == CAN_Mode_Silent) || ((MODE) == CAN_Mode_Silent_LoopBack))
92
 
93
/* CAN synchronisation jump width */
94
#define CAN_SJW_1tq                 ((u8)0x00)  /* 1 time quantum */
95
#define CAN_SJW_2tq                 ((u8)0x01)  /* 2 time quantum */
96
#define CAN_SJW_3tq                 ((u8)0x02)  /* 3 time quantum */
97
#define CAN_SJW_4tq                 ((u8)0x03)  /* 4 time quantum */
98
 
99
#define IS_CAN_SJW(SJW) (((SJW) == CAN_SJW_1tq) || ((SJW) == CAN_SJW_2tq)|| \
100
                         ((SJW) == CAN_SJW_3tq) || ((SJW) == CAN_SJW_4tq))
101
 
102
/* time quantum in bit segment 1 */
103
#define CAN_BS1_1tq                 ((u8)0x00)  /* 1 time quantum */
104
#define CAN_BS1_2tq                 ((u8)0x01)  /* 2 time quantum */
105
#define CAN_BS1_3tq                 ((u8)0x02)  /* 3 time quantum */
106
#define CAN_BS1_4tq                 ((u8)0x03)  /* 4 time quantum */
107
#define CAN_BS1_5tq                 ((u8)0x04)  /* 5 time quantum */
108
#define CAN_BS1_6tq                 ((u8)0x05)  /* 6 time quantum */
109
#define CAN_BS1_7tq                 ((u8)0x06)  /* 7 time quantum */
110
#define CAN_BS1_8tq                 ((u8)0x07)  /* 8 time quantum */
111
#define CAN_BS1_9tq                 ((u8)0x08)  /* 9 time quantum */
112
#define CAN_BS1_10tq                ((u8)0x09)  /* 10 time quantum */
113
#define CAN_BS1_11tq                ((u8)0x0A)  /* 11 time quantum */
114
#define CAN_BS1_12tq                ((u8)0x0B)  /* 12 time quantum */
115
#define CAN_BS1_13tq                ((u8)0x0C)  /* 13 time quantum */
116
#define CAN_BS1_14tq                ((u8)0x0D)  /* 14 time quantum */
117
#define CAN_BS1_15tq                ((u8)0x0E)  /* 15 time quantum */
118
#define CAN_BS1_16tq                ((u8)0x0F)  /* 16 time quantum */
119
 
120
#define IS_CAN_BS1(BS1) ((BS1) <= CAN_BS1_16tq)
121
 
122
/* time quantum in bit segment 2 */
123
#define CAN_BS2_1tq                 ((u8)0x00)  /* 1 time quantum */
124
#define CAN_BS2_2tq                 ((u8)0x01)  /* 2 time quantum */
125
#define CAN_BS2_3tq                 ((u8)0x02)  /* 3 time quantum */
126
#define CAN_BS2_4tq                 ((u8)0x03)  /* 4 time quantum */
127
#define CAN_BS2_5tq                 ((u8)0x04)  /* 5 time quantum */
128
#define CAN_BS2_6tq                 ((u8)0x05)  /* 6 time quantum */
129
#define CAN_BS2_7tq                 ((u8)0x06)  /* 7 time quantum */
130
#define CAN_BS2_8tq                 ((u8)0x07)  /* 8 time quantum */
131
 
132
#define IS_CAN_BS2(BS2) ((BS2) <= CAN_BS2_8tq)
133
 
134
/* CAN clock prescaler */
135
#define IS_CAN_PRESCALER(PRESCALER) (((PRESCALER) >= 1) && ((PRESCALER) <= 1024))
136
 
137
/* CAN filter number */
138
#define IS_CAN_FILTER_NUMBER(NUMBER) ((NUMBER) <= 13)
139
 
140
/* CAN filter mode */
141
#define CAN_FilterMode_IdMask       ((u8)0x00)  /* id/mask mode */
142
#define CAN_FilterMode_IdList       ((u8)0x01)  /* identifier list mode */
143
 
144
#define IS_CAN_FILTER_MODE(MODE) (((MODE) == CAN_FilterMode_IdMask) || \
145
                                  ((MODE) == CAN_FilterMode_IdList))
146
 
147
/* CAN filter scale */
148
#define CAN_FilterScale_16bit       ((u8)0x00) /* 16-bit filter scale */
149
#define CAN_FilterScale_32bit       ((u8)0x01) /* 2-bit filter scale */
150
 
151
#define IS_CAN_FILTER_SCALE(SCALE) (((SCALE) == CAN_FilterScale_16bit) || \
152
                                    ((SCALE) == CAN_FilterScale_32bit))
153
 
154
/* CAN filter FIFO assignation */
155
#define CAN_FilterFIFO0             ((u8)0x00)  /* Filter FIFO 0 assignment for filter x */
156
#define CAN_FilterFIFO1             ((u8)0x01)  /* Filter FIFO 1 assignment for filter x */
157
 
158
#define IS_CAN_FILTER_FIFO(FIFO) (((FIFO) == CAN_FilterFIFO0) || \
159
                                  ((FIFO) == CAN_FilterFIFO1))
160
 
161
/* CAN Tx */
162
#define IS_CAN_TRANSMITMAILBOX(TRANSMITMAILBOX) ((TRANSMITMAILBOX) <= ((u8)0x02))
163
#define IS_CAN_STDID(STDID)   ((STDID) <= ((u32)0x7FF))
164
#define IS_CAN_EXTID(EXTID)   ((EXTID) <= ((u32)0x1FFFFFFF))
165
#define IS_CAN_DLC(DLC)       ((DLC) <= ((u8)0x08))
166
 
167
/* CAN identifier type */
168
#define CAN_ID_STD                 ((u32)0x00000000)  /* Standard Id */
169
#define CAN_ID_EXT                 ((u32)0x00000004)  /* Extended Id */
170
 
171
#define IS_CAN_IDTYPE(IDTYPE) (((IDTYPE) == CAN_ID_STD) || ((IDTYPE) == CAN_ID_EXT))
172
 
173
/* CAN remote transmission request */
174
#define CAN_RTR_DATA                ((u32)0x00000000)  /* Data frame */
175
#define CAN_RTR_REMOTE              ((u32)0x00000002)  /* Remote frame */
176
 
177
#define IS_CAN_RTR(RTR) (((RTR) == CAN_RTR_DATA) || ((RTR) == CAN_RTR_REMOTE))
178
 
179
/* CAN transmit constants */
180
#define CANTXFAILED                 ((u8)0x00) /* CAN transmission failed */
181
#define CANTXOK                     ((u8)0x01) /* CAN transmission succeeded */
182
#define CANTXPENDING                ((u8)0x02) /* CAN transmission pending */
183
#define CAN_NO_MB                   ((u8)0x04) /* CAN cell did not provide an empty mailbox */
184
 
185
/* CAN receive FIFO number constants */
186
#define CAN_FIFO0                 ((u8)0x00) /* CAN FIFO0 used to receive */
187
#define CAN_FIFO1                 ((u8)0x01) /* CAN FIFO1 used to receive */
188
 
189
#define IS_CAN_FIFO(FIFO) (((FIFO) == CAN_FIFO0) || ((FIFO) == CAN_FIFO1))
190
 
191
/* CAN sleep constants */
192
#define CANSLEEPFAILED              ((u8)0x00) /* CAN did not enter the sleep mode */
193
#define CANSLEEPOK                  ((u8)0x01) /* CAN entered the sleep mode */
194
 
195
/* CAN wake up constants */
196
#define CANWAKEUPFAILED             ((u8)0x00) /* CAN did not leave the sleep mode */
197
#define CANWAKEUPOK                 ((u8)0x01) /* CAN leaved the sleep mode */
198
 
199
/* CAN flags */
200
#define CAN_FLAG_EWG                ((u32)0x00000001) /* Error Warning Flag */
201
#define CAN_FLAG_EPV                ((u32)0x00000002) /* Error Passive Flag */
202
#define CAN_FLAG_BOF                ((u32)0x00000004) /* Bus-Off Flag */
203
 
204
#define IS_CAN_FLAG(FLAG) (((FLAG) == CAN_FLAG_EWG) || ((FLAG) == CAN_FLAG_EPV) ||\
205
                           ((FLAG) == CAN_FLAG_BOF))
206
 
207
/* CAN interrupts */
208
#define CAN_IT_RQCP0                ((u32)0x00000005) /* Request completed mailbox 0 */
209
#define CAN_IT_RQCP1                ((u32)0x00000006) /* Request completed mailbox 1 */
210
#define CAN_IT_RQCP2                ((u32)0x00000007) /* Request completed mailbox 2 */
211
#define CAN_IT_TME                  ((u32)0x00000001) /* Transmit mailbox empty */
212
#define CAN_IT_FMP0                 ((u32)0x00000002) /* FIFO 0 message pending */
213
#define CAN_IT_FF0                  ((u32)0x00000004) /* FIFO 0 full */
214
#define CAN_IT_FOV0                 ((u32)0x00000008) /* FIFO 0 overrun */
215
#define CAN_IT_FMP1                 ((u32)0x00000010) /* FIFO 1 message pending */
216
#define CAN_IT_FF1                  ((u32)0x00000020) /* FIFO 1 full */
217
#define CAN_IT_FOV1                 ((u32)0x00000040) /* FIFO 1 overrun */
218
#define CAN_IT_EWG                  ((u32)0x00000100) /* Error warning */
219
#define CAN_IT_EPV                  ((u32)0x00000200) /* Error passive */
220
#define CAN_IT_BOF                  ((u32)0x00000400) /* Bus-off */
221
#define CAN_IT_LEC                  ((u32)0x00000800) /* Last error code */
222
#define CAN_IT_ERR                  ((u32)0x00008000) /* Error */
223
#define CAN_IT_WKU                  ((u32)0x00010000) /* Wake-up */
224
#define CAN_IT_SLK                  ((u32)0x00020000) /* Sleep */
225
 
226
#define IS_CAN_ITConfig(IT) (((IT) == CAN_IT_TME)   || ((IT) == CAN_IT_FMP0)  ||\
227
                             ((IT) == CAN_IT_FF0)   || ((IT) == CAN_IT_FOV0)  ||\
228
                             ((IT) == CAN_IT_FMP1)  || ((IT) == CAN_IT_FF1)   ||\
229
                             ((IT) == CAN_IT_FOV1)  || ((IT) == CAN_IT_EWG)   ||\
230
                             ((IT) == CAN_IT_EPV)   || ((IT) == CAN_IT_BOF)   ||\
231
                             ((IT) == CAN_IT_LEC)   || ((IT) == CAN_IT_ERR)   ||\
232
                             ((IT) == CAN_IT_WKU)   || ((IT) == CAN_IT_SLK))
233
 
234
#define IS_CAN_ITStatus(IT) (((IT) == CAN_IT_RQCP0)  || ((IT) == CAN_IT_RQCP1)  ||\
235
                             ((IT) == CAN_IT_RQCP2)  || ((IT) == CAN_IT_FF0)    ||\
236
                             ((IT) == CAN_IT_FOV0)   || ((IT) == CAN_IT_FF1)    ||\
237
                             ((IT) == CAN_IT_FOV1)   || ((IT) == CAN_IT_EWG)    ||\
238
                             ((IT) == CAN_IT_EPV)    || ((IT) == CAN_IT_BOF)    ||\
239
                             ((IT) == CAN_IT_WKU)    || ((IT) == CAN_IT_SLK))
240
 
241
/* Exported macro ------------------------------------------------------------*/
242
/* Exported function protypes ----------------------------------------------- */
243
void CAN_DeInit(void);
244
u8 CAN_Init(CAN_InitTypeDef* CAN_InitStruct);
245
void CAN_FilterInit(CAN_FilterInitTypeDef* CAN_FilterInitStruct);
246
void CAN_StructInit(CAN_InitTypeDef* CAN_InitStruct);
247
void CAN_ITConfig(u32 CAN_IT, FunctionalState NewState);
248
u8 CAN_Transmit(CanTxMsg* TxMessage);
249
u8 CAN_TransmitStatus(u8 TransmitMailbox);
250
void CAN_CancelTransmit(u8 Mailbox);
251
void CAN_FIFORelease(u8 FIFONumber);
252
u8 CAN_MessagePending(u8 FIFONumber);
253
void CAN_Receive(u8 FIFONumber, CanRxMsg* RxMessage);
254
u8 CAN_Sleep(void);
255
u8 CAN_WakeUp(void);
256
FlagStatus CAN_GetFlagStatus(u32 CAN_FLAG);
257
void CAN_ClearFlag(u32 CAN_FLAG);
258
ITStatus CAN_GetITStatus(u32 CAN_IT);
259
void CAN_ClearITPendingBit(u32 CAN_IT);
260
 
261
#endif /* __STM32F10x_CAN_H */
262
 
263
/******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.