Subversion Repositories NaviCtrl

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
196 killagreg 1
/******************** (C) COPYRIGHT 2008 STMicroelectronics ********************
1 ingob 2
* File Name          : 91x_scu.c
3
* Author             : MCD Application Team
196 killagreg 4
* Version            : V2.1
5
* Date               : 12/22/2008
6
* Description        : This file provides the SCU library firmware functions
1 ingob 7
********************************************************************************
8
* THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS WITH
9
* CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. AS
10
* A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT, INDIRECT
11
* OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE CONTENT
12
* OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING INFORMATION
13
* CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
14
*******************************************************************************/
15
 
16
/* Includes ------------------------------------------------------------------*/
17
#include "91x_scu.h"
18
 
19
/* Include of other module interface headers ---------------------------------*/
20
/* Local includes ------------------------------------------------------------*/
21
/* Private typedef -----------------------------------------------------------*/
22
/* Private define ------------------------------------------------------------*/
23
#define SCU_PLLEN 0x80000
24
/* Private macro -------------------------------------------------------------*/
25
/* Private variables ---------------------------------------------------------*/
26
/* Private function prototypes -----------------------------------------------*/
27
/* Interface functions -------------------------------------------------------*/
28
/* Private functions ---------------------------------------------------------*/
29
 
30
/*******************************************************************************
31
* Function Name  : SCU_MCLKSourceConfig
32
* Description    : Configures the MCLK source clock
33
* Input          : MCLK_Source = SCU_MCLK_OSC, SCU_MCLK_PLL or SCU_MCLK_RTC
34
* Output         : None
35
* Return         : ErrorStatus: SUCCESS or ERROR
36
* Note           : this function returns ERROR if trying to select the PLL as
37
*                  clock source while the PLL is disabled or not locked.
38
*******************************************************************************/
39
ErrorStatus SCU_MCLKSourceConfig(u32 MCLK_Source)
40
{
41
  u32 CLKCNTR_Value;
42
 
43
  CLKCNTR_Value = SCU->CLKCNTR;         /*get CLKCNTR register value*/
44
  CLKCNTR_Value &=~0x3;                 /*clear field MCLKSEL*/
45
  if (MCLK_Source == SCU_MCLK_PLL)      /*PLL selected as clock source*/
46
  {
47
    /*check if PLL enabled & locked*/
48
    if (!((SCU->PLLCONF&SCU_PLLEN)&&(SCU->SYSSTATUS&SCU_FLAG_LOCK)))
49
    return ERROR;
50
  }
51
  else CLKCNTR_Value |=MCLK_Source;     /*OSC or RTC selected as clock source*/
52
  SCU->CLKCNTR = CLKCNTR_Value;         /*Update CLKCNTR register value*/
53
  return SUCCESS;
54
}
55
 
56
/*******************************************************************************
57
* Function Name  : SCU_PLLFactorsConfig
58
* Description    : Sets the PLL factors
59
* Input          : PLLN, PLLM and PLLP
60
* Output         : None
61
* Return         : ErrorStatus: ERROR or SUCCESS
62
* Notes          : -The PLL factors must respect the PLL specification requirements
63
*                  -The function returns ERROR if trying to change PLL
64
*                   factors while PLL is selected as Main Clock source (MCLK)
65
*                  -This function disables the PLL, to enable the PLL use
66
*                   function" SCU_PLLCmd(ENABLE)" after setting the PLL factors
67
******************************************************************************/
68
ErrorStatus SCU_PLLFactorsConfig(u8 PLLN, u8 PLLM, u8 PLLP)
69
{
70
  if (SCU_PLLCmd(DISABLE)==SUCCESS)      /*Disable PLL*/
71
  {
72
    SCU->PLLCONF =0;                     /*clear PLLCONF register*/
73
    SCU->PLLCONF |=(PLLN<<8);            /*update PLLN field*/
74
    SCU->PLLCONF |=PLLM;                 /*update PLLM field*/
75
    SCU->PLLCONF |=PLLP<<16;             /*update PLLP field*/
76
    return SUCCESS;
77
  }
78
  return ERROR;
79
}
80
 
