2012-11-15 00:39:56 +01:00
|
|
|
#include "stdafx.h"
|
2014-06-17 17:44:03 +02:00
|
|
|
#include "Utilities/Log.h"
|
2014-06-02 19:27:24 +02:00
|
|
|
#include "Emu/Memory/Memory.h"
|
|
|
|
|
#include "Emu/System.h"
|
2012-11-15 00:39:56 +01:00
|
|
|
#include "Emu/SysCalls/SysCalls.h"
|
|
|
|
|
|
2014-06-25 00:38:34 +02:00
|
|
|
s32 sys_tty_read(u32 ch, u64 buf_addr, u32 len, u64 preadlen_addr)
|
2012-11-15 00:39:56 +01:00
|
|
|
{
|
2014-06-17 17:44:03 +02:00
|
|
|
//we currently do not support reading from the Console
|
2014-06-27 15:26:46 +02:00
|
|
|
LOG_WARNING(HLE, "sys_tty_read: ch: %d, buf addr: %llx, len: %d", ch, buf_addr, len);
|
2012-11-15 00:39:56 +01:00
|
|
|
Memory.Write32NN(preadlen_addr, len);
|
2014-02-16 09:28:32 +01:00
|
|
|
Emu.Pause();
|
2012-11-15 00:39:56 +01:00
|
|
|
|
|
|
|
|
return CELL_OK;
|
|
|
|
|
}
|
|
|
|
|
|
2014-06-25 00:38:34 +02:00
|
|
|
s32 sys_tty_write(u32 ch, u64 buf_addr, u32 len, u64 pwritelen_addr)
|
2012-11-15 00:39:56 +01:00
|
|
|
{
|
2014-02-16 09:28:32 +01:00
|
|
|
if(ch > 15 || (s32)len <= 0) return CELL_EINVAL;
|
2013-06-30 10:46:29 +02:00
|
|
|
if(!Memory.IsGoodAddr(buf_addr)) return CELL_EFAULT;
|
2012-11-15 00:39:56 +01:00
|
|
|
|
2014-06-17 17:44:03 +02:00
|
|
|
//ch 0 seems to be stdout and ch 1 stderr
|
|
|
|
|
if (ch == 1)
|
2014-05-25 10:00:54 +02:00
|
|
|
{
|
2014-06-17 17:44:03 +02:00
|
|
|
LOG_ERROR(TTY, Memory.ReadString(buf_addr, len));
|
2014-05-25 10:00:54 +02:00
|
|
|
}
|
2014-06-17 17:44:03 +02:00
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_NOTICE(TTY, Memory.ReadString(buf_addr, len));
|
|
|
|
|
}
|
|
|
|
|
|
2012-11-15 00:39:56 +01:00
|
|
|
if(!Memory.IsGoodAddr(pwritelen_addr)) return CELL_EFAULT;
|
|
|
|
|
|
|
|
|
|
Memory.Write32(pwritelen_addr, len);
|
|
|
|
|
|
|
|
|
|
return CELL_OK;
|
2013-06-30 10:46:29 +02:00
|
|
|
}
|