rpcsx/rpcs3/Emu/SysCalls/lv2/sys_tty.cpp

39 lines
1.1 KiB
C++
Raw Normal View History

#include "stdafx.h"
#include "Utilities/Log.h"
#include "Emu/Memory/Memory.h"
#include "Emu/System.h"
#include "Emu/SysCalls/SysCalls.h"
2014-08-23 16:51:51 +02:00
#include "sys_tty.h"
2014-08-23 16:51:51 +02:00
SysCallBase sys_tty("sys_tty");
s32 sys_tty_read(u32 ch, u64 buf_addr, u32 len, u64 preadlen_addr)
{
2014-08-23 16:51:51 +02:00
sys_tty.Error("sys_tty_read(ch=%d, buf_addr=%llx, len=%d, preadlen_addr=0x%llx)", ch, buf_addr, len, preadlen_addr);
2014-07-06 18:05:52 +02:00
// We currently do not support reading from the Console
2014-07-14 21:15:30 +02:00
Memory.Write32(preadlen_addr, len);
2014-02-16 09:28:32 +01:00
Emu.Pause();
return CELL_OK;
}
s32 sys_tty_write(u32 ch, u64 buf_addr, u32 len, u64 pwritelen_addr)
{
2014-08-23 16:51:51 +02:00
sys_tty.Log("sys_tty_write(ch=%d, buf_addr=%llx, len=%d, preadlen_addr=0x%llx)", ch, buf_addr, len, pwritelen_addr);
2014-02-16 09:28:32 +01:00
if(ch > 15 || (s32)len <= 0) return CELL_EINVAL;
2014-07-06 18:05:52 +02:00
if (ch == SYS_TTYP_PPU_STDOUT || ch == SYS_TTYP_SPU_STDOUT || (ch >= SYS_TTYP_USER1 && ch <= SYS_TTYP_USER13)) {
LOG_NOTICE(TTY, "%s", Memory.ReadString(buf_addr, len).c_str());
}
2014-07-06 18:05:52 +02:00
if (ch == SYS_TTYP_PPU_STDERR) {
LOG_ERROR(TTY, "%s", Memory.ReadString(buf_addr, len).c_str());
2014-07-06 18:05:52 +02:00
}
Memory.Write32(pwritelen_addr, len);
return CELL_OK;
}