81
/*******************************************************************************
82
* Function Name  : SCU_PLLCmd
83
* Description    : Enable or Disable the PLL
84
* Input          : NewState = ENABLE or DISABLE
85
* Output         : None
86
* Return         : ErrorStatus: SUCCESS or ERROR
87
* Note           : -The function returns ERROR if:
88
*                   *trying to disable the PLL while it is selected as the MCLK
89
*                   *trying to enable the PLL while it is already enabled and
90
*                    locked
91
*******************************************************************************/
92
ErrorStatus SCU_PLLCmd(FunctionalState NewState)
93
{
94
  if (NewState==ENABLE)
95
  {
96
    if (!((SCU->PLLCONF&SCU_PLLEN)&&(SCU->SYSSTATUS&SCU_FLAG_LOCK)))
97
    {
98
      SCU->SYSSTATUS|=SCU_FLAG_LOCK;               /*clear LOCK bit*/
99
      SCU->PLLCONF |=SCU_PLLEN;                    /*PLL Enable*/
196 killagreg 100
      while(!(SCU->SYSSTATUS&SCU_FLAG_LOCK));        /*Wait PLL to lock*/
1 ingob 101
      return SUCCESS;
102
    }
103
    else return ERROR;
104
  }
105
  else /*NewState = DISABLE*/
106
  {
107
    if(SCU->CLKCNTR&0x3)                /*check if PLL not sys CLK*/
108
    {
109
      SCU->PLLCONF &=~SCU_PLLEN;        /*PLL Disable*/
110
      return SUCCESS;
111
    }
112
    else return ERROR;
113
  }
114
}
115
 
116
/*******************************************************************************
117
* Function Name  : SCU_RCLKDivisorConfig
118
* Description    : Sets the RCLK divisor value
119
* Input          : RCLK_Divisor
120
* Output         : None
121
* Return         : None
122
*******************************************************************************/
123
void SCU_RCLKDivisorConfig(u32 RCLK_Divisor)
124
{
125
  SCU->CLKCNTR &=SCU_RCLK_Div1;              /*clear RCLKDIV[2:0] field*/
126
  if (RCLK_Divisor!=SCU_RCLK_Div1)
127
  SCU->CLKCNTR |= RCLK_Divisor;              /*update field with RCLK divisor*/
128
}
129
 
130
/*******************************************************************************
131
* Function Name  : SCU_HCLKDivisorConfig
132
* Description    : Sets the HCLK divisor value
133
* Input          : HCLK_Divisor
134
* Output         : None
135
* Return         : None
136
*******************************************************************************/
137
void SCU_HCLKDivisorConfig(u32 HCLK_Divisor)
138
{
139
  SCU->CLKCNTR &=SCU_HCLK_Div1;              /*clear AHBDIV[1:0] field*/
140
  if (HCLK_Divisor!=SCU_HCLK_Div1)
141
  SCU->CLKCNTR |= HCLK_Divisor;              /*update field with HCLK divisor*/
142
}
143
 
144
/*******************************************************************************
145
* Function Name  : SCU_PCLKDivisorConfig
146
* Description    : Sets the PCLK divisor value
147
* Input          : PCLK_Divisor
148
* Output         : None
149
* Return         : None
150
*******************************************************************************/
151
void SCU_PCLKDivisorConfig(u32 PCLK_Divisor)
152
{
153
  SCU->CLKCNTR &=SCU_PCLK_Div1;              /*clear APBDIV[1:0] field*/
154
  if (PCLK_Divisor!=SCU_PCLK_Div1)
155
  SCU->CLKCNTR |= PCLK_Divisor;              /*update field with PCLK Divisor*/
156
}
157
 
