/*
This file is part of jpcsp.
Jpcsp is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Jpcsp is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Jpcsp. If not, see <http://www.gnu.org/licenses/>.
*/
package jpcsp.HLE.VFS;
import static jpcsp.HLE.kernel.types.SceKernelErrors.ERROR_KERNEL_UNSUPPORTED_OPERATION;
import java.util.Map;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import jpcsp.HLE.TPointer;
import jpcsp.HLE.kernel.types.SceIoDirent;
import jpcsp.HLE.kernel.types.SceIoStat;
import jpcsp.HLE.modules.IoFileMgrForUser;
import jpcsp.util.Utilities;
public abstract class AbstractVirtualFileSystem implements IVirtualFileSystem {
protected static Logger log = Logger.getLogger("vfs");
public static final int IO_ERROR = -1;
protected static boolean hasFlag(int mode, int flag) {
return (mode & flag) == flag;
}
@Override
public void ioInit() {
}
@Override
public void ioExit() {
}
@Override
public IVirtualFile ioOpen(String fileName, int flags, int mode) {
return null;
}
@Override
public int ioRead(IVirtualFile file, TPointer outputPointer, int outputLength) {
return file.ioRead(outputPointer, outputLength);
}
@Override
public int ioWrite(IVirtualFile file, TPointer inputPointer, int inputLength) {
return file.ioWrite(inputPointer, inputLength);
}
@Override
public long ioLseek(IVirtualFile file, long offset) {
return file.ioLseek(offset);
}
@Override
public int ioIoctl(IVirtualFile file, int command, TPointer inputPointer, int inputLength, TPointer outputPointer, int outputLength) {
return file.ioIoctl(command, inputPointer, inputLength, outputPointer, outputLength);
}
@Override
public int ioClose(IVirtualFile file) {
return file.ioClose();
}
@Override
public int ioRemove(String name) {
return IO_ERROR;
}
@Override
public int ioMkdir(String name, int mode) {
return IO_ERROR;
}
@Override
public int ioRmdir(String name) {
return IO_ERROR;
}
@Override
public String[] ioDopen(String dirName) {
return null;
}
@Override
public int ioDread(String dirName, SceIoDirent dir) {
// Return the Getstat on the given directory file
String fileName;
if (dirName == null || dirName.length() == 0) {
fileName = dir.filename;
} else {
fileName = dirName + "/" + dir.filename;
}
int result = ioGetstat(fileName, dir.stat);
if (result == 0) {
// Success is 1 for sceIoDread
return 1;
}
return result;
}
@Override
public int ioDclose(String dirName) {
return 0;
}
@Override
public int ioGetstat(String fileName, SceIoStat stat) {
return IO_ERROR;
}
@Override
public int ioChstat(String fileName, SceIoStat stat, int bits) {
return IO_ERROR;
}
@Override
public int ioRename(String oldFileName, String newFileName) {
return IO_ERROR;
}
@Override
public int ioChdir(String directoryName) {
return IO_ERROR;
}
@Override
public int ioMount() {
return IO_ERROR;
}
@Override
public int ioUmount() {
return IO_ERROR;
}
@Override
public int ioDevctl(String deviceName, int command, TPointer inputPointer, int inputLength, TPointer outputPointer, int outputLength) {
if (log.isEnabledFor(Level.WARN)) {
log.warn(String.format("ioDevctl on '%s', 0x%08X unsupported command, inlen=%d, outlen=%d", deviceName, command, inputLength, outputLength));
if (inputPointer.isAddressGood()) {
log.warn(String.format("ioDevctl indata: %s", Utilities.getMemoryDump(inputPointer.getAddress(), inputLength)));
}
if (outputPointer.isAddressGood()) {
log.warn(String.format("ioDevctl outdata: %s", Utilities.getMemoryDump(outputPointer.getAddress(), outputLength)));
}
}
return ERROR_KERNEL_UNSUPPORTED_OPERATION;
}
@Override
public Map<IoFileMgrForUser.IoOperation, IoFileMgrForUser.IoOperationTiming> getTimings() {
return IoFileMgrForUser.defaultTimings;
}
}