| 273 |
theseven |
1 |
//
|
|
|
2 |
//
|
|
|
3 |
// Copyright 2010 TheSeven
|
|
|
4 |
//
|
|
|
5 |
//
|
| 427 |
farthen |
6 |
// This file is part of emCORE.
|
| 273 |
theseven |
7 |
//
|
| 427 |
farthen |
8 |
// emCORE is free software: you can redistribute it and/or
|
| 273 |
theseven |
9 |
// modify it under the terms of the GNU General Public License as
|
|
|
10 |
// published by the Free Software Foundation, either version 2 of the
|
|
|
11 |
// License, or (at your option) any later version.
|
|
|
12 |
//
|
| 427 |
farthen |
13 |
// emCORE is distributed in the hope that it will be useful,
|
| 273 |
theseven |
14 |
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
15 |
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
16 |
// See the GNU General Public License for more details.
|
|
|
17 |
//
|
|
|
18 |
// You should have received a copy of the GNU General Public License along
|
| 427 |
farthen |
19 |
// with emCORE. If not, see <http://www.gnu.org/licenses/>.
|
| 273 |
theseven |
20 |
//
|
|
|
21 |
//
|
|
|
22 |
|
|
|
23 |
|
|
|
24 |
#include "global.h"
|
|
|
25 |
#include "s5l8702.h"
|
|
|
26 |
|
|
|
27 |
|
| 560 |
theseven |
28 |
uint32_t clockgates_dma[2];
|
|
|
29 |
|
| 557 |
theseven |
30 |
bool clockgate_get_state(int gate)
|
|
|
31 |
{
|
|
|
32 |
return !(PWRCON(gate >> 5) & (1 << (gate & 0x1f)));
|
|
|
33 |
}
|
|
|
34 |
|
| 273 |
theseven |
35 |
void clockgate_enable(int gate, bool enable)
|
|
|
36 |
{
|
| 387 |
theseven |
37 |
uint32_t mode = enter_critical_section();
|
| 273 |
theseven |
38 |
if (enable) PWRCON(gate >> 5) &= ~(1 << (gate & 0x1f));
|
|
|
39 |
else PWRCON(gate >> 5) |= 1 << (gate & 0x1f);
|
| 387 |
theseven |
40 |
leave_critical_section(mode);
|
| 273 |
theseven |
41 |
}
|
| 560 |
theseven |
42 |
|
|
|
43 |
void clockgate_dma(int dmac, int chan, bool enable)
|
|
|
44 |
{
|
|
|
45 |
uint32_t mode = enter_critical_section();
|
|
|
46 |
uint32_t old = clockgates_dma[dmac];
|
|
|
47 |
if (enable) clockgates_dma[dmac] |= 1 << chan;
|
|
|
48 |
else clockgates_dma[dmac] &= ~(1 << chan);
|
|
|
49 |
if (clockgates_dma[dmac] != old)
|
|
|
50 |
clockgate_enable(CLOCKGATE_DMA(dmac), true);
|
|
|
51 |
leave_critical_section(mode);
|
|
|
52 |
}
|