158
/*******************************************************************************
159
* Function Name  : SCU_APBPeriphClockConfig
160
* Description    : Enable the clock for an APB peripheral
161
* Input          : -APBPerip : APB peripherals(__RTC, __ADC ,...)
162
*                  -NewState : ENABLE or DISABLE
163
* Output         : None
164
* Return         : None
165
*******************************************************************************/
166
void SCU_APBPeriphClockConfig(u32 APBPeriph, FunctionalState NewState)
167
{
168
  if (NewState==ENABLE)                     /*Enable clock for APB peripheral*/
169
  SCU->PCGR1 |=APBPeriph;
170
  else
171
  SCU->PCGR1 &=~APBPeriph;                  /*Disable clock for APB peripheral*/
172
}
173
 
174
/*******************************************************************************
175
* Function Name  : SCU_AHBPeriphClockConfig
176
* Description    : Enable the clock for an AHB peripheral
177
* Input          : -AHBPerip: AHB peripherals(__USB, __DMA,...)
178
*                  -NewState : ENABLE or DISABLE
179
* Output         : None
180
* Return         : None
181
*******************************************************************************/
182
void SCU_AHBPeriphClockConfig(u32 AHBPeriph, FunctionalState NewState)
183
{
184
  if (NewState==ENABLE)                     /*Enable clock for AHB peripheral*/
196 killagreg 185
  SCU->PCGR0 |=AHBPeriph;
1 ingob 186
  else
196 killagreg 187
  SCU->PCGR0 &=~AHBPeriph;                  /*Disable clock for AHB peripheral*/
1 ingob 188
}
189
 
190
/*******************************************************************************
191
* Function Name  : SCU_APBPeriphReset
192
* Description    : Assert or deassert Reset on APB peripheral
193
* Input          : -APBPeriph: APB peripherals(__RTC, __ADC,...)
194
                   -NewState : ENABLE or DISABLE
195
* Output         : None
196
* Return         : None
197
*******************************************************************************/
198
void SCU_APBPeriphReset(u32 APBPeriph, FunctionalState NewState)
199
{
200
  if (NewState==DISABLE)                    /*APB peripheral not held in Reset*/
201
  SCU->PRR1 |=APBPeriph;
202
  else
203
  SCU->PRR1 &=~APBPeriph;                   /*APB peripheral held in Reset*/
204
}
205
 
206
/*******************************************************************************
207
* Function Name  : SCU_AHBPeriphReset
208
* Description    : Assert or deassert Reset on AHB peripheral
209
* Input          : -AHBPeriph: AHB peripherals(__USB, __DMA,...)
210
                   -NewState : ENABLE or DISABLE
211
* Output         : None
212
* Return         : None
213
*******************************************************************************/
214
void SCU_AHBPeriphReset(u32 AHBPeriph, FunctionalState NewState)
215
{
216
  if (NewState==DISABLE)
217
  SCU->PRR0 |=AHBPeriph;                    /*AHB peripheral not held in Reset*/
218
  else
219
  SCU->PRR0 &=~AHBPeriph;                   /*AHB peripheral held in Reset*/
220
}
221
 
222
/*******************************************************************************
223
* Function Name  : SCU_APBPeriphIdleConfig
224
* Description    : Enable or Disable Periph Clock during Idle mode
225
* Input          : -APBPeriph: APB peripherals(__RTC, __ADC,...)
226
                   -NewState : ENABLE or DISABLE
227
* Output         : None
228
* Return         : None
229
*******************************************************************************/
230
void SCU_APBPeriphIdleConfig(u32 APBPeriph, FunctionalState NewState)
231
{
232
  if (NewState==ENABLE)
233
  SCU->MGR1 |=APBPeriph;      /*APB peripheral clock enabled during Idle mode*/
234
  else
235
  SCU->MGR1 &=~APBPeriph;     /*APB peripheral clock disabled during Idle mode*/
236
}
237
 
