2017-08-08 09:40:09 -03:00
|
|
|
#include <cpu.h>
|
|
|
|
#include <pxi.h>
|
2017-08-21 21:01:18 -03:00
|
|
|
#include <gic.h>
|
|
|
|
#include <gpulcd.h>
|
2017-08-18 13:45:00 -03:00
|
|
|
#include <vram.h>
|
2017-08-21 21:01:18 -03:00
|
|
|
#include <types.h>
|
2017-08-18 13:45:00 -03:00
|
|
|
|
2017-08-21 21:01:18 -03:00
|
|
|
vu32 *entrypoint = (vu32*)0x1FFFFFFC;
|
2017-07-26 21:39:30 +02:00
|
|
|
|
2017-08-21 21:01:18 -03:00
|
|
|
void PXI_IRQHandler(void)
|
2017-07-26 21:39:30 +02:00
|
|
|
{
|
2017-11-09 01:24:46 +01:00
|
|
|
// char pxi_buf[PXI_MAXBUFLEN] = {0};
|
2017-08-21 21:01:18 -03:00
|
|
|
u32 pxi_args[PXI_FIFO_LEN] = {0};
|
|
|
|
u8 pxi_cmd;
|
2017-07-26 21:39:30 +02:00
|
|
|
|
2017-08-21 21:01:18 -03:00
|
|
|
pxi_cmd = PXI_GetRemote();
|
|
|
|
switch (pxi_cmd) {
|
|
|
|
default:
|
|
|
|
break;
|
2017-07-26 21:39:30 +02:00
|
|
|
|
2017-09-26 19:56:19 -03:00
|
|
|
case PXI_SCREENINIT:
|
|
|
|
{
|
|
|
|
GPU_Init();
|
|
|
|
GPU_PSCFill(VRAM_START, VRAM_END, 0);
|
|
|
|
GPU_SetFramebuffers((u32[]){VRAM_TOP_LA, VRAM_TOP_LB,
|
|
|
|
VRAM_TOP_RA, VRAM_TOP_RB,
|
|
|
|
VRAM_BOT_A, VRAM_BOT_B});
|
|
|
|
|
|
|
|
GPU_SetFramebufferMode(0, PDC_RGB24);
|
|
|
|
GPU_SetFramebufferMode(1, PDC_RGB24);
|
|
|
|
|
|
|
|
PXI_SetRemote(PXI_BUSY);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-08-21 21:01:18 -03:00
|
|
|
case PXI_BRIGHTNESS:
|
|
|
|
{
|
|
|
|
PXI_RecvArray(pxi_args, 1);
|
|
|
|
PXI_SetRemote(PXI_BUSY);
|
|
|
|
LCD_SetBrightness(0, pxi_args[0]);
|
|
|
|
LCD_SetBrightness(1, pxi_args[0]);
|
|
|
|
break;
|
2017-07-27 18:28:27 +02:00
|
|
|
}
|
2017-07-26 21:39:30 +02:00
|
|
|
|
2017-08-21 21:01:18 -03:00
|
|
|
/* New CMD template:
|
|
|
|
case CMD_ID:
|
|
|
|
{
|
|
|
|
<var declarations/assignments>
|
|
|
|
<receive args from PXI FIFO>
|
|
|
|
<if necessary, copy stuff to pxi_buf>
|
|
|
|
PXI_SetRemote(PXI_BUSY);
|
|
|
|
<execute the command>
|
2017-08-08 09:40:09 -03:00
|
|
|
break;
|
|
|
|
}
|
2017-08-21 21:01:18 -03:00
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
PXI_SetRemote(PXI_READY);
|
2017-08-08 09:40:09 -03:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-03-14 23:18:29 +01:00
|
|
|
vu16 *CFG11_MPCORE_CLKCNT = (vu16*)(0x10141300);
|
|
|
|
vu16 *CFG11_SOCINFO = (vu16*)(0x10140FFC);
|
|
|
|
|
2017-08-08 09:40:09 -03:00
|
|
|
void main(void)
|
|
|
|
{
|
2017-08-22 23:23:17 -03:00
|
|
|
u32 entry;
|
2017-07-26 21:39:30 +02:00
|
|
|
|
2018-03-14 23:18:29 +01:00
|
|
|
if ((*CFG11_SOCINFO & 2) && (!(*CFG11_MPCORE_CLKCNT & 1))) {
|
|
|
|
GIC_Reset();
|
|
|
|
GIC_SetIRQ(88, NULL);
|
|
|
|
CPU_EnableIRQ();
|
|
|
|
*CFG11_MPCORE_CLKCNT = 0x8001;
|
|
|
|
do {
|
|
|
|
asm("wfi\n\t");
|
|
|
|
} while(!(*CFG11_MPCORE_CLKCNT & 0x8000));
|
|
|
|
CPU_DisableIRQ();
|
|
|
|
}
|
|
|
|
|
|
|
|
PXI_Reset();
|
2017-08-21 21:01:18 -03:00
|
|
|
GIC_Reset();
|
|
|
|
GIC_SetIRQ(IRQ_PXI_SYNC, PXI_IRQHandler);
|
2017-08-08 09:40:09 -03:00
|
|
|
PXI_EnableIRQ();
|
|
|
|
CPU_EnableIRQ();
|
|
|
|
|
2017-08-21 21:01:18 -03:00
|
|
|
PXI_SetRemote(PXI_READY);
|
2017-08-12 16:04:20 -03:00
|
|
|
|
2017-08-21 21:01:18 -03:00
|
|
|
*entrypoint = 0;
|
|
|
|
while((entry=*entrypoint) == 0);
|
2017-08-08 09:40:09 -03:00
|
|
|
|
|
|
|
CPU_DisableIRQ();
|
|
|
|
PXI_DisableIRQ();
|
2017-08-18 13:45:00 -03:00
|
|
|
PXI_Reset();
|
|
|
|
GIC_Reset();
|
2017-08-21 21:01:18 -03:00
|
|
|
|
2017-07-27 18:28:27 +02:00
|
|
|
((void (*)())(entry))();
|
2017-07-26 21:39:30 +02:00
|
|
|
}
|