Subversion Repositories freemyipod

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
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
 
961 theseven 35
void clockgate_enable(int gate, bool enable) ICODE_ATTR;
273 theseven 36
void clockgate_enable(int gate, bool enable)
37
{
387 theseven 38
    uint32_t mode = enter_critical_section();
273 theseven 39
    if (enable) PWRCON(gate >> 5) &= ~(1 << (gate & 0x1f));
40
    else PWRCON(gate >> 5) |= 1 << (gate & 0x1f);
387 theseven 41
    leave_critical_section(mode);
273 theseven 42
}
560 theseven 43
 
44
void clockgate_dma(int dmac, int chan, bool enable)
45
{
46
    uint32_t mode = enter_critical_section();
47
    uint32_t old = clockgates_dma[dmac];
48
    if (enable) clockgates_dma[dmac] |= 1 << chan;
49
    else clockgates_dma[dmac] &= ~(1 << chan);
50
    if (clockgates_dma[dmac] != old)
51
        clockgate_enable(CLOCKGATE_DMA(dmac), true);
52
    leave_critical_section(mode);
53
}