238
/*******************************************************************************
239
* Function Name  : SCU_AHBPeriphIdleConfig
240
* Description    : Enable or Disable Periph Clock during Idle mode
241
* Input          : -AHBPeriph: AHB peripherals(__USB, __DMA,...)
242
                   -NewState : ENABLE or DISABLE
243
* Output         : None
244
* Return         : None
245
*******************************************************************************/
246
void SCU_AHBPeriphIdleConfig(u32 AHBPeriph, FunctionalState NewState)
247
{
248
  if (NewState==ENABLE)
249
  SCU->MGR0 |=AHBPeriph;      /*AHB peripheral clock enabled during Idle mode*/
250
  else
251
  SCU->MGR0 &=~AHBPeriph;     /*AHB peripheral clock disabled during Idle mode*/
252
}
253
 
254
/*******************************************************************************
255
* Function Name  : SCU_APBPeriphDebugConfig
256
* Description    : Enable or Disable Periph Clock during ARM debug state
257
* Input          : -APBPeriph: APB peripherals(__RTC, __ADC,...)
258
                   -NewState : ENABLE or DISABLE
259
* Output         : None
260
* Return         : None
261
*******************************************************************************/
262
void SCU_APBPeriphDebugConfig(u32 APBPeriph, FunctionalState NewState)
263
{
264
  if (NewState==ENABLE)
265
  SCU->PECGR1 |=APBPeriph;    /*APB peripheral clock enabled during ARM debug state*/
266
  else
267
  SCU->PECGR1 &=~APBPeriph;   /*APB peripheral clock disabled during ARM debug state*/
268
}
269
 
270
/*******************************************************************************
271
* Function Name  : SCU_AHBPeriphDebugConfig
272
* Description    : Enable or Disable Periph Clock during ARM debug state
273
* Input          : -AHBPeriph: AHB peripherals(__USB, __DMA,...)
274
                   -NewState : ENABLE or DISABLE
275
* Output         : None
276
* Return         : None
277
*******************************************************************************/
278
void SCU_AHBPeriphDebugConfig(u32 AHBPeriph, FunctionalState NewState)
279
{
280
  if (NewState==ENABLE)
281
  SCU->PECGR0 |=AHBPeriph;    /*AHB peripheral clock enabled during ARM debug state*/
282
  else
283
  SCU->PECGR0 &=~AHBPeriph;   /*AHB peripheral clock disabled during ARM debug state*/
284
}
285
/*******************************************************************************
286
* Function Name  : SCU_BRCLKDivisorConfig
287
* Description    : Sets the BRCLK divisor value
288
* Input          : BRCLK_Divisor
289
* Output         : None
290
* Return         : None
291
*******************************************************************************/
292
void SCU_BRCLKDivisorConfig(u32 BRCLK_Divisor)
293
{
294
  SCU->CLKCNTR &=SCU_BRCLK_Div2;              /*Clear BRSEL bit*/
295
  if (BRCLK_Divisor==SCU_BRCLK_Div1)
296
  SCU->CLKCNTR |= SCU_BRCLK_Div1;             /*set bit BRSEL*/
297
}
298
 
299
/*******************************************************************************
196 killagreg 300
* Function Name  : SCU_TIMExtCLKCmd
301
* Description    : Enable or disable the TIMx external clock source
1 ingob 302
* Input          : - TIMx : SCU_TIM01 or SCU_TIM23
196 killagreg 303
*                  -  NewState : ENABLE or DISABLE
304
* Output         : Non
1 ingob 305
* Return         : None
306
*******************************************************************************/
196 killagreg 307
void SCU_TIMExtCLKCmd (u8 TIMx, FunctionalState NewState)
1 ingob 308
{
309
  if (TIMx== SCU_TIM01)                     /*TIM01 clock source configuration*/
310
  {
311
    SCU->CLKCNTR &=0xFFFFDFFF;
196 killagreg 312
    if (NewState==ENABLE)
1 ingob 313
    SCU->CLKCNTR |=0x2000;
314
  }
315
  else
316
  {
317
    SCU->CLKCNTR &=0xFFFFBFFF;            /*TIM23 clock source configuration*/
196 killagreg 318
     if (NewState==ENABLE)
1 ingob 319
    SCU->CLKCNTR |=0x4000;
320
  }
321
}
322
 
