mirror of
https://github.com/ApacheThunder/XuluMenu.git
synced 2025-06-18 19:45:45 -04:00

* Can now boot stage2 (in safe block mode) if holding L-Shoulder + R-Shoulder + A + B + DPAD Up on boot. This allows using built in stage2 usb update mode for "bootleg" style N-Cards that have Xulumenu installed. * This button combo will not do anything for regular N-Card users as they already have a proper stage2 section on nand and it will always end up booting to USB update mode with this button combo before xulumenu can boot.
66 lines
1.7 KiB
C
66 lines
1.7 KiB
C
/*
|
|
NitroHax -- Cheat tool for the Nintendo DS
|
|
Copyright (C) 2008 Michael "Chishm" Chisholm
|
|
|
|
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/>.
|
|
*/
|
|
|
|
#ifndef _COMMON_H
|
|
#define _COMMON_H
|
|
|
|
#include <nds/dma.h>
|
|
#include <nds/ipc.h>
|
|
#include <stdlib.h>
|
|
|
|
#define resetCpu() \
|
|
__asm volatile("swi 0x000000")
|
|
|
|
// Values fixed so they can be shared with ASM code
|
|
enum ARM9_STATE {
|
|
ARM9_BOOT = 0,
|
|
ARM9_START = 1,
|
|
ARM9_RESET = 2,
|
|
ARM9_READY = 3,
|
|
ARM9_MEMCLR = 4
|
|
};
|
|
|
|
enum ARM7_STATE {
|
|
ARM7_BOOT = 0,
|
|
ARM7_START = 1,
|
|
ARM7_RESET = 2,
|
|
ARM7_READY = 3,
|
|
ARM7_MEMCLR = 4,
|
|
ARM7_LOADBIN = 5,
|
|
ARM7_BOOTBIN = 6,
|
|
ARM7_ERR = 7
|
|
};
|
|
|
|
static inline void dmaFill(const void* src, void* dest, uint32 size) {
|
|
DMA_SRC(3) = (uint32)src;
|
|
DMA_DEST(3) = (uint32)dest;
|
|
DMA_CR(3) = DMA_COPY_WORDS | DMA_SRC_FIX | (size>>2);
|
|
while(DMA_CR(3) & DMA_BUSY);
|
|
}
|
|
|
|
static inline void copyLoop (u32* dest, const u32* src, size_t size) {
|
|
do { *dest++ = *src++; } while (size -= 4);
|
|
}
|
|
|
|
static inline void ipcSendState(uint8_t state) { REG_IPC_SYNC = (state & 0x0f) << 8; }
|
|
|
|
static inline uint8_t ipcRecvState(void) { return (uint8_t)(REG_IPC_SYNC & 0x0f); }
|
|
|
|
#endif // _COMMON_H
|
|
|