added separate file for ...cookie() functions
This commit is contained in:
@@ -15,6 +15,7 @@ APP=$(EMUSD).prg
|
|||||||
all: $(APP)
|
all: $(APP)
|
||||||
|
|
||||||
SOURCES=$(EMUSD).c \
|
SOURCES=$(EMUSD).c \
|
||||||
|
cookie.c \
|
||||||
xhdi.c
|
xhdi.c
|
||||||
|
|
||||||
OBJECTS=$(SOURCES:.c=.o)
|
OBJECTS=$(SOURCES:.c=.o)
|
||||||
|
|||||||
51
sd-emutos/cookie.c
Normal file
51
sd-emutos/cookie.c
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* cookie.c
|
||||||
|
*
|
||||||
|
* Created on: 03.05.2013
|
||||||
|
* Author: mfro
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <osbind.h>
|
||||||
|
|
||||||
|
static uint32_t cookieptr(void)
|
||||||
|
{
|
||||||
|
return * (uint32_t *) 0x5a0L;
|
||||||
|
}
|
||||||
|
|
||||||
|
int getcookie(uint32_t cookie, uint32_t *p_value)
|
||||||
|
{
|
||||||
|
uint32_t *cookiejar = (long *) Supexec(cookieptr);
|
||||||
|
|
||||||
|
if (!cookiejar) return 0;
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if (cookiejar[0] == cookie)
|
||||||
|
{
|
||||||
|
if (p_value) *p_value = cookiejar[1];
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
cookiejar = &(cookiejar[2]);
|
||||||
|
} while (cookiejar[-2]);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setcookie(uint32_t cookie, uint32_t value)
|
||||||
|
{
|
||||||
|
uint32_t *cookiejar = (uint32_t *) Supexec(cookieptr);
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if (cookiejar[0] == cookie)
|
||||||
|
{
|
||||||
|
cookiejar[1] = value;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
cookiejar = &(cookiejar[2]);
|
||||||
|
} while (cookiejar[-2]);
|
||||||
|
}
|
||||||
|
|
||||||
@@ -19,47 +19,6 @@ typedef uint32_t (*cookie_fun)(uint16_t opcode,...);
|
|||||||
|
|
||||||
static cookie_fun old_vector = NULL;
|
static cookie_fun old_vector = NULL;
|
||||||
|
|
||||||
static long cookieptr (void)
|
|
||||||
{
|
|
||||||
return * (uint32_t *) 0x5a0L;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int getcookie(uint32_t cookie, uint32_t *p_value)
|
|
||||||
{
|
|
||||||
long *cookiejar = (long *) Supexec (cookieptr);
|
|
||||||
|
|
||||||
if (!cookiejar) return 0;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (cookiejar[0] == cookie)
|
|
||||||
{
|
|
||||||
if (p_value) *p_value = cookiejar[1];
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
cookiejar = &(cookiejar[2]);
|
|
||||||
} while (cookiejar[-2]);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void setcookie(uint32_t cookie, uint32_t value)
|
|
||||||
{
|
|
||||||
long *cookiejar = (long *) Supexec(cookieptr);
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (cookiejar[0] == cookie)
|
|
||||||
{
|
|
||||||
cookiejar[1] = value;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
cookiejar = &(cookiejar[2]);
|
|
||||||
} while (cookiejar[-2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
static cookie_fun get_fun_ptr(void)
|
static cookie_fun get_fun_ptr(void)
|
||||||
{
|
{
|
||||||
static cookie_fun XHDI = NULL;
|
static cookie_fun XHDI = NULL;
|
||||||
|
|||||||
Reference in New Issue
Block a user