323
/*******************************************************************************
324
* Function Name  : SCU_USBCLKConfig
325
* Description    : Configures the clock source for the 48MHz USBCLK
326
* Input          : USBCLK_Source: SCU_USBCLK_MCLK,SCU_USBCLK_MCLK2 or SCU_USBCLK_EXT
327
* Output         : None
328
* Return         : None
329
*******************************************************************************/
330
void SCU_USBCLKConfig(u32 USBCLK_Source)
331
{
332
  SCU->CLKCNTR &=SCU_USBCLK_MCLK;            /*clear USBSEL[1:0] field*/
333
  if (USBCLK_Source!=SCU_USBCLK_MCLK)
334
  SCU->CLKCNTR |= USBCLK_Source;             /*update field with USBCLK_Source*/
335
}
336
 
337
/*******************************************************************************
338
* Function Name  : SCU_PHYCLKConfig
339
* Description    : Enable or Disable PHY clock output
340
* Input          : NewState : ENABLE or DISABLE
341
* Output         : None
342
* Return         : None
343
*******************************************************************************/
344
void SCU_PHYCLKConfig(FunctionalState NewState)
345
{
346
  if (NewState==ENABLE)
347
  SCU->CLKCNTR |= 0x1000;                    /*enable MIIPHY clock*/
348
  else
349
  SCU->CLKCNTR &=~0x1000;                    /*disable MIIPHY clock*/
350
}
351
 
352
/*******************************************************************************
353
* Function Name  : SCU_FMICLKDivisorConfig
354
* Description    : Set the FMI clock divisor
355
* Input          : FMICLK_Divisor: SCU_FMICLK_Div1 or SCU_FMICLK_DIV2
356
* Output         : None
357
* Return         : None
358
*******************************************************************************/
359
void SCU_FMICLKDivisorConfig(u32 FMICLK_Divisor)
360
{
361
  SCU->CLKCNTR &=SCU_FMICLK_Div1;            /*FMICLK = RCLK*/
362
  if (FMICLK_Divisor!=SCU_FMICLK_Div1)
363
  SCU->CLKCNTR |=SCU_FMICLK_Div2;            /*FMICLK = RCLK/2 */
364
}
365
 
366
/*******************************************************************************
367
* Function Name  : SCU_EMIBCLKDivisorConfig
368
* Description    : Set the EMI Bus clock divisor: EMIBCLK = HCLK or HCLK/2
369
* Input          : SCU_EMICLK: SCU_EMIBCLK_Div1 , SCU_EMIBCLK_Div2
370
* Output         : None
371
* Return         : None
372
*******************************************************************************/
373
void SCU_EMIBCLKDivisorConfig(u32 SCU_EMIBCLK)
374
{
375
  SCU->CLKCNTR &=SCU_EMIBCLK_Div1;          /*EMIBCLK = HCLK */
376
  if (SCU_EMIBCLK!=SCU_EMIBCLK_Div1)
377
  SCU->CLKCNTR |= SCU_EMIBCLK_Div2;         /*EMIBCLK = HCLK/2 */
378
}
379
 
380
/*******************************************************************************
381
* Function Name  : SCU_EMIModeConfig
382
* Description    : Configure the EMI as Multiplexed or Demultiplexed
383
* Input          : SCU_EMIMODE : SCU_EMI_MUX or SCU_EMI_DEMUX
384
* Output         : None
385
* Return         : None
386
*******************************************************************************/
387
void SCU_EMIModeConfig(u32 SCU_EMIMODE)
388
{
389
  SCU->SCR0 &=SCU_EMI_MUX;                 /*EMI mode = Multiplexed*/
390
  if (SCU_EMIMODE!=SCU_EMI_MUX)
391
  SCU->SCR0 |= SCU_EMI_DEMUX;                /*EMI mode = Demultiplexed*/
392
}
393
 
