mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-03-13 07:14:49 +00:00
560 lines
17 KiB
C++
560 lines
17 KiB
C++
#include "stdafx.h"
|
|
#include "Emu/SysCalls/SysCalls.h"
|
|
#include "Emu/SysCalls/SC_FUNC.h"
|
|
#include "cellPamf.h"
|
|
|
|
void cellPamf_init();
|
|
Module cellPamf(0x0012, cellPamf_init);
|
|
|
|
int pamfStreamTypeToEsFilterId(u8 type, u8 ch, mem_ptr_t<CellCodecEsFilterId> pEsFilterId)
|
|
{
|
|
//TODO: convert type and ch to EsFilterId
|
|
pEsFilterId->filterIdMajor = 0;
|
|
pEsFilterId->filterIdMinor = 0;
|
|
pEsFilterId->supplementalInfo1 = 0;
|
|
pEsFilterId->supplementalInfo2 = 0;
|
|
|
|
switch (type)
|
|
{
|
|
case CELL_PAMF_STREAM_TYPE_AVC:
|
|
switch (ch)
|
|
{
|
|
case 0:
|
|
{
|
|
pEsFilterId->filterIdMajor = 0xe0; //fake info
|
|
pEsFilterId->filterIdMinor = 0;
|
|
pEsFilterId->supplementalInfo1 = 0x01;
|
|
pEsFilterId->supplementalInfo2 = 0;
|
|
}
|
|
break;
|
|
case 1:
|
|
{
|
|
pEsFilterId->filterIdMajor = 0xe1;
|
|
pEsFilterId->filterIdMinor = 0;
|
|
pEsFilterId->supplementalInfo1 = 0x01;
|
|
pEsFilterId->supplementalInfo2 = 0;
|
|
}
|
|
break;
|
|
default:
|
|
cellPamf.Error("*** TODO: pamfStreamTypeToEsFilterId: CELL_PAMF_STREAM_TYPE_AVC (ch=%d)", ch);
|
|
}
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_ATRAC3PLUS:
|
|
if (ch == 0)
|
|
{
|
|
pEsFilterId->filterIdMajor = 0xbd;
|
|
pEsFilterId->filterIdMinor = 0;
|
|
pEsFilterId->supplementalInfo1 = 0;
|
|
pEsFilterId->supplementalInfo2 = 0;
|
|
}
|
|
else
|
|
cellPamf.Error("*** TODO: pamfStreamTypeToEsFilterId: CELL_PAMF_STREAM_TYPE_ATRAC3PLUS (ch=%d)", ch);
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_PAMF_LPCM:
|
|
if (ch == 0)
|
|
{
|
|
pEsFilterId->filterIdMajor = 0xbd;
|
|
pEsFilterId->filterIdMinor = 0x40;
|
|
pEsFilterId->supplementalInfo1 = 0;
|
|
pEsFilterId->supplementalInfo2 = 0;
|
|
}
|
|
else
|
|
cellPamf.Error("*** TODO: pamfStreamTypeToEsFilterId: CELL_PAMF_STREAM_TYPE_LPCM (ch=%d)", ch);
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_USER_DATA:
|
|
if (ch == 0)
|
|
{
|
|
pEsFilterId->filterIdMajor = 0xbd;
|
|
pEsFilterId->filterIdMinor = 0x20;
|
|
pEsFilterId->supplementalInfo1 = 0;
|
|
pEsFilterId->supplementalInfo2 = 0;
|
|
}
|
|
else
|
|
cellPamf.Error("*** TODO: pamfStreamTypeToEsFilterId: CELL_PAMF_STREAM_TYPE_USER_DATA (ch=%d)", ch);
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_AC3:
|
|
cellPamf.Error("*** TODO: pamfStreamTypeToEsFilterId: CELL_PAMF_STREAM_TYPE_AC3 (ch=%d)", ch);
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_M2V:
|
|
cellPamf.Error("*** TODO: pamfStreamTypeToEsFilterId: CELL_PAMF_STREAM_TYPE_M2V (ch=%d)", ch);
|
|
break;
|
|
default:
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
return CELL_OK;
|
|
}
|
|
|
|
u8 pamfGetStreamType(mem_ptr_t<CellPamfReader> pSelf, u8 stream)
|
|
{
|
|
//TODO: get stream type correctly
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
|
|
switch (pAddr->stream_headers[stream].type)
|
|
{
|
|
case 0x1b: return CELL_PAMF_STREAM_TYPE_AVC;
|
|
case 0xdc: return CELL_PAMF_STREAM_TYPE_ATRAC3PLUS;
|
|
case 0x80: return CELL_PAMF_STREAM_TYPE_PAMF_LPCM;
|
|
case 0xdd: return CELL_PAMF_STREAM_TYPE_USER_DATA;
|
|
default:
|
|
cellPamf.Error("pamfGetStreamType: unsupported stream type found(0x%x)",
|
|
pAddr->stream_headers[stream].type);
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
u8 pamfGetStreamChannel(mem_ptr_t<CellPamfReader> pSelf, u8 stream)
|
|
{
|
|
cellPamf.Warning("TODO: pamfGetStreamChannel");
|
|
//TODO: get stream channel correctly
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
|
|
if ((pAddr->stream_headers[stream].type == 0x1b) &&
|
|
(pAddr->stream_headers[stream].stream_id == 0xe1)) return 1;
|
|
return 0;
|
|
}
|
|
|
|
int cellPamfGetHeaderSize(mem_ptr_t<PamfHeader> pAddr, u64 fileSize, mem64_t pSize)
|
|
{
|
|
cellPamf.Warning("cellPamfGetHeaderSize(pAddr=0x%x, fileSize=%d, pSize_addr=0x%x)",
|
|
pAddr.GetAddr(), fileSize, pSize.GetAddr());
|
|
|
|
//if ((u32)pAddr->magic != 0x464d4150)
|
|
//return CELL_PAMF_ERROR_UNKNOWN_TYPE;
|
|
|
|
const u64 offset = (u64)pAddr->data_offset << 11;
|
|
pSize = offset /*? offset : 2048*/; //hack
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfGetHeaderSize2(mem_ptr_t<PamfHeader> pAddr, u64 fileSize, u32 attribute, mem64_t pSize)
|
|
{
|
|
cellPamf.Warning("cellPamfGetHeaderSize2(pAddr=0x%x, fileSize=%d, attribute=0x%x, pSize_addr=0x%x)",
|
|
pAddr.GetAddr(), fileSize, attribute, pSize.GetAddr());
|
|
|
|
//if ((u32)pAddr->magic != 0x464d4150)
|
|
//return CELL_PAMF_ERROR_UNKNOWN_TYPE;
|
|
|
|
const u64 offset = (u64)pAddr->data_offset << 11;
|
|
pSize = offset /*? offset : 2048*/; //hack
|
|
return CELL_OK;
|
|
}
|
|
|
|
//u32 hack_LastHeader = 0;
|
|
|
|
int cellPamfGetStreamOffsetAndSize(mem_ptr_t<PamfHeader> pAddr, u64 fileSize, mem64_t pOffset, mem64_t pSize)
|
|
{
|
|
cellPamf.Warning("cellPamfGetStreamOffsetAndSize(pAddr=0x%x, fileSize=%d, pOffset_addr=0x%x, pSize_addr=0x%x)",
|
|
pAddr.GetAddr(), fileSize, pOffset.GetAddr(), pSize.GetAddr());
|
|
|
|
//if ((u32)pAddr->magic != 0x464d4150)
|
|
//return CELL_PAMF_ERROR_UNKNOWN_TYPE;
|
|
|
|
const u64 offset = (u64)pAddr->data_offset << 11;
|
|
pOffset = offset /*? offset : 2048*/; //hack
|
|
const u64 size = (u64)pAddr->data_size << 11;
|
|
pSize = size /*? size : (fileSize - 2048)*/; //hack
|
|
//if (!(u32)pAddr->magic) hack_LastHeader = pAddr.GetAddr();
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfVerify(mem_ptr_t<PamfHeader> pAddr, u64 fileSize)
|
|
{
|
|
cellPamf.Warning("cellPamfVerify(pAddr=0x%x, fileSize=%d)", pAddr.GetAddr(), fileSize);
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfReaderInitialize(mem_ptr_t<CellPamfReader> pSelf, mem_ptr_t<PamfHeader> pAddr, u64 fileSize, u32 attribute)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderInitialize(pSelf=0x%x, pAddr=0x%x, fileSize=%d, attribute=0x%x)",
|
|
pSelf.GetAddr(), pAddr.GetAddr(), fileSize, attribute);
|
|
|
|
if (fileSize)
|
|
{
|
|
pSelf->fileSize = fileSize;
|
|
}
|
|
else //if fileSize is unknown
|
|
{
|
|
pSelf->fileSize = ((u64)pAddr->data_offset << 11) + ((u64)pAddr->data_size << 11);
|
|
}
|
|
pSelf->pAddr = pAddr.GetAddr();
|
|
//if (hack_LastHeader) memcpy(Memory + pAddr.GetAddr(), Memory + hack_LastHeader, 2048);
|
|
if (attribute & CELL_PAMF_ATTRIBUTE_VERIFY_ON)
|
|
{
|
|
//TODO
|
|
}
|
|
|
|
pSelf->stream = 0; //??? currently set stream
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfReaderGetPresentationStartTime(mem_ptr_t<CellPamfReader> pSelf, mem_ptr_t<CellCodecTimeStamp> pTimeStamp)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetPresentationStartTime(pSelf=0x%x, pTimeStamp_addr=0x%x)",
|
|
pSelf.GetAddr(), pTimeStamp.GetAddr());
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
const u32 upper = (u16)pAddr->start_pts_high;
|
|
pTimeStamp->upper = upper;
|
|
pTimeStamp->lower = pAddr->start_pts_low;
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfReaderGetPresentationEndTime(mem_ptr_t<CellPamfReader> pSelf, mem_ptr_t<CellCodecTimeStamp> pTimeStamp)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetPresentationEndTime(pSelf=0x%x, pTimeStamp_addr=0x%x)",
|
|
pSelf.GetAddr(), pTimeStamp.GetAddr());
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
const u32 upper = (u16)pAddr->end_pts_high;
|
|
pTimeStamp->upper = upper;
|
|
pTimeStamp->lower = pAddr->end_pts_low;
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfReaderGetMuxRateBound(mem_ptr_t<CellPamfReader> pSelf)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetMuxRateBound(pSelf=0x%x)", pSelf.GetAddr());
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
return pAddr->mux_rate_max;
|
|
}
|
|
|
|
int cellPamfReaderGetNumberOfStreams(mem_ptr_t<CellPamfReader> pSelf)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetNumberOfStreams(pSelf=0x%x)", pSelf.GetAddr());
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
return pAddr->stream_count;
|
|
}
|
|
|
|
int cellPamfReaderGetNumberOfSpecificStreams(mem_ptr_t<CellPamfReader> pSelf, u8 streamType)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetNumberOfSpecificStreams(pSelf=0x%x, streamType=%d)",
|
|
pSelf.GetAddr(), streamType);
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
|
|
int counts[6] = {0, 0, 0, 0, 0, 0};
|
|
|
|
for (u8 i = 0; i < pAddr->stream_count; i++)
|
|
{
|
|
counts[pamfGetStreamType(pSelf, i)]++;
|
|
}
|
|
|
|
switch (streamType)
|
|
{
|
|
case CELL_PAMF_STREAM_TYPE_AVC:
|
|
case CELL_PAMF_STREAM_TYPE_M2V:
|
|
case CELL_PAMF_STREAM_TYPE_ATRAC3PLUS:
|
|
case CELL_PAMF_STREAM_TYPE_PAMF_LPCM:
|
|
case CELL_PAMF_STREAM_TYPE_AC3:
|
|
case CELL_PAMF_STREAM_TYPE_USER_DATA:
|
|
return counts[streamType];
|
|
case CELL_PAMF_STREAM_TYPE_VIDEO:
|
|
return counts[CELL_PAMF_STREAM_TYPE_AVC] + counts[CELL_PAMF_STREAM_TYPE_M2V];
|
|
case CELL_PAMF_STREAM_TYPE_AUDIO:
|
|
return counts[CELL_PAMF_STREAM_TYPE_ATRAC3PLUS] +
|
|
counts[CELL_PAMF_STREAM_TYPE_PAMF_LPCM] + counts[CELL_PAMF_STREAM_TYPE_AC3];
|
|
default:
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
int cellPamfReaderSetStreamWithIndex(mem_ptr_t<CellPamfReader> pSelf, u8 streamIndex)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderSetStreamWithIndex(pSelf=0x%x, streamIndex=%d)",
|
|
pSelf.GetAddr(), streamIndex);
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
|
|
if (streamIndex < pAddr->stream_count)
|
|
{
|
|
pSelf->stream = streamIndex;
|
|
return CELL_OK;
|
|
}
|
|
else
|
|
{
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
}
|
|
|
|
int cellPamfReaderSetStreamWithTypeAndChannel(mem_ptr_t<CellPamfReader> pSelf, u8 streamType, u8 ch)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderSetStreamWithTypeAndChannel(pSelf=0x%x, streamType=%d, ch=%d)",
|
|
pSelf.GetAddr(), streamType, ch);
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
|
|
if (streamType > 5)
|
|
{
|
|
cellPamf.Error("cellPamfReaderSetStreamWithTypeAndChannel: invalid stream type(%d)", streamType);
|
|
//it probably doesn't support "any audio" or "any video" argument
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
|
|
for (u8 i = 0; i < pAddr->stream_count; i++)
|
|
{
|
|
if (pamfGetStreamType(pSelf, i) == streamType)
|
|
{
|
|
if (pamfGetStreamChannel(pSelf, i) == ch)
|
|
{
|
|
pSelf->stream = i;
|
|
return i;
|
|
}
|
|
}
|
|
}
|
|
|
|
return CELL_PAMF_ERROR_STREAM_NOT_FOUND;
|
|
}
|
|
|
|
int cellPamfReaderSetStreamWithTypeAndIndex(mem_ptr_t<CellPamfReader> pSelf, u8 streamType, u8 streamIndex)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderSetStreamWithTypeAndIndex(pSelf=0x%x, streamType=%d, streamIndex=%d)",
|
|
pSelf.GetAddr(), streamType, streamIndex);
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
|
|
u32 found = 0;
|
|
|
|
for (u8 i = 0; i < pAddr->stream_count; i++)
|
|
{
|
|
const u8 type = pamfGetStreamType(pSelf, i);
|
|
|
|
if (type == streamType)
|
|
{
|
|
found++;
|
|
}
|
|
else switch(streamType)
|
|
{
|
|
case CELL_PAMF_STREAM_TYPE_VIDEO:
|
|
if (type == CELL_PAMF_STREAM_TYPE_AVC || type == CELL_PAMF_STREAM_TYPE_M2V)
|
|
{
|
|
found++;
|
|
}
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_AUDIO:
|
|
if (type == CELL_PAMF_STREAM_TYPE_ATRAC3PLUS || type == CELL_PAMF_STREAM_TYPE_AC3 || type == CELL_PAMF_STREAM_TYPE_PAMF_LPCM)
|
|
{
|
|
found++;
|
|
}
|
|
break;
|
|
default:
|
|
if (streamType > 5)
|
|
{
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
}
|
|
|
|
if (found > streamIndex)
|
|
{
|
|
pSelf->stream = i;
|
|
return i;
|
|
}
|
|
}
|
|
|
|
return CELL_PAMF_ERROR_STREAM_NOT_FOUND;
|
|
}
|
|
|
|
int cellPamfStreamTypeToEsFilterId(u8 type, u8 ch, mem_ptr_t<CellCodecEsFilterId> pEsFilterId)
|
|
{
|
|
cellPamf.Warning("cellPamfStreamTypeToEsFilterId(type=%d, ch=%d, pEsFilterId_addr=0x%x)",
|
|
type, ch, pEsFilterId.GetAddr());
|
|
|
|
return pamfStreamTypeToEsFilterId(type, ch, pEsFilterId);
|
|
}
|
|
|
|
int cellPamfReaderGetStreamIndex(mem_ptr_t<CellPamfReader> pSelf)
|
|
{
|
|
return pSelf->stream;
|
|
}
|
|
|
|
int cellPamfReaderGetStreamTypeAndChannel(mem_ptr_t<CellPamfReader> pSelf, mem8_t pType, mem8_t pCh)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetStreamTypeAndChannel(pSelf=0x%x (stream=%d), pType_addr=0x%x, pCh_addr=0x%x",
|
|
pSelf.GetAddr(), pSelf->stream, pType.GetAddr(), pCh.GetAddr());
|
|
|
|
pType = pamfGetStreamType(pSelf, pSelf->stream);
|
|
pCh = pamfGetStreamChannel(pSelf, pSelf->stream);
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfReaderGetEsFilterId(mem_ptr_t<CellPamfReader> pSelf, mem_ptr_t<CellCodecEsFilterId> pEsFilterId)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetEsFilterId(pSelf=0x%x (stream=%d), pEsFilterId_addr=0x%x)",
|
|
pSelf.GetAddr(), pSelf->stream, pEsFilterId.GetAddr());
|
|
|
|
return pamfStreamTypeToEsFilterId(pamfGetStreamType(pSelf, pSelf->stream),
|
|
pamfGetStreamChannel(pSelf, pSelf->stream), pEsFilterId);
|
|
}
|
|
|
|
int cellPamfReaderGetStreamInfo(mem_ptr_t<CellPamfReader> pSelf, u32 pInfo_addr, u32 size)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetStreamInfo(pSelf=0x%x (stream=%d), pInfo_addr=0x%x, size=%d)",
|
|
pSelf.GetAddr(), pSelf->stream, pInfo_addr, size);
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
|
|
memset(Memory + pInfo_addr, 0, size);
|
|
|
|
switch (pamfGetStreamType(pSelf, pSelf->stream))
|
|
{
|
|
case CELL_PAMF_STREAM_TYPE_AVC:
|
|
{
|
|
mem_ptr_t<CellPamfAvcInfo> pInfo(pInfo_addr);
|
|
mem_ptr_t<PamfStreamHeader_AVC> pAVC(pSelf->pAddr + 0x98 + pSelf->stream * 0x30);
|
|
|
|
if (size != sizeof(CellPamfAvcInfo))
|
|
{
|
|
cellPamf.Error("cellPamfReaderGetStreamInfo: wrong AVC data size(%d)", size);
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
|
|
pInfo->profileIdc = pAVC->profileIdc;
|
|
pInfo->levelIdc = pAVC->levelIdc;
|
|
|
|
pInfo->frameMbsOnlyFlag = 1; //fake
|
|
pInfo->frameRateInfo = (pAVC->unk0 & 0x7) - 1;
|
|
pInfo->aspectRatioIdc = 1; //fake
|
|
|
|
pInfo->horizontalSize = 16 * (u16)pAVC->horizontalSize;
|
|
pInfo->verticalSize = 16 * (u16)pAVC->verticalSize;
|
|
|
|
pInfo->videoSignalInfoFlag = 1; //fake
|
|
pInfo->colourPrimaries = 1; //fake
|
|
pInfo->transferCharacteristics = 1; //fake
|
|
pInfo->matrixCoefficients = 1; //fake
|
|
//pInfo->deblockingFilterFlag = 1; //???
|
|
|
|
cellPamf.Warning("cellPamfReaderGetStreamInfo: CELL_PAMF_STREAM_TYPE_AVC");
|
|
}
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_M2V:
|
|
{
|
|
//TODO
|
|
cellPamf.Error("TODO: cellPamfReaderGetStreamInfo: CELL_PAMF_STREAM_TYPE_M2V");
|
|
}
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_ATRAC3PLUS:
|
|
{
|
|
mem_ptr_t<CellPamfAtrac3plusInfo> pInfo(pInfo_addr);
|
|
mem_ptr_t<PamfStreamHeader_Audio> pAudio(pSelf->pAddr + 0x98 + pSelf->stream * 0x30);
|
|
|
|
if (size != sizeof(CellPamfAtrac3plusInfo))
|
|
{
|
|
cellPamf.Error("cellPamfReaderGetStreamInfo: wrong ATRAC3+ data size(%d)", size);
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
|
|
pInfo->numberOfChannels = pAudio->channels;
|
|
pInfo->samplingFrequency = CELL_PAMF_FS_48kHz;
|
|
}
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_AC3:
|
|
{
|
|
mem_ptr_t<CellPamfAc3Info> pInfo(pInfo_addr);
|
|
mem_ptr_t<PamfStreamHeader_Audio> pAudio(pSelf->pAddr + 0x98 + pSelf->stream * 0x30);
|
|
|
|
if (size != sizeof(CellPamfAc3Info))
|
|
{
|
|
cellPamf.Error("cellPamfReaderGetStreamInfo: wrong AC3 data size(%d)", size);
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
|
|
pInfo->numberOfChannels = pAudio->channels;
|
|
pInfo->samplingFrequency = CELL_PAMF_FS_48kHz;
|
|
}
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_PAMF_LPCM:
|
|
{
|
|
mem_ptr_t<CellPamfLpcmInfo> pInfo(pInfo_addr);
|
|
mem_ptr_t<PamfStreamHeader_Audio> pAudio(pSelf->pAddr + 0x98 + pSelf->stream * 0x30);
|
|
|
|
if (size != sizeof(CellPamfLpcmInfo))
|
|
{
|
|
cellPamf.Error("cellPamfReaderGetStreamInfo: wrong LPCM data size(%d)", size);
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
|
|
pInfo->numberOfChannels = pAudio->channels;
|
|
pInfo->samplingFrequency = CELL_PAMF_FS_48kHz;
|
|
|
|
if (pAudio->bps = 0x40)
|
|
pInfo->bitsPerSample = CELL_PAMF_BIT_LENGTH_16;
|
|
else
|
|
//TODO: CELL_PAMF_BIT_LENGTH_24
|
|
cellPamf.Error("cellPamfReaderGetStreamInfo: unknown bps(0x%x)", (u8)pAudio->bps);
|
|
}
|
|
break;
|
|
case CELL_PAMF_STREAM_TYPE_USER_DATA:
|
|
{
|
|
cellPamf.Error("cellPamfReaderGetStreamInfo: CELL_PAMF_STREAM_TYPE_USER_DATA");
|
|
return CELL_PAMF_ERROR_INVALID_ARG;
|
|
}
|
|
}
|
|
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfReaderGetNumberOfEp(mem_ptr_t<CellPamfReader> pSelf)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetNumberOfEp(pSelf=0x%x (stream=%d))",
|
|
pSelf.GetAddr(), pSelf->stream);
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
return pAddr->stream_headers[pSelf->stream].ep_num;
|
|
}
|
|
|
|
int cellPamfReaderGetEpIteratorWithIndex(mem_ptr_t<CellPamfReader> pSelf, u32 epIndex, mem_ptr_t<CellPamfEpIterator> pIt)
|
|
{
|
|
cellPamf.Warning("cellPamfReaderGetEpIteratorWithIndex(pSelf=0x%x (stream=%d), epIndex=%d, pIt_addr=0x%x)",
|
|
pSelf.GetAddr(), pSelf->stream, epIndex, pIt.GetAddr());
|
|
|
|
const mem_ptr_t<PamfHeader> pAddr(pSelf->pAddr);
|
|
//TODO:
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfReaderGetEpIteratorWithTimeStamp(mem_ptr_t<CellPamfReader> pSelf, mem_ptr_t<CellCodecTimeStamp> pTimeStamp, mem_ptr_t<CellPamfEpIterator> pIt)
|
|
{
|
|
UNIMPLEMENTED_FUNC(cellPamf);
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfEpIteratorGetEp(mem_ptr_t<CellPamfEpIterator> pIt, mem_ptr_t<CellPamfEp> pEp)
|
|
{
|
|
UNIMPLEMENTED_FUNC(cellPamf);
|
|
return CELL_OK;
|
|
}
|
|
|
|
int cellPamfEpIteratorMove(mem_ptr_t<CellPamfEpIterator> pIt, int steps, mem_ptr_t<CellPamfEp> pEp)
|
|
{
|
|
UNIMPLEMENTED_FUNC(cellPamf);
|
|
return CELL_OK;
|
|
}
|
|
|
|
void cellPamf_init()
|
|
{
|
|
cellPamf.AddFunc(0xca8181c1, cellPamfGetHeaderSize);
|
|
cellPamf.AddFunc(0x90fc9a59, cellPamfGetHeaderSize2);
|
|
cellPamf.AddFunc(0x44f5c9e3, cellPamfGetStreamOffsetAndSize);
|
|
cellPamf.AddFunc(0xd1a40ef4, cellPamfVerify);
|
|
cellPamf.AddFunc(0xb8436ee5, cellPamfReaderInitialize);
|
|
cellPamf.AddFunc(0x4de501b1, cellPamfReaderGetPresentationStartTime);
|
|
cellPamf.AddFunc(0xf61609d6, cellPamfReaderGetPresentationEndTime);
|
|
cellPamf.AddFunc(0xdb70296c, cellPamfReaderGetMuxRateBound);
|
|
cellPamf.AddFunc(0x37f723f7, cellPamfReaderGetNumberOfStreams);
|
|
cellPamf.AddFunc(0xd0230671, cellPamfReaderGetNumberOfSpecificStreams);
|
|
cellPamf.AddFunc(0x461534b4, cellPamfReaderSetStreamWithIndex);
|
|
cellPamf.AddFunc(0x03fd2caa, cellPamfReaderSetStreamWithTypeAndChannel);
|
|
cellPamf.AddFunc(0x28b4e2c1, cellPamfReaderSetStreamWithTypeAndIndex);
|
|
cellPamf.AddFunc(0x01067e22, cellPamfStreamTypeToEsFilterId);
|
|
cellPamf.AddFunc(0x041cc708, cellPamfReaderGetStreamIndex);
|
|
cellPamf.AddFunc(0x9ab20793, cellPamfReaderGetStreamTypeAndChannel);
|
|
cellPamf.AddFunc(0x71df326a, cellPamfReaderGetEsFilterId);
|
|
cellPamf.AddFunc(0x67fd273b, cellPamfReaderGetStreamInfo);
|
|
cellPamf.AddFunc(0xd9ea3457, cellPamfReaderGetNumberOfEp);
|
|
cellPamf.AddFunc(0xe8586ec6, cellPamfReaderGetEpIteratorWithIndex);
|
|
cellPamf.AddFunc(0x439fba17, cellPamfReaderGetEpIteratorWithTimeStamp);
|
|
cellPamf.AddFunc(0x1abeb9d6, cellPamfEpIteratorGetEp);
|
|
cellPamf.AddFunc(0x50b83205, cellPamfEpIteratorMove);
|
|
} |