mirror of
https://gitee.com/anod/open_agb_firm.git
synced 2025-05-06 22:04:10 +08:00

gfx: 常量大改名、函数大改名,增加了双缓冲的一些驱动函数 其他:基本是ARM9/ARM11宏修改和BIT取值修改,bool从c风格转成c++强类型风格等。sha.c使用了memory.h进行的改动(copy32)
97 lines
3.1 KiB
C
97 lines
3.1 KiB
C
#pragma once
|
|
|
|
/*
|
|
* This file is part of open_agb_firm
|
|
* Copyright (C) 2021 derrek, profi200
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifdef __ARM9__
|
|
#include "arm9/drivers/interrupt.h"
|
|
#include "arm9/drivers/cfg9.h"
|
|
#elif __ARM11__
|
|
#include "arm11/drivers/interrupt.h"
|
|
#endif // #ifdef __ARM9__
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
// Note on port numbers:
|
|
// To make things easier 2 ports are assigned to each controller.
|
|
// There are a maximum of 2 controllers mapped at the same time
|
|
// and 3 (on DSi 2) controllers in total.
|
|
// Also see tmio.h.
|
|
//
|
|
// Examples:
|
|
// Port 0 is port 0 on controller 1, port 3 is port 1 on controller 2.
|
|
|
|
// This define determines whenever the SD slot is accessible on
|
|
// ARM9 or ARM11 when TMIO_CARD_PORT for ARM9 is set to 2.
|
|
#define TMIO_C2_MAP (0u) // Controller 2 (physical 3) memory mapping. 0=ARM9 0x10007000 or 1=ARM11 0x10100000.
|
|
|
|
#ifdef __ARM9__
|
|
#define TMIO_CARD_PORT (2u) // Can be on port 0 or 2. 0 always on ARM9.
|
|
#define TMIO_eMMC_PORT (1u) // Port 1 only. Do not change.
|
|
#elif __ARM11__
|
|
#define TMIO_CARD_PORT (2u) // Port 2 only. Do not change.
|
|
#define TMIO_eMMC_PORT (3u) // Placeholder. Do not change. Not connected/accessible.
|
|
#endif // #ifdef __ARM9__
|
|
|
|
|
|
|
|
// Don't modify anything below!
|
|
#ifdef __ARM9__
|
|
#define TMIO_MAP_CONTROLLERS() \
|
|
{ \
|
|
getCfg9Regs()->sdmmcctl = (TMIO_CARD_PORT == 2u ? SDMMCCTL_CARD_TMIO3_SEL : SDMMCCTL_CARD_TMIO1_SEL) | \
|
|
(TMIO_C2_MAP == 1u ? SDMMCCTL_TMIO3_MAP11 : SDMMCCTL_TMIO3_MAP9) | \
|
|
SDMMCCTL_UNK_BIT6 | SDMMCCTL_UNK_PWR_OFF; \
|
|
}
|
|
|
|
#define TMIO_UNMAP_CONTROLLERS() {getCfg9Regs()->sdmmcctl = SDMMCCTL_UNK_BIT6 | SDMMCCTL_UNK_PWR_OFF | SDMMCCTL_CARD_PWR_OFF;}
|
|
#define TMIO_NUM_CONTROLLERS (TMIO_C2_MAP == 0u ? 2u : 1u)
|
|
#define TMIO_IRQ_ID_CONTROLLER1 (IRQ_TMIO1)
|
|
#define TMIO_REGISTER_ISR(isr) \
|
|
{ \
|
|
IRQ_registerIsr(IRQ_TMIO1, (isr)); \
|
|
if(TMIO_NUM_CONTROLLERS == 2u) \
|
|
IRQ_registerIsr(IRQ_TMIO3, (isr)); \
|
|
}
|
|
#elif __ARM11__
|
|
#define TMIO_MAP_CONTROLLERS()
|
|
#define TMIO_UNMAP_CONTROLLERS()
|
|
#define TMIO_NUM_CONTROLLERS (TMIO_C2_MAP == 1u ? 2u : 1u)
|
|
#define TMIO_IRQ_ID_CONTROLLER1 (IRQ_TMIO2)
|
|
#define TMIO_REGISTER_ISR(isr) \
|
|
{ \
|
|
IRQ_registerIsr(IRQ_TMIO2, 14, 0, (isr)); \
|
|
if(TMIO_NUM_CONTROLLERS == 2u) \
|
|
IRQ_registerIsr(IRQ_TMIO3, 14, 0, (isr)); \
|
|
}
|
|
#endif // #ifdef __ARM9__
|
|
|
|
#define TMIO_UNREGISTER_ISR() \
|
|
{ \
|
|
IRQ_unregisterIsr(TMIO_IRQ_ID_CONTROLLER1); \
|
|
if(TMIO_NUM_CONTROLLERS == 2u) \
|
|
IRQ_unregisterIsr(IRQ_TMIO3); \
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
#endif |