394
/*******************************************************************************
395
* Function Name  : SCU_EMIALEConfig
396
* Description    : Configure the ALE signal (length & polarity)
397
* Input          : -SCU_EMIALE_LEN : SCU_EMIALE_LEN1 or SCU_EMIALE_LEN2
398
*                  -SCU_EMIALE_POL : SCU_EMIALE_POLLow or SCU_EMI_POLHigh
399
* Output         : None
400
* Return         : None
401
*******************************************************************************/
402
void SCU_EMIALEConfig(u32 SCU_EMIALE_LEN, u32 SCU_EMIALE_POL)
403
{
404
  /*Configure EMI ALE Length*/
405
  SCU->SCR0 &=SCU_EMIALE_LEN1;
406
  if (SCU_EMIALE_LEN!=SCU_EMIALE_LEN1)
407
  SCU->SCR0 |= SCU_EMIALE_LEN2;
408
 
409
  /*Configure EMI ALE POL*/
410
  SCU->SCR0 &=SCU_EMIALE_POLLow;
411
  if (SCU_EMIALE_POL!=SCU_EMIALE_POLLow)
412
  SCU->SCR0 |= SCU_EMIALE_POLHigh;
413
}
414
 
415
/*******************************************************************************
416
* Function Name  : SCU_ITConfig
417
* Description    : ENBALE or DISABLE an SCU interrupt
418
* Input          : -SCU_IT:   interrupt mask
419
*                  -NewState: ENABLE or DISABLE
420
* Output         : None
421
* Return         : None
422
*******************************************************************************/
423
void SCU_ITConfig(u32 SCU_IT, FunctionalState NewState)
424
{
425
  if (NewState==ENABLE)
426
  SCU->ITCMSK&=~SCU_IT;                    /*IT enable */
427
  else
428
  SCU->ITCMSK|=SCU_IT;                     /*IT disable( mask)*/
429
}
430
 
431
/*******************************************************************************
432
* Function Name  : SCU_GetFlagStatus
433
* Description    : Returns flag status
434
* Input          : SCU_Flag
435
* Output         : NONE
436
* Return         : SET or RESET
437
*******************************************************************************/
438
FlagStatus SCU_GetFlagStatus(u32 SCU_Flag)
439
{
440
  if (SCU->SYSSTATUS&SCU_Flag)
441
  return SET;
442
  else return RESET;
443
}
444
 
445
/*******************************************************************************
446
* Function Name  : SCU_ClearFlag
447
* Description    : Clears a SYSTATUS Flag
448
* Input          : SCU_Flag
449
* Output         : None
450
* Return         : None
451
*******************************************************************************/
452
void SCU_ClearFlag(u32 SCU_Flag)
453
{
454
  SCU->SYSSTATUS = SCU_Flag;
455
}
456
/*******************************************************************************
457
* Function Name  : SCU_GetPLLfreqValue
458
* Description    : Gets the current PLL frequency
459
* Input          : None
460
* Output         : None
461
* Return         : PLL frequency (KHz)
462
*******************************************************************************/
463
u32 SCU_GetPLLFreqValue(void)
464
{
465
  u8 PLL_M;
466
  u8 PLL_N;
467
  u8 PLL_P;
468
 
469
  PLL_M = SCU->PLLCONF&0xFF;
470
  PLL_N = (SCU->PLLCONF&0xFF00)>>8;
471
  PLL_P = (SCU->PLLCONF&0x70000)>>16;
472
 
473
  if ((PLL_M>0)&&(PLL_N>0))
474
  return (u32)(((_Main_Crystal*2)*PLL_N)/(PLL_M<<PLL_P));
475
 
476
  else return 0;
477
}
478
/*******************************************************************************
479
* Function Name  : SCU_GetMCLKFreqValue
480
* Description    : Gets the current MCLK frequency
481
* Input          : None
482
* Output         : None
483
* Return         : MCLK frequency (KHz)
484
*******************************************************************************/
485
u32 SCU_GetMCLKFreqValue(void)
486
{
487
  if ((SCU->CLKCNTR&0x3) == 0x2) return (u32)(_Main_Crystal);
488
  if ((SCU->CLKCNTR&0x3) == 0x1) return (u32)(32);
489
  else return (SCU_GetPLLFreqValue());
490
}
491
 
