mirror of https://github.com/red-prig/fpPS4.git
writev/sceKernelWritev and extended char fd
This commit is contained in:
parent
bb1a892ce5
commit
82f7cbd35f
|
@ -41,6 +41,9 @@ function ps4_sceKernelWrite(fd:Integer;buf:Pointer;nbytes:Int64):Int64; SysV_ABI
|
|||
function ps4_pwrite(fd:Integer;data:Pointer;size,offset:Int64):Int64; SysV_ABI_CDecl;
|
||||
function ps4_sceKernelPwrite(fd:Integer;buf:Pointer;nbytes,offset:Int64):Int64; SysV_ABI_CDecl;
|
||||
|
||||
function ps4_writev(fd:Integer;vector:p_iovec;count:Integer):Int64; SysV_ABI_CDecl;
|
||||
function ps4_sceKernelWritev(fd:Integer;iov:p_iovec;iovcnt:Integer):Int64; SysV_ABI_CDecl;
|
||||
|
||||
function ps4_ftruncate(fd:Integer;size:Int64):Integer; SysV_ABI_CDecl;
|
||||
function ps4_sceKernelFtruncate(fd:Integer;size:Int64):Integer; SysV_ABI_CDecl;
|
||||
|
||||
|
@ -99,7 +102,7 @@ begin
|
|||
Result:=0;
|
||||
if (path=nil) then Exit(-EINVAL);
|
||||
|
||||
Writeln(SysLogPrefix, 'open:',path,' ',flags,' (',OctStr(mode,3),')');
|
||||
Writeln(SysLogPrefix, 'open:',path,' 0x',HexStr(flags,4),' (',OctStr(mode,3),')');
|
||||
|
||||
if ((flags and WR_RDWR)=WR_RDWR) then
|
||||
begin
|
||||
|
@ -416,6 +419,38 @@ begin
|
|||
end;
|
||||
end;
|
||||
|
||||
function ps4_writev(fd:Integer;vector:p_iovec;count:Integer):Int64; SysV_ABI_CDecl;
|
||||
begin
|
||||
_sig_lock;
|
||||
Result:=_sys_writev(fd,vector,count);
|
||||
_sig_unlock;
|
||||
|
||||
if (Result<0) then
|
||||
begin
|
||||
Result:=_set_errno(-Result);
|
||||
end else
|
||||
begin
|
||||
_set_errno(0);
|
||||
end;
|
||||
end;
|
||||
|
||||
function ps4_sceKernelWritev(fd:Integer;iov:p_iovec;iovcnt:Integer):Int64; SysV_ABI_CDecl;
|
||||
begin
|
||||
_sig_lock;
|
||||
Result:=_sys_writev(fd,iov,iovcnt);
|
||||
_sig_unlock;
|
||||
|
||||
if (Result<0) then
|
||||
begin
|
||||
Result:=-Result;
|
||||
_set_errno(Result);
|
||||
Result:=px2sce(Result);
|
||||
end else
|
||||
begin
|
||||
_set_errno(0);
|
||||
end;
|
||||
end;
|
||||
|
||||
function ps4_ftruncate(fd:Integer;size:Int64):Integer; SysV_ABI_CDecl;
|
||||
begin
|
||||
_sig_lock;
|
||||
|
@ -1106,6 +1141,8 @@ begin
|
|||
|
||||
if (path=nil) then Exit(EFAULT);
|
||||
|
||||
//Writeln('access:',path,' ',mode);
|
||||
|
||||
if (path[0]=#0) then
|
||||
begin
|
||||
Exit(ENOENT);
|
||||
|
|
|
@ -1480,6 +1480,7 @@ begin
|
|||
lib^.set_proc($C938FAD88EE4C38B,@ps4_sceKernelPreadv);
|
||||
lib^.set_proc($E304B37BDD8184B2,@ps4_sceKernelWrite);
|
||||
lib^.set_proc($9CA5A2FCDD87055E,@ps4_sceKernelPwrite);
|
||||
lib^.set_proc($900B7A5436C79ABA,@ps4_sceKernelWritev);
|
||||
lib^.set_proc($556DD355988CE3F1,@ps4_sceKernelFtruncate);
|
||||
lib^.set_proc($901C023EC617FE6E,@ps4_sceKernelFstat);
|
||||
|
||||
|
@ -1511,6 +1512,9 @@ begin
|
|||
|
||||
lib^.set_proc($0B6909FDBC92E6B3,@ps4_pwrite);
|
||||
|
||||
lib^.set_proc($6121D10512E7DA92,@ps4_writev); //_writev
|
||||
lib^.set_proc($67668A771CD2E0A1,@ps4_writev); //writev
|
||||
|
||||
lib^.set_proc($8A1E020FDFE08213,@ps4_ftruncate);
|
||||
lib^.set_proc($9AA40C875CCF3D3F,@ps4_fstat);
|
||||
|
||||
|
|
|
@ -33,14 +33,15 @@ type
|
|||
function preadv(vector:p_iovec;count:Integer;offset:Int64):Int64; override;
|
||||
function write (data:Pointer;size:Int64):Int64; override;
|
||||
function pwrite(data:Pointer;size,offset:Int64):Int64; override;
|
||||
function writev(vector:p_iovec;count:Integer):Int64; override;
|
||||
end;
|
||||
|
||||
TDevStd=class(TDevFile)
|
||||
var
|
||||
Text:PText;
|
||||
RText,WText:PText;
|
||||
lock:TRWLock;
|
||||
cache:RawByteString;
|
||||
Constructor Create(t:PText);
|
||||
Constructor Create(r,w:PText);
|
||||
Destructor Destroy; override;
|
||||
function read (data:Pointer;size:Int64):Int64; override;
|
||||
function pread (data:Pointer;size,offset:Int64):Int64; override;
|
||||
|
@ -48,13 +49,14 @@ type
|
|||
function preadv(vector:p_iovec;count:Integer;offset:Int64):Int64; override;
|
||||
function write (data:Pointer;size:Int64):Int64; override;
|
||||
function pwrite(data:Pointer;size,offset:Int64):Int64; override;
|
||||
function writev(vector:p_iovec;count:Integer):Int64; override;
|
||||
end;
|
||||
|
||||
procedure _sys_dev_init;
|
||||
begin
|
||||
_sys_dev_open('stdin' ,O_RDONLY,0); //0
|
||||
_sys_dev_open('stdout',O_WRONLY,0); //1
|
||||
_sys_dev_open('stderr',O_WRONLY,0); //2
|
||||
_sys_dev_open('stdin' ,O_RDWR,0); //0
|
||||
_sys_dev_open('stdout',O_RDWR,0); //1
|
||||
_sys_dev_open('stderr',O_RDWR,0); //2
|
||||
end;
|
||||
|
||||
function _sys_dev_open(const path:RawByteString;flags,mode:Integer):Integer;
|
||||
|
@ -63,9 +65,9 @@ var
|
|||
begin
|
||||
|
||||
Case path of
|
||||
'stdin' :f:=TDevStd.Create(@Input);
|
||||
'stdout':f:=TDevStd.Create(@StdOut);
|
||||
'stderr':f:=TDevStd.Create(@StdErr);
|
||||
'stdin' :f:=TDevStd.Create(@Input,@StdOut);
|
||||
'stdout':f:=TDevStd.Create(@Input,@StdOut);
|
||||
'stderr':f:=TDevStd.Create(@Input,@StdErr);
|
||||
|
||||
'random',
|
||||
'urandom':
|
||||
|
@ -167,14 +169,27 @@ begin
|
|||
Result:=size;
|
||||
end;
|
||||
|
||||
function TDevRandom.writev(vector:p_iovec;count:Integer):Int64;
|
||||
var
|
||||
i:Integer;
|
||||
begin
|
||||
Result:=0;
|
||||
|
||||
For i:=0 to count-1 do
|
||||
begin
|
||||
Result:=Result+vector[i].iov_len;
|
||||
end;
|
||||
end;
|
||||
|
||||
//
|
||||
|
||||
Constructor TDevStd.Create(t:PText);
|
||||
Constructor TDevStd.Create(r,w:PText);
|
||||
type
|
||||
PTextRec=^TextRec;
|
||||
begin
|
||||
Handle:=PTextRec(t)^.Handle;
|
||||
Text:=t;
|
||||
Handle:=PTextRec(w)^.Handle;
|
||||
RText:=r;
|
||||
WText:=w;
|
||||
rwlock_init(lock);
|
||||
cache:='';
|
||||
end;
|
||||
|
@ -207,7 +222,7 @@ begin
|
|||
rwlock_unlock(lock);
|
||||
|
||||
S:='';
|
||||
System.ReadLn(Text^,S);
|
||||
System.ReadLn(RText^,S);
|
||||
S:=S+#10;
|
||||
|
||||
if (Length(S)>size) then
|
||||
|
@ -266,7 +281,7 @@ var
|
|||
S:RawByteString;
|
||||
begin
|
||||
SetString(S,data,size);
|
||||
System.Write(Text^,S);
|
||||
System.Write(WText^,S);
|
||||
Result:=size;
|
||||
end;
|
||||
|
||||
|
@ -275,6 +290,29 @@ begin
|
|||
Result:=write(data,size);
|
||||
end;
|
||||
|
||||
function TDevStd.writev(vector:p_iovec;count:Integer):Int64;
|
||||
var
|
||||
i,n:Integer;
|
||||
begin
|
||||
Result:=0;
|
||||
|
||||
For i:=0 to count-1 do
|
||||
begin
|
||||
n:=write(vector[i].iov_base,vector[i].iov_len);
|
||||
|
||||
if (n>0) then
|
||||
begin
|
||||
Result:=Result+n;
|
||||
if (n<vector[i].iov_len) then Exit;
|
||||
end else
|
||||
begin
|
||||
Exit(-EIO);
|
||||
Break;
|
||||
end;
|
||||
|
||||
end;
|
||||
end;
|
||||
|
||||
//
|
||||
|
||||
end.
|
||||
|
|
|
@ -63,6 +63,7 @@ type
|
|||
function preadv (vector:p_iovec;count:Integer;offset:Int64):Int64; override;
|
||||
function write (data:Pointer;size:Int64):Int64; override;
|
||||
function pwrite (data:Pointer;size,offset:Int64):Int64; override;
|
||||
function writev (vector:p_iovec;count:Integer):Int64; override;
|
||||
function ftruncate (size:Int64):Integer; override;
|
||||
function fstat (stat:PSceKernelStat):Integer; override;
|
||||
function lseek (offset:Int64;whence:Integer):Int64; override;
|
||||
|
@ -360,6 +361,11 @@ begin
|
|||
Result:=-EISDIR;
|
||||
end;
|
||||
|
||||
function TDirFile.writev(vector:p_iovec;count:Integer):Int64;
|
||||
begin
|
||||
Result:=-EISDIR;
|
||||
end;
|
||||
|
||||
function TDirFile.ftruncate(size:Int64):Integer;
|
||||
begin
|
||||
Result:=EISDIR;
|
||||
|
|
|
@ -207,6 +207,7 @@ type
|
|||
function preadv (vector:p_iovec;count:Integer;offset:Int64):Int64; virtual;
|
||||
function write (data:Pointer;size:Int64):Int64; virtual;
|
||||
function pwrite (data:Pointer;size,offset:Int64):Int64; virtual;
|
||||
function writev (vector:p_iovec;count:Integer):Int64; virtual;
|
||||
function ftruncate (size:Int64):Integer; virtual;
|
||||
function fstat (stat:PSceKernelStat):Integer; virtual;
|
||||
function fsync ():Integer; virtual;
|
||||
|
@ -224,6 +225,7 @@ function _sys_pread(fd:Integer;data:Pointer;size,offset:Int64):Int64;
|
|||
function _sys_readv(fd:Integer;vector:p_iovec;count:Integer):Int64;
|
||||
function _sys_preadv(fd:Integer;vector:p_iovec;count:Integer;offset:Int64):Int64;
|
||||
function _sys_write(fd:Integer;data:Pointer;size:Int64):Int64;
|
||||
function _sys_writev(fd:Integer;vector:p_iovec;count:Integer):Int64;
|
||||
function _sys_pwrite(fd:Integer;data:Pointer;size,offset:Int64):Int64;
|
||||
function _sys_ftruncate(fd:Integer;size:Int64):Integer;
|
||||
function _sys_fstat(fd:Integer;stat:PSceKernelStat):Integer;
|
||||
|
@ -273,6 +275,11 @@ begin
|
|||
Result:=-ENOTSUP;
|
||||
end;
|
||||
|
||||
function TCustomFile.writev(vector:p_iovec;count:Integer):Int64;
|
||||
begin
|
||||
Result:=-ENOTSUP;
|
||||
end;
|
||||
|
||||
function TCustomFile.ftruncate(size:Int64):Integer;
|
||||
begin
|
||||
Result:=ENOTSUP;
|
||||
|
@ -427,7 +434,6 @@ end;
|
|||
function _sys_readv(fd:Integer;vector:p_iovec;count:Integer):Int64;
|
||||
var
|
||||
f:TCustomFile;
|
||||
i:Integer;
|
||||
begin
|
||||
if (fd<0) then Exit(-EINVAL);
|
||||
|
||||
|
@ -452,7 +458,6 @@ end;
|
|||
function _sys_preadv(fd:Integer;vector:p_iovec;count:Integer;offset:Int64):Int64;
|
||||
var
|
||||
f:TCustomFile;
|
||||
i:Integer;
|
||||
begin
|
||||
if (fd<0) then Exit(-EINVAL);
|
||||
|
||||
|
@ -523,6 +528,30 @@ begin
|
|||
f.Release;
|
||||
end;
|
||||
|
||||
function _sys_writev(fd:Integer;vector:p_iovec;count:Integer):Int64;
|
||||
var
|
||||
f:TCustomFile;
|
||||
begin
|
||||
if (fd<0) then Exit(-EINVAL);
|
||||
|
||||
if (vector=nil) or (count=0) then //zero check
|
||||
begin
|
||||
f:=_sys_acqure_fd(fd);
|
||||
if (f=nil) then Exit(-EBADF);
|
||||
f.Release;
|
||||
Exit(0);
|
||||
end;
|
||||
|
||||
if (count<=0) or (count>IOV_MAX) then Exit(-EINVAL);
|
||||
|
||||
f:=_sys_acqure_fd(fd);
|
||||
if (f=nil) then Exit(-EBADF);
|
||||
|
||||
Result:=f.writev(vector,count);
|
||||
|
||||
f.Release;
|
||||
end;
|
||||
|
||||
function _sys_ftruncate(fd:Integer;size:Int64):Integer;
|
||||
var
|
||||
f:TCustomFile;
|
||||
|
|
|
@ -32,6 +32,7 @@ type
|
|||
function preadv (vector:p_iovec;count:Integer;offset:Int64):Int64; override;
|
||||
function write (data:Pointer;size:Int64):Int64; override;
|
||||
function pwrite (data:Pointer;size,offset:Int64):Int64; override;
|
||||
function writev (vector:p_iovec;count:Integer):Int64; override;
|
||||
function ftruncate(size:Int64):Integer; override;
|
||||
function fstat (stat:PSceKernelStat):Integer; override;
|
||||
function fsync ():Integer; override;
|
||||
|
@ -476,6 +477,52 @@ begin
|
|||
end;
|
||||
end;
|
||||
|
||||
function TFile.writev(vector:p_iovec;count:Integer):Int64;
|
||||
label
|
||||
_exit;
|
||||
var
|
||||
s:IO_STATUS_BLOCK;
|
||||
e:Integer;
|
||||
i:Integer;
|
||||
v:iovec;
|
||||
begin
|
||||
Result:=0;
|
||||
|
||||
rwlock_wrlock(lock);
|
||||
|
||||
For i:=0 to count-1 do
|
||||
begin
|
||||
v:=vector[i];
|
||||
|
||||
if (v.iov_base<>nil) and (v.iov_len<>0) then
|
||||
begin
|
||||
|
||||
s:=Default(IO_STATUS_BLOCK);
|
||||
e:=NtWriteFile(Handle,0,nil,nil,@s,v.iov_base,v.iov_len,nil,nil);
|
||||
if (e=STATUS_PENDING) then e:=NtWaitForSingleObject(Handle,False,nil);
|
||||
|
||||
e:=-ntf2px(e);
|
||||
|
||||
if (e<>0) then
|
||||
begin
|
||||
Result:=e;
|
||||
Goto _exit;
|
||||
end else
|
||||
begin
|
||||
Result:=Result+Int64(s.Information);
|
||||
if (Int64(s.Information)<v.iov_len) then
|
||||
begin
|
||||
Goto _exit;
|
||||
end;
|
||||
end;
|
||||
|
||||
end;
|
||||
end;
|
||||
|
||||
_exit:
|
||||
rwlock_unlock(lock);
|
||||
end;
|
||||
|
||||
function TFile.ftruncate(size:Int64):Integer;
|
||||
var
|
||||
s:IO_STATUS_BLOCK;
|
||||
|
|
Loading…
Reference in New Issue