mirror of
https://github.com/wiiu-env/libiosuhax.git
synced 2025-01-23 15:21:11 +01:00
- added sd and usb disc interface that can be used with libfat, libntfs or libext2fs
- added "make wut" target to build the library for WUT applications - added parameter to IOSUHAX_Open with dev path which can be used to override the default path. If not wanted use NULL or 0.
This commit is contained in:
parent
989724c15f
commit
918491b2db
8
Makefile
8
Makefile
@ -16,7 +16,7 @@ include $(DEVKITPPC)/wii_rules
|
|||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
BUILD := build
|
BUILD := build
|
||||||
SOURCES := source
|
SOURCES := source
|
||||||
INCLUDES := iosuhax.h iosuhax_devoptab.h
|
INCLUDES := iosuhax.h iosuhax_devoptab.h iosuhax_disc_interface.h
|
||||||
LIBTARGET := libiosuhax.a
|
LIBTARGET := libiosuhax.a
|
||||||
|
|
||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
@ -28,7 +28,7 @@ HDRINSTALL := $(PORTLIBS)/include
|
|||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
# options for code generation
|
# options for code generation
|
||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
CFLAGS = -O2 -Wall -Wno-unused $(MACHDEP) $(INCLUDE)
|
CFLAGS = -O2 $(DEF_FLAGS) -Wall -Wno-unused $(MACHDEP) $(INCLUDE)
|
||||||
CXXFLAGS = $(CFLAGS)
|
CXXFLAGS = $(CFLAGS)
|
||||||
ASFLAGS := -g
|
ASFLAGS := -g
|
||||||
|
|
||||||
@ -90,6 +90,10 @@ install: $(LIBTARGET)
|
|||||||
cp $(foreach incl,$(INCLUDES),$(SOURCES)/$(incl)) $(HDRINSTALL)
|
cp $(foreach incl,$(INCLUDES),$(SOURCES)/$(incl)) $(HDRINSTALL)
|
||||||
cp $(LIBTARGET) $(LIBINSTALL)
|
cp $(LIBTARGET) $(LIBINSTALL)
|
||||||
|
|
||||||
|
wut:
|
||||||
|
@[ -d $(BUILD) ] || mkdir -p $(BUILD)
|
||||||
|
@$(MAKE) --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile DEF_FLAGS=-D__WUT__
|
||||||
|
|
||||||
#---------------------------------------------------------------------------------
|
#---------------------------------------------------------------------------------
|
||||||
else
|
else
|
||||||
|
|
||||||
|
@ -62,12 +62,12 @@
|
|||||||
|
|
||||||
static int iosuhaxHandle = -1;
|
static int iosuhaxHandle = -1;
|
||||||
|
|
||||||
int IOSUHAX_Open(void)
|
int IOSUHAX_Open(const char *dev)
|
||||||
{
|
{
|
||||||
if(iosuhaxHandle >= 0)
|
if(iosuhaxHandle >= 0)
|
||||||
return iosuhaxHandle;
|
return iosuhaxHandle;
|
||||||
|
|
||||||
iosuhaxHandle = IOS_Open("/dev/iosuhax", 0);
|
iosuhaxHandle = IOS_Open((char*)(dev ? dev : "/dev/iosuhax"), 0);
|
||||||
return iosuhaxHandle;
|
return iosuhaxHandle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ typedef struct
|
|||||||
#define FSA_MOUNTFLAGS_BINDMOUNT (1 << 0)
|
#define FSA_MOUNTFLAGS_BINDMOUNT (1 << 0)
|
||||||
#define FSA_MOUNTFLAGS_GLOBAL (1 << 1)
|
#define FSA_MOUNTFLAGS_GLOBAL (1 << 1)
|
||||||
|
|
||||||
int IOSUHAX_Open(void);
|
int IOSUHAX_Open(const char *dev); // if dev == NULL the default path /dev/iosuhax will be used
|
||||||
int IOSUHAX_Close(void);
|
int IOSUHAX_Close(void);
|
||||||
|
|
||||||
int IOSUHAX_memwrite(uint32_t address, const uint8_t * buffer, uint32_t size); // IOSU external input
|
int IOSUHAX_memwrite(uint32_t address, const uint8_t * buffer, uint32_t size); // IOSU external input
|
||||||
|
262
source/iosuhax_disc_interface.c
Normal file
262
source/iosuhax_disc_interface.c
Normal file
@ -0,0 +1,262 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 2016
|
||||||
|
* by Dimok
|
||||||
|
*
|
||||||
|
* This software is provided 'as-is', without any express or implied
|
||||||
|
* warranty. In no event will the authors be held liable for any
|
||||||
|
* damages arising from the use of this software.
|
||||||
|
*
|
||||||
|
* Permission is granted to anyone to use this software for any
|
||||||
|
* purpose, including commercial applications, and to alter it and
|
||||||
|
* redistribute it freely, subject to the following restrictions:
|
||||||
|
*
|
||||||
|
* 1. The origin of this software must not be misrepresented; you
|
||||||
|
* must not claim that you wrote the original software. If you use
|
||||||
|
* this software in a product, an acknowledgment in the product
|
||||||
|
* documentation would be appreciated but is not required.
|
||||||
|
*
|
||||||
|
* 2. Altered source versions must be plainly marked as such, and
|
||||||
|
* must not be misrepresented as being the original software.
|
||||||
|
*
|
||||||
|
* 3. This notice may not be removed or altered from any source
|
||||||
|
* distribution.
|
||||||
|
***************************************************************************/
|
||||||
|
#include <string.h>
|
||||||
|
#include <malloc.h>
|
||||||
|
#include "iosuhax.h"
|
||||||
|
#include "iosuhax_disc_interface.h"
|
||||||
|
|
||||||
|
#define FSA_REF_SD 0x01
|
||||||
|
#define FSA_REF_USB 0x02
|
||||||
|
|
||||||
|
static int initialized = 0;
|
||||||
|
|
||||||
|
static int fsaFdSd = 0;
|
||||||
|
static int fsaFdUsb = 0;
|
||||||
|
static int sdioFd = 0;
|
||||||
|
static int usbFd = 0;
|
||||||
|
|
||||||
|
static void IOSUHAX_disc_io_initialize(void)
|
||||||
|
{
|
||||||
|
if(initialized == 0)
|
||||||
|
{
|
||||||
|
initialized = 1;
|
||||||
|
fsaFdSd = -1;
|
||||||
|
fsaFdUsb = -1;
|
||||||
|
sdioFd = -1;
|
||||||
|
usbFd = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_disc_io_fsa_open(int fsaFd)
|
||||||
|
{
|
||||||
|
IOSUHAX_disc_io_initialize();
|
||||||
|
|
||||||
|
if(IOSUHAX_Open(NULL) < 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if(fsaFd == FSA_REF_SD)
|
||||||
|
{
|
||||||
|
if(fsaFdSd < 0)
|
||||||
|
{
|
||||||
|
fsaFdSd = IOSUHAX_FSA_Open();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(fsaFdSd >= 0)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else if(fsaFd == FSA_REF_USB)
|
||||||
|
{
|
||||||
|
if(fsaFdUsb < 0)
|
||||||
|
{
|
||||||
|
fsaFdUsb = IOSUHAX_FSA_Open();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(fsaFdUsb >= 0)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void IOSUHAX_disc_io_fsa_close(int fsaFd)
|
||||||
|
{
|
||||||
|
if(fsaFd == FSA_REF_SD)
|
||||||
|
{
|
||||||
|
if(fsaFdSd >= 0)
|
||||||
|
{
|
||||||
|
IOSUHAX_FSA_Close(fsaFdSd);
|
||||||
|
fsaFdSd = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(fsaFd == FSA_REF_USB)
|
||||||
|
{
|
||||||
|
if(fsaFdUsb >= 0)
|
||||||
|
{
|
||||||
|
IOSUHAX_FSA_Close(fsaFdUsb);
|
||||||
|
fsaFdUsb = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_sdio_startup(void)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_disc_io_fsa_open(FSA_REF_SD))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if(sdioFd < 0)
|
||||||
|
{
|
||||||
|
int res = IOSUHAX_FSA_RawOpen(fsaFdSd, "/dev/sdcard01", &sdioFd);
|
||||||
|
if(res < 0)
|
||||||
|
{
|
||||||
|
IOSUHAX_disc_io_fsa_close(FSA_REF_SD);
|
||||||
|
sdioFd = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return (sdioFd >= 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_sdio_isInserted(void)
|
||||||
|
{
|
||||||
|
//! TODO: check for SD card inserted with IOSUHAX_FSA_GetDeviceInfo()
|
||||||
|
return initialized && (fsaFdSd >= 0) && (sdioFd >= 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_sdio_clearStatus(void)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_sdio_shutdown(void)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_sdio_isInserted())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
IOSUHAX_FSA_RawClose(fsaFdSd, sdioFd);
|
||||||
|
IOSUHAX_disc_io_fsa_close(FSA_REF_SD);
|
||||||
|
sdioFd = -1;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_sdio_readSectors(uint32_t sector, uint32_t numSectors, void* buffer)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_sdio_isInserted())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
int res = IOSUHAX_FSA_RawRead(fsaFdSd, buffer, 512, numSectors, sector, sdioFd);
|
||||||
|
if(res < 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_sdio_writeSectors(uint32_t sector, uint32_t numSectors, const void* buffer)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_sdio_isInserted())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
int res = IOSUHAX_FSA_RawWrite(fsaFdSd, buffer, 512, numSectors, sector, sdioFd);
|
||||||
|
if(res < 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
const DISC_INTERFACE IOSUHAX_sdio_disc_interface =
|
||||||
|
{
|
||||||
|
DEVICE_TYPE_WII_U_SD,
|
||||||
|
FEATURE_MEDIUM_CANREAD | FEATURE_MEDIUM_CANWRITE | FEATURE_WII_U_SD,
|
||||||
|
IOSUHAX_sdio_startup,
|
||||||
|
IOSUHAX_sdio_isInserted,
|
||||||
|
IOSUHAX_sdio_readSectors,
|
||||||
|
IOSUHAX_sdio_writeSectors,
|
||||||
|
IOSUHAX_sdio_clearStatus,
|
||||||
|
IOSUHAX_sdio_shutdown
|
||||||
|
};
|
||||||
|
|
||||||
|
static bool IOSUHAX_usb_startup(void)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_disc_io_fsa_open(FSA_REF_USB))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if(usbFd < 0)
|
||||||
|
{
|
||||||
|
int res = IOSUHAX_FSA_RawOpen(fsaFdUsb, "/dev/usb01", &usbFd);
|
||||||
|
if(res < 0)
|
||||||
|
{
|
||||||
|
res = IOSUHAX_FSA_RawOpen(fsaFdUsb, "/dev/usb02", &usbFd);
|
||||||
|
if(res < 0)
|
||||||
|
{
|
||||||
|
IOSUHAX_disc_io_fsa_close(FSA_REF_USB);
|
||||||
|
usbFd = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (usbFd >= 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_usb_isInserted(void)
|
||||||
|
{
|
||||||
|
return initialized && (fsaFdUsb >= 0) && (usbFd >= 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_usb_clearStatus(void)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_usb_shutdown(void)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_usb_isInserted())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
IOSUHAX_FSA_RawClose(fsaFdUsb, usbFd);
|
||||||
|
IOSUHAX_disc_io_fsa_close(FSA_REF_USB);
|
||||||
|
usbFd = -1;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_usb_readSectors(uint32_t sector, uint32_t numSectors, void* buffer)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_usb_isInserted())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
int res = IOSUHAX_FSA_RawRead(fsaFdUsb, buffer, 512, numSectors, sector, usbFd);
|
||||||
|
if(res < 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IOSUHAX_usb_writeSectors(uint32_t sector, uint32_t numSectors, const void* buffer)
|
||||||
|
{
|
||||||
|
if(!IOSUHAX_usb_isInserted())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
int res = IOSUHAX_FSA_RawWrite(fsaFdUsb, buffer, 512, numSectors, sector, usbFd);
|
||||||
|
if(res < 0)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
const DISC_INTERFACE IOSUHAX_usb_disc_interface =
|
||||||
|
{
|
||||||
|
DEVICE_TYPE_WII_U_USB,
|
||||||
|
FEATURE_MEDIUM_CANREAD | FEATURE_MEDIUM_CANWRITE | FEATURE_WII_U_USB,
|
||||||
|
IOSUHAX_usb_startup,
|
||||||
|
IOSUHAX_usb_isInserted,
|
||||||
|
IOSUHAX_usb_readSectors,
|
||||||
|
IOSUHAX_usb_writeSectors,
|
||||||
|
IOSUHAX_usb_clearStatus,
|
||||||
|
IOSUHAX_usb_shutdown
|
||||||
|
};
|
73
source/iosuhax_disc_interface.h
Normal file
73
source/iosuhax_disc_interface.h
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* Copyright (C) 2016
|
||||||
|
* by Dimok
|
||||||
|
*
|
||||||
|
* This software is provided 'as-is', without any express or implied
|
||||||
|
* warranty. In no event will the authors be held liable for any
|
||||||
|
* damages arising from the use of this software.
|
||||||
|
*
|
||||||
|
* Permission is granted to anyone to use this software for any
|
||||||
|
* purpose, including commercial applications, and to alter it and
|
||||||
|
* redistribute it freely, subject to the following restrictions:
|
||||||
|
*
|
||||||
|
* 1. The origin of this software must not be misrepresented; you
|
||||||
|
* must not claim that you wrote the original software. If you use
|
||||||
|
* this software in a product, an acknowledgment in the product
|
||||||
|
* documentation would be appreciated but is not required.
|
||||||
|
*
|
||||||
|
* 2. Altered source versions must be plainly marked as such, and
|
||||||
|
* must not be misrepresented as being the original software.
|
||||||
|
*
|
||||||
|
* 3. This notice may not be removed or altered from any source
|
||||||
|
* distribution.
|
||||||
|
***************************************************************************/
|
||||||
|
#ifndef _IOSUHAX_DISC_INTERFACE_H_
|
||||||
|
#define _IOSUHAX_DISC_INTERFACE_H_
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define DEVICE_TYPE_WII_U_SD (('W'<<24)|('U'<<16)|('S'<<8)|'D')
|
||||||
|
#define DEVICE_TYPE_WII_U_USB (('W'<<24)|('U'<<16)|('S'<<8)|'B')
|
||||||
|
#define FEATURE_WII_U_SD 0x00001000
|
||||||
|
#define FEATURE_WII_U_USB 0x00002000
|
||||||
|
|
||||||
|
#ifndef OGC_DISC_IO_INCLUDE
|
||||||
|
typedef uint32_t sec_t;
|
||||||
|
|
||||||
|
#define FEATURE_MEDIUM_CANREAD 0x00000001
|
||||||
|
#define FEATURE_MEDIUM_CANWRITE 0x00000002
|
||||||
|
|
||||||
|
typedef bool (* FN_MEDIUM_STARTUP)(void) ;
|
||||||
|
typedef bool (* FN_MEDIUM_ISINSERTED)(void) ;
|
||||||
|
typedef bool (* FN_MEDIUM_READSECTORS)(uint32_t sector, uint32_t numSectors, void* buffer) ;
|
||||||
|
typedef bool (* FN_MEDIUM_WRITESECTORS)(uint32_t sector, uint32_t numSectors, const void* buffer) ;
|
||||||
|
typedef bool (* FN_MEDIUM_CLEARSTATUS)(void) ;
|
||||||
|
typedef bool (* FN_MEDIUM_SHUTDOWN)(void) ;
|
||||||
|
|
||||||
|
struct DISC_INTERFACE_STRUCT {
|
||||||
|
unsigned long ioType ;
|
||||||
|
unsigned long features ;
|
||||||
|
FN_MEDIUM_STARTUP startup ;
|
||||||
|
FN_MEDIUM_ISINSERTED isInserted ;
|
||||||
|
FN_MEDIUM_READSECTORS readSectors ;
|
||||||
|
FN_MEDIUM_WRITESECTORS writeSectors ;
|
||||||
|
FN_MEDIUM_CLEARSTATUS clearStatus ;
|
||||||
|
FN_MEDIUM_SHUTDOWN shutdown ;
|
||||||
|
} ;
|
||||||
|
|
||||||
|
typedef struct DISC_INTERFACE_STRUCT DISC_INTERFACE ;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern const DISC_INTERFACE IOSUHAX_sdio_disc_interface;
|
||||||
|
extern const DISC_INTERFACE IOSUHAX_usb_disc_interface;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
@ -7,13 +7,13 @@ extern "C" {
|
|||||||
|
|
||||||
#define OS_MUTEX_SIZE 44
|
#define OS_MUTEX_SIZE 44
|
||||||
|
|
||||||
|
#ifndef __WUT__
|
||||||
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
//! Mutex functions
|
//! Mutex functions
|
||||||
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
extern void (* OSInitMutex)(void* mutex);
|
extern void (* OSInitMutex)(void* mutex);
|
||||||
extern void (* OSLockMutex)(void* mutex);
|
extern void (* OSLockMutex)(void* mutex);
|
||||||
extern void (* OSUnlockMutex)(void* mutex);
|
extern void (* OSUnlockMutex)(void* mutex);
|
||||||
extern int (* OSTryLockMutex)(void* mutex);
|
|
||||||
|
|
||||||
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
//! IOS function
|
//! IOS function
|
||||||
@ -21,6 +21,21 @@ extern int (* OSTryLockMutex)(void* mutex);
|
|||||||
extern int (*IOS_Ioctl)(int fd, unsigned int request, void *input_buffer,unsigned int input_buffer_len, void *output_buffer, unsigned int output_buffer_len);
|
extern int (*IOS_Ioctl)(int fd, unsigned int request, void *input_buffer,unsigned int input_buffer_len, void *output_buffer, unsigned int output_buffer_len);
|
||||||
extern int (*IOS_Open)(char *path, unsigned int mode);
|
extern int (*IOS_Open)(char *path, unsigned int mode);
|
||||||
extern int (*IOS_Close)(int fd);
|
extern int (*IOS_Close)(int fd);
|
||||||
|
#else
|
||||||
|
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
//! Mutex functions
|
||||||
|
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
extern void OSInitMutex(void* mutex);
|
||||||
|
extern void OSLockMutex(void* mutex);
|
||||||
|
extern void OSUnlockMutex(void* mutex);
|
||||||
|
|
||||||
|
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
//! IOS function
|
||||||
|
//!----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
extern int IOS_Ioctl(int fd, unsigned int request, void *input_buffer,unsigned int input_buffer_len, void *output_buffer, unsigned int output_buffer_len);
|
||||||
|
extern int IOS_Open(char *path, unsigned int mode);
|
||||||
|
extern int IOS_Close(int fd);
|
||||||
|
#endif // __WUT__
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user