492
/*******************************************************************************
493
* Function Name  : SCU_GetRCLKFreqValue
494
* Description    : Gets the current RCLK frequency
495
* Input          : None
496
* Output         : None
497
* Return         : RCLK frequency (KHz)
498
*******************************************************************************/
499
u32 SCU_GetRCLKFreqValue(void)
500
{
501
  u8 RCLK_Div;
502
  RCLK_Div = (SCU->CLKCNTR&0x1C)>>2;
503
  if (RCLK_Div==0x5) RCLK_Div=10;
504
  return (u32)(SCU_GetMCLKFreqValue() >>RCLK_Div);
505
}
506
 
507
/*******************************************************************************
508
* Function Name  : SCU_GetHCLKFreqValue
509
* Description    : Gets the current PCLK frequency
510
* Input          : None
511
* Output         : None
512
* Return         : HCLK frequency (KHz)
513
*******************************************************************************/
514
u32 SCU_GetHCLKFreqValue(void)
515
{
516
  u8 HCLK_Div;
517
  HCLK_Div = (SCU->CLKCNTR&0x60)>>5;
518
  return (u32)(SCU_GetRCLKFreqValue() >>HCLK_Div);
519
}
520
 
521
/*******************************************************************************
522
* Function Name  : SCU_GetPCLKFreqValue
523
* Description    : Gets the current HCLK frequency
524
* Input          : None
525
* Output         : None
526
* Return         : PCLK frequency (KHz)
527
*******************************************************************************/
528
u32 SCU_GetPCLKFreqValue(void)
529
{
530
  u8 PCLK_Div;
531
  PCLK_Div = (SCU->CLKCNTR&0x180)>>7;
532
  return (u32)(SCU_GetRCLKFreqValue() >>PCLK_Div);
533
}
534
 
535
/*******************************************************************************
536
* Function Name  : SCU_WakeUpLineConfig
537
* Description    : Configures an External interrupt as WakeUp line
538
* Input          : EXTint : 0 -> 31
539
* Output         : None
540
* Return         : None
541
*******************************************************************************/
542
void SCU_WakeUpLineConfig(u8 EXTint)
543
{
544
  if (EXTint < 8)
545
  {
546
    SCU->WKUPSEL&=~0x7;
547
    SCU->WKUPSEL|=EXTint;
548
  }
549
  else if (EXTint<16)
550
  {
551
    SCU->WKUPSEL&=~0x38;
552
    SCU->WKUPSEL|=(EXTint-8)<<3;
553
  }
554
  else if (EXTint<24)
555
  {
556
    SCU->WKUPSEL&=~0x1C0;
557
    SCU->WKUPSEL|=(EXTint-16)<<6;
558
  }
559
  else
560
  {
561
    SCU->WKUPSEL&=~0xE00;
562
    SCU->WKUPSEL|=(EXTint-24)<<9;
563
  }
564
}
565
 
566
/*******************************************************************************
567
* Function Name  : SCU_SpecIntRunModeConfig
568
* Description    : Enables or Disables the Special Run mode
569
* Input          : newstate = ENABLE or DISABLE
570
* Output         : None
571
* Return         : None
572
*******************************************************************************/
573
void SCU_SpecIntRunModeConfig(FunctionalState NewState)
574
{
575
  if (NewState == ENABLE)
576
  SCU->PWRMNG |=0x8;
577
  else
578
  SCU->PWRMNG &=~0x8;
579
}
580
/*******************************************************************************
581
* Function Name  : SCU_EnterIdleMode
582
* Description    : Enters in Idle mode
583
* Input          : None
584
* Output         : None
585
* Return         : None
586
*******************************************************************************/
587
void SCU_EnterIdleMode(void)
588
{
589
  SCU->PWRMNG |=0x1;
590
}
591
/*******************************************************************************
592
* Function Name  : SCU_EnterSleepMode
593
* Description    : Enters in Sleep mode
594
* Input          : None
595
* Output         : None
596
* Return         : None
597
*******************************************************************************/
598
void SCU_EnterSleepMode(void)
599
{
600
  SCU->PWRMNG |=0x2;
601
}
602
 
603
/*******************************************************************************
604
* Function Name  : SCU_UARTIrDAConfig
605
* Description    : Enable or Disable the Irda mode for UARTx
606
* Input          : - SCU_UARTx :x=0,1 or 2
607
*                  - UART_IrDA_Mode : SCU_UARTMode_IrDA or SCU_UARTMode_UART
608
* Output         :  None
609
* Return         :  None
610
*******************************************************************************/
611
void SCU_UARTIrDASelect(u8 SCU_UARTx, u8 UART_IrDA_Mode)
612
{
613
  if (UART_IrDA_Mode == SCU_UARTMode_IrDA)
614
  {
615
    if (SCU_UARTx== SCU_UART0) SCU->SCR0 |=0x400;
616
    else if (SCU_UARTx== SCU_UART1) SCU->SCR0 |=0x800;
617
    else SCU->SCR0 |=0x1000;
618
  }
619
  else
620
  {
621
    if (SCU_UARTx== SCU_UART0) SCU->SCR0 &=~0x400;
622
    else if (SCU_UARTx== SCU_UART1) SCU->SCR0 &=~0x800;
623
    else SCU->SCR0 &=~0x1000;
624
  }
625
}
626
/*******************************************************************************
627
* Function Name  : SCU_PFQBCCmd
628
* Description    : Enable or Disable PFQBC
629
* Input          : NewState : ENABLE or DISABLE
630
* Output         : None
631
* Return         : None
632
*******************************************************************************/
633
void SCU_PFQBCCmd(FunctionalState NewState)
634
{
635
  if (NewState==ENABLE)
636
  SCU->SCR0 |=0x1;
637
  else SCU->SCR0 &=~0x1;
638
}
639
 
196 killagreg 640
 
641
/*******************************************************************************
642
* Function Name  : SCU_EMIByte_Select_Pinconfig
643
* Description    : Enable or Disable the Byte selection pins behaviour(LFBGA only)
644
* Input          : NewState : ENABLE or DISABLE
645
* Output         : None
646
* Return         : None
647
*******************************************************************************/
648
void SCU_EMIByte_Select_Pinconfig(FunctionalState NewState)
649
{
650
 if (NewState==ENABLE)
651
  SCU->GPIOEMI |= 0x04;                    
652
  else
653
  SCU->GPIOEMI &=~0x04;  
654
 
655
 }
656
 
657
/*******************************************************************************
658
* Function Name  : SCU_EMIclock_Pinconfig
659
* Description    : Enable or Disable the BCLK pin clock driving (LFBGA only)
660
* Input          : NewState : ENABLE or DISABLE
661
* Output         : None
662
* Return         : None
663
*******************************************************************************/
664
 
665
void SCU_EMIclock_Pinconfig(FunctionalState NewState)
666
{
667
 if (NewState==DISABLE)
668
  SCU->GPIOEMI |= 0x02;                    
669
  else
670
  SCU->GPIOEMI &=~0x02;  
671
 
672
 }
673
 
674
 
675
/******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/