mirror of
https://github.com/switchbrew/libnx.git
synced 2025-07-04 10:32:15 +02:00
Compare commits
5 Commits
99edb1c0f0
...
919e3d3938
Author | SHA1 | Date | |
---|---|---|---|
|
919e3d3938 | ||
|
b615b01d44 | ||
|
be45a91b9c | ||
|
827c6b6ddf | ||
|
ce1f87050d |
@ -161,6 +161,11 @@ typedef struct {
|
|||||||
u32 iova;
|
u32 iova;
|
||||||
} nvioctl_command_buffer_map;
|
} nvioctl_command_buffer_map;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
u32 rate;
|
||||||
|
u32 moduleid;
|
||||||
|
} nvioctl_clk_rate;
|
||||||
|
|
||||||
#define NVGPU_ZBC_TYPE_INVALID 0
|
#define NVGPU_ZBC_TYPE_INVALID 0
|
||||||
#define NVGPU_ZBC_TYPE_COLOR 1
|
#define NVGPU_ZBC_TYPE_COLOR 1
|
||||||
#define NVGPU_ZBC_TYPE_DEPTH 2
|
#define NVGPU_ZBC_TYPE_DEPTH 2
|
||||||
@ -284,5 +289,7 @@ Result nvioctlChannel_Submit(u32 fd, const nvioctl_cmdbuf *cmdbufs, u32 num_cmdb
|
|||||||
const nvioctl_syncpt_incr *syncpt_incrs, u32 num_syncpt_incrs, nvioctl_fence *fences, u32 num_fences);
|
const nvioctl_syncpt_incr *syncpt_incrs, u32 num_syncpt_incrs, nvioctl_fence *fences, u32 num_fences);
|
||||||
Result nvioctlChannel_GetSyncpt(u32 fd, u32 module_id, u32 *syncpt);
|
Result nvioctlChannel_GetSyncpt(u32 fd, u32 module_id, u32 *syncpt);
|
||||||
Result nvioctlChannel_GetModuleClockRate(u32 fd, u32 module_id, u32 *freq);
|
Result nvioctlChannel_GetModuleClockRate(u32 fd, u32 module_id, u32 *freq);
|
||||||
|
Result nvioctlChannel_SetModuleClockRate(u32 fd, u32 module_id, u32 freq);
|
||||||
Result nvioctlChannel_MapCommandBuffer(u32 fd, nvioctl_command_buffer_map *maps, u32 num_maps, bool compressed);
|
Result nvioctlChannel_MapCommandBuffer(u32 fd, nvioctl_command_buffer_map *maps, u32 num_maps, bool compressed);
|
||||||
Result nvioctlChannel_UnmapCommandBuffer(u32 fd, const nvioctl_command_buffer_map *maps, u32 num_maps, bool compressed);
|
Result nvioctlChannel_UnmapCommandBuffer(u32 fd, const nvioctl_command_buffer_map *maps, u32 num_maps, bool compressed);
|
||||||
|
Result nvioctlChannel_SetSubmitTimeout(u32 fd, u32 timeout);
|
||||||
|
@ -650,7 +650,9 @@ Result fsDeviceOperatorIsGameCardInserted(FsDeviceOperator* d, bool* out);
|
|||||||
Result fsDeviceOperatorGetGameCardHandle(FsDeviceOperator* d, FsGameCardHandle* out);
|
Result fsDeviceOperatorGetGameCardHandle(FsDeviceOperator* d, FsGameCardHandle* out);
|
||||||
Result fsDeviceOperatorGetGameCardUpdatePartitionInfo(FsDeviceOperator* d, const FsGameCardHandle* handle, FsGameCardUpdatePartitionInfo* out);
|
Result fsDeviceOperatorGetGameCardUpdatePartitionInfo(FsDeviceOperator* d, const FsGameCardHandle* handle, FsGameCardUpdatePartitionInfo* out);
|
||||||
Result fsDeviceOperatorGetGameCardAttribute(FsDeviceOperator* d, const FsGameCardHandle* handle, u8 *out);
|
Result fsDeviceOperatorGetGameCardAttribute(FsDeviceOperator* d, const FsGameCardHandle* handle, u8 *out);
|
||||||
|
Result fsDeviceOperatorGetGameCardDeviceCertificate(FsDeviceOperator* d, const FsGameCardHandle* handle, void* dst, size_t dst_size, s64 size);
|
||||||
Result fsDeviceOperatorGetGameCardIdSet(FsDeviceOperator* d, void* dst, size_t dst_size, s64 size);
|
Result fsDeviceOperatorGetGameCardIdSet(FsDeviceOperator* d, void* dst, size_t dst_size, s64 size);
|
||||||
Result fsDeviceOperatorGetGameCardErrorReportInfo(FsDeviceOperator* d, FsGameCardErrorReportInfo* out);
|
Result fsDeviceOperatorGetGameCardErrorReportInfo(FsDeviceOperator* d, FsGameCardErrorReportInfo* out);
|
||||||
Result fsDeviceOperatorGetGameCardDeviceId(FsDeviceOperator* d, void* dst, size_t dst_size, s64 size);
|
Result fsDeviceOperatorGetGameCardDeviceId(FsDeviceOperator* d, void* dst, size_t dst_size, s64 size);
|
||||||
|
Result fsDeviceOperatorChallengeCardExistence(FsDeviceOperator* d, const FsGameCardHandle* handle, void* dst, size_t dst_size, void* seed, size_t seed_size, void* value, size_t value_size);
|
||||||
void fsDeviceOperatorClose(FsDeviceOperator* d);
|
void fsDeviceOperatorClose(FsDeviceOperator* d);
|
||||||
|
@ -31,7 +31,7 @@ typedef enum {
|
|||||||
SetSysProductModel_Iowa = 3, ///< Mariko Model
|
SetSysProductModel_Iowa = 3, ///< Mariko Model
|
||||||
SetSysProductModel_Hoag = 4, ///< Mariko Lite Model
|
SetSysProductModel_Hoag = 4, ///< Mariko Lite Model
|
||||||
SetSysProductModel_Calcio = 5, ///< Mariko "Simulation" Model
|
SetSysProductModel_Calcio = 5, ///< Mariko "Simulation" Model
|
||||||
SetSysProductModel_Aula = 6, ///< Mariko Pro Model(?)
|
SetSysProductModel_Aula = 6, ///< Mariko OLED Model
|
||||||
} SetSysProductModel;
|
} SetSysProductModel;
|
||||||
|
|
||||||
/// IDs for Language.
|
/// IDs for Language.
|
||||||
|
@ -254,15 +254,12 @@ Result nvioctlChannel_GetSyncpt(u32 fd, u32 id, u32 *syncpt) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Result nvioctlChannel_GetModuleClockRate(u32 fd, u32 module_id, u32 *freq) {
|
Result nvioctlChannel_GetModuleClockRate(u32 fd, u32 module_id, u32 *freq) {
|
||||||
struct {
|
nvioctl_clk_rate data = {
|
||||||
__nv_out u32 rate;
|
.moduleid = module_id,
|
||||||
__nv_in u32 module;
|
|
||||||
} data = {
|
|
||||||
.module = module_id,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
u32 ioctl = _NV_IOWR(0, hosversionAtLeast(8,0,0) ? 0x14 : 0x23, data);
|
u32 nr = _NV_IOWR(0, hosversionBefore(8,0,0) ? 0x14 : 0x23, data);
|
||||||
Result rc = nvIoctl(fd, ioctl, &data);
|
Result rc = nvIoctl(fd, nr, &data);
|
||||||
|
|
||||||
if (R_SUCCEEDED(rc) && freq)
|
if (R_SUCCEEDED(rc) && freq)
|
||||||
*freq = data.rate;
|
*freq = data.rate;
|
||||||
@ -270,6 +267,25 @@ Result nvioctlChannel_GetModuleClockRate(u32 fd, u32 module_id, u32 *freq) {
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result nvioctlChannel_SetModuleClockRate(u32 fd, u32 module_id, u32 freq) {
|
||||||
|
nvioctl_clk_rate data = {
|
||||||
|
.rate = freq,
|
||||||
|
.moduleid = module_id,
|
||||||
|
};
|
||||||
|
|
||||||
|
return nvIoctl(fd, _NV_IOW(0, 0x08, data), &data);
|
||||||
|
}
|
||||||
|
|
||||||
|
Result nvioctlChannel_SetSubmitTimeout(u32 fd, u32 timeout) {
|
||||||
|
struct {
|
||||||
|
__nv_in u32 timeout;
|
||||||
|
} data = {
|
||||||
|
.timeout = timeout,
|
||||||
|
};
|
||||||
|
|
||||||
|
return nvIoctl(fd, _NV_IOW(0, 0x07, data), &data);
|
||||||
|
}
|
||||||
|
|
||||||
Result nvioctlChannel_MapCommandBuffer(u32 fd, nvioctl_command_buffer_map *maps, u32 num_maps, bool compressed) {
|
Result nvioctlChannel_MapCommandBuffer(u32 fd, nvioctl_command_buffer_map *maps, u32 num_maps, bool compressed) {
|
||||||
if (num_maps > 0x200)
|
if (num_maps > 0x200)
|
||||||
return MAKERESULT(Module_Libnx, LibnxError_OutOfMemory);
|
return MAKERESULT(Module_Libnx, LibnxError_OutOfMemory);
|
||||||
|
@ -1226,6 +1226,17 @@ Result fsDeviceOperatorGetGameCardAttribute(FsDeviceOperator* d, const FsGameCar
|
|||||||
return _fsObjectDispatchInOut(&d->s, 205, *handle, *out);
|
return _fsObjectDispatchInOut(&d->s, 205, *handle, *out);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result fsDeviceOperatorGetGameCardDeviceCertificate(FsDeviceOperator* d, const FsGameCardHandle* handle, void* dst, size_t dst_size, s64 size) {
|
||||||
|
const struct {
|
||||||
|
FsGameCardHandle handle;
|
||||||
|
s64 buffer_size;
|
||||||
|
} in = { *handle, size };
|
||||||
|
|
||||||
|
return _fsObjectDispatchIn(&d->s, 206, in,
|
||||||
|
.buffer_attrs = { SfBufferAttr_HipcMapAlias | SfBufferAttr_Out },
|
||||||
|
.buffers = { { dst, dst_size } });
|
||||||
|
}
|
||||||
|
|
||||||
Result fsDeviceOperatorGetGameCardIdSet(FsDeviceOperator* d, void* dst, size_t dst_size, s64 size) {
|
Result fsDeviceOperatorGetGameCardIdSet(FsDeviceOperator* d, void* dst, size_t dst_size, s64 size) {
|
||||||
return _fsCmdInSizeOutBuffer(&d->s, dst, dst_size, size, 208);
|
return _fsCmdInSizeOutBuffer(&d->s, dst, dst_size, size, 208);
|
||||||
}
|
}
|
||||||
@ -1242,6 +1253,24 @@ Result fsDeviceOperatorGetGameCardDeviceId(FsDeviceOperator* d, void* dst, size_
|
|||||||
return _fsCmdInSizeOutBuffer(&d->s, dst, dst_size, size, 218);
|
return _fsCmdInSizeOutBuffer(&d->s, dst, dst_size, size, 218);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result fsDeviceOperatorChallengeCardExistence(FsDeviceOperator* d, const FsGameCardHandle* handle, void* dst, size_t dst_size, void* seed, size_t seed_size, void* value, size_t value_size) {
|
||||||
|
if (hosversionBefore(8,0,0))
|
||||||
|
return MAKERESULT(Module_Libnx, LibnxError_IncompatSysVer);
|
||||||
|
|
||||||
|
return _fsObjectDispatchIn(&d->s, 219, *handle,
|
||||||
|
.buffer_attrs = {
|
||||||
|
SfBufferAttr_HipcMapAlias | SfBufferAttr_Out,
|
||||||
|
SfBufferAttr_HipcMapAlias | SfBufferAttr_In,
|
||||||
|
SfBufferAttr_HipcMapAlias | SfBufferAttr_In,
|
||||||
|
},
|
||||||
|
.buffers = {
|
||||||
|
{ dst, dst_size },
|
||||||
|
{ seed, seed_size },
|
||||||
|
{ value, value_size },
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
void fsDeviceOperatorClose(FsDeviceOperator* d) {
|
void fsDeviceOperatorClose(FsDeviceOperator* d) {
|
||||||
_fsObjectClose(&d->s);
|
_fsObjectClose(&d->s);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user