orbea bfc366decc Squeeze extra blank lines with cat(1).
Example:

find . -type f -iname '*.c' | while read -r i; do
  cat -s "$i" > "$i.new"
  mv "$i.new" "$i"
done
2019-01-08 11:04:58 -08:00

479 lines
9.4 KiB
C

/*-------------------------------------------------------------
conf.c -- SYSCONF support
Copyright (C) 2008
Hector Martin (marcan)
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.
-------------------------------------------------------------*/
#if defined(HW_RVL)
#include <stdio.h>
#include <string.h>
#include <malloc.h>
#include "ipc.h"
#include "asm.h"
#include "processor.h"
#include "conf.h"
static int __conf_inited = 0;
static u8 __conf_buffer[0x4000] ATTRIBUTE_ALIGN(32);
static char __conf_txt_buffer[0x101] ATTRIBUTE_ALIGN(32);
static const char __conf_file[] ATTRIBUTE_ALIGN(32) = "/shared2/sys/SYSCONF";
static const char __conf_txt_file[] ATTRIBUTE_ALIGN(32) = "/title/00000001/00000002/data/setting.txt";
void __CONF_DecryptTextBuffer(void)
{
u32 key = 0x73B5DBFA;
int i;
for(i=0; i<0x100; i++) {
__conf_txt_buffer[i] ^= key & 0xff;
key = (key<<1) | (key>>31);
}
}
s32 CONF_Init(void)
{
int fd;
int ret;
if(__conf_inited) return 0;
fd = IOS_Open(__conf_file,1);
if(fd < 0) return fd;
memset(__conf_buffer,0,0x4000);
memset(__conf_txt_buffer,0,0x101);
ret = IOS_Read(fd, __conf_buffer, 0x4000);
IOS_Close(fd);
if(ret != 0x4000) return CONF_EBADFILE;
fd = IOS_Open(__conf_txt_file,1);
if(fd < 0) return fd;
ret = IOS_Read(fd, __conf_txt_buffer, 0x100);
IOS_Close(fd);
if(ret != 0x100) return CONF_EBADFILE;
if(memcmp(__conf_buffer, "SCv0", 4)) return CONF_EBADFILE;
__CONF_DecryptTextBuffer();
__conf_inited = 1;
return 0;
}
int __CONF_GetTxt(const char *name, char *buf, int length)
{
char *line = __conf_txt_buffer;
char *delim, *end;
int slen;
int nlen = strlen(name);
if(!__conf_inited) return CONF_ENOTINIT;
while(line < (__conf_txt_buffer+0x100) ) {
delim = strchr(line, '=');
if(delim && ((delim - line) == nlen) && !memcmp(name, line, nlen)) {
delim++;
end = strchr(line, '\r');
if (!end) end = strchr(line, '\n');
if(end) {
slen = end - delim;
if(slen < length) {
memcpy(buf, delim, slen);
buf[slen] = 0;
return slen;
} else {
return CONF_ETOOBIG;
}
}
}
// skip to line end
while(line < (__conf_txt_buffer+0x100) && *line++ != '\n');
}
return CONF_ENOENT;
}
u8 *__CONF_Find(const char *name)
{
u16 count;
u16 *offset;
int nlen = strlen(name);
count = *((u16*)(&__conf_buffer[4]));
offset = (u16*)&__conf_buffer[6];
while(count--) {
if((nlen == ((__conf_buffer[*offset]&0x0F)+1)) && !memcmp(name, &__conf_buffer[*offset+1], nlen))
return &__conf_buffer[*offset];
offset++;
}
return NULL;
}
s32 CONF_GetLength(const char *name)
{
u8 *entry;
if(!__conf_inited) return CONF_ENOTINIT;
entry = __CONF_Find(name);
if(!entry) return CONF_ENOENT;
switch(*entry>>5) {
case 1:
return *((u16*)&entry[strlen(name)+1]) + 1;
case 2:
return entry[strlen(name)+1] + 1;
case 3:
return 1;
case 4:
return 2;
case 5:
return 4;
case 7:
return 1;
default:
return CONF_ENOTIMPL;
}
}
s32 CONF_GetType(const char *name)
{
u8 *entry;
if(!__conf_inited) return CONF_ENOTINIT;
entry = __CONF_Find(name);
if(!entry) return CONF_ENOENT;
return *entry>>5;
}
s32 CONF_Get(const char *name, void *buffer, u32 length)
{
u8 *entry;
s32 len;
if(!__conf_inited) return CONF_ENOTINIT;
entry = __CONF_Find(name);
if(!entry) return CONF_ENOENT;
len = CONF_GetLength(name);
if(len<0) return len;
if(len>length) return CONF_ETOOBIG;
switch(*entry>>5) {
case CONF_BIGARRAY:
memcpy(buffer, &entry[strlen(name)+3], len);
break;
case CONF_SMALLARRAY:
memcpy(buffer, &entry[strlen(name)+2], len);
break;
case CONF_BYTE:
case CONF_SHORT:
case CONF_LONG:
case CONF_BOOL:
memset(buffer, 0, length);
memcpy(buffer, &entry[strlen(name)+1], len);
break;
default:
return CONF_ENOTIMPL;
}
return len;
}
s32 CONF_GetShutdownMode(void)
{
u8 idleconf[2] = {0,0};
int res;
res = CONF_Get("IPL.IDL", idleconf, 2);
if(res<0) return res;
if(res!=2) return CONF_EBADVALUE;
return idleconf[0];
}
s32 CONF_GetIdleLedMode(void)
{
int res;
u8 idleconf[2] = {0,0};
res = CONF_Get("IPL.IDL", idleconf, 2);
if(res<0) return res;
if(res!=2) return CONF_EBADVALUE;
return idleconf[1];
}
s32 CONF_GetProgressiveScan(void)
{
int res;
u8 val = 0;
res = CONF_Get("IPL.PGS", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetEuRGB60(void)
{
int res;
u8 val = 0;
res = CONF_Get("IPL.E60", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetIRSensitivity(void)
{
int res;
u32 val = 0;
res = CONF_Get("BT.SENS", &val, 4);
if(res<0) return res;
if(res!=4) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetSensorBarPosition(void)
{
int res;
u8 val = 0;
res = CONF_Get("BT.BAR", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetPadSpeakerVolume(void)
{
int res;
u8 val = 0;
res = CONF_Get("BT.SPKV", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetPadMotorMode(void)
{
int res;
u8 val = 0;
res = CONF_Get("BT.MOT", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetSoundMode(void)
{
int res;
u8 val = 0;
res = CONF_Get("IPL.SND", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetLanguage(void)
{
int res;
u8 val = 0;
res = CONF_Get("IPL.LNG", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetCounterBias(u32 *bias)
{
int res;
res = CONF_Get("IPL.CB", bias, 4);
if(res<0) return res;
if(res!=4) return CONF_EBADVALUE;
return CONF_ERR_OK;
}
s32 CONF_GetScreenSaverMode(void)
{
int res;
u8 val = 0;
res = CONF_Get("IPL.SSV", &val, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetDisplayOffsetH(s8 *offset)
{
int res;
res = CONF_Get("IPL.DH", offset, 1);
if(res<0) return res;
if(res!=1) return CONF_EBADVALUE;
return 0;
}
s32 CONF_GetPadDevices(conf_pads *pads)
{
int res;
res = CONF_Get("BT.DINF", pads, sizeof(conf_pads));
if(res < 0) return res;
if(res < sizeof(conf_pads)) return CONF_EBADVALUE;
return 0;
}
s32 CONF_GetNickName(u8 *nickname)
{
int i, res;
u16 buf[11];
res = CONF_Get("IPL.NIK", buf, 0x16);
if(res < 0) return res;
if((res != 0x16) || (!buf[0])) return CONF_EBADVALUE;
for(i=0; i<10; i++)
nickname[i] = buf[i];
nickname[10] = 0;
return res;
}
s32 CONF_GetAspectRatio(void)
{
int res;
u8 val = 0;
res = CONF_Get("IPL.AR", &val, 1);
if(res < 0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetEULA(void)
{
int res;
u8 val = 0;
res = CONF_Get("IPL.EULA", &val, 1);
if(res < 0) return res;
if(res!=1) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetParentalPassword(s8 *password)
{
int res;
u8 buf[0x4A];
res = CONF_Get("IPL.PC", buf, 0x4A);
if(res < 0) return res;
if(res!=1) return CONF_EBADVALUE;
memcpy(password, buf+3, 4);
password[4] = 0;
return res;
}
s32 CONF_GetParentalAnswer(s8 *answer)
{
int res;
u8 buf[0x4A];
res = CONF_Get("IPL.PC", buf, 0x4A);
if(res < 0) return res;
if(res!=1) return CONF_EBADVALUE;
memcpy(answer, buf+8, 32);
answer[32] = 0;
return res;
}
s32 CONF_GetWiiConnect24(void)
{
int res;
u32 val = 0;
res = CONF_Get("NET.WCFG", &val, 4);
if(res < 0) return res;
if(res!=4) return CONF_EBADVALUE;
return val;
}
s32 CONF_GetRegion(void)
{
int res;
char buf[3];
res = __CONF_GetTxt("GAME", buf, 3);
if(res < 0) return res;
if(!strcmp(buf, "JP")) return CONF_REGION_JP;
if(!strcmp(buf, "US")) return CONF_REGION_US;
if(!strcmp(buf, "EU")) return CONF_REGION_EU;
if(!strcmp(buf, "KR")) return CONF_REGION_KR;
if(!strcmp(buf, "CN")) return CONF_REGION_CN;
return CONF_EBADVALUE;
}
s32 CONF_GetArea(void)
{
int res;
char buf[4];
res = __CONF_GetTxt("AREA", buf, 4);
if(res < 0) return res;
if(!strcmp(buf, "JPN")) return CONF_AREA_JPN;
if(!strcmp(buf, "USA")) return CONF_AREA_USA;
if(!strcmp(buf, "EUR")) return CONF_AREA_EUR;
if(!strcmp(buf, "AUS")) return CONF_AREA_AUS;
if(!strcmp(buf, "BRA")) return CONF_AREA_BRA;
if(!strcmp(buf, "TWN")) return CONF_AREA_TWN;
if(!strcmp(buf, "ROC")) return CONF_AREA_ROC;
if(!strcmp(buf, "KOR")) return CONF_AREA_KOR;
if(!strcmp(buf, "HKG")) return CONF_AREA_HKG;
if(!strcmp(buf, "ASI")) return CONF_AREA_ASI;
if(!strcmp(buf, "LTN")) return CONF_AREA_LTN;
if(!strcmp(buf, "SAF")) return CONF_AREA_SAF;
if(!strcmp(buf, "CHN")) return CONF_AREA_CHN;
return CONF_EBADVALUE;
}
s32 CONF_GetVideo(void)
{
int res;
char buf[5];
res = __CONF_GetTxt("VIDEO", buf, 5);
if(res < 0) return res;
if(!strcmp(buf, "NTSC")) return CONF_VIDEO_NTSC;
if(!strcmp(buf, "PAL")) return CONF_VIDEO_PAL;
if(!strcmp(buf, "MPAL")) return CONF_VIDEO_MPAL;
return CONF_EBADVALUE;
}
#endif