Line 18: |
Line 18: |
| | 5 || GetBoardPowerControlEvent | | | 5 || GetBoardPowerControlEvent |
| |- | | |- |
− | | 6 || GetSleepButtonState | + | | 6 || [2.0.0+] GetSleepButtonState |
| |- | | |- |
− | | 7 || GetPowerEvent | + | | 7 || [2.0.0+] GetPowerEvent |
| |- | | |- |
− | | 8 || | + | | 8 || [2.0.0-9.2.0] CreateWakeupTimer |
| |- | | |- |
− | | 9 || | + | | 9 || [2.0.0-9.2.0] CancelWakeupTimer |
| |- | | |- |
− | | 10 || | + | | 10 || [2.0.0-9.2.0] [[#EnableWakeupTimerOnDevice]] |
| + | |- |
| + | | 11 || [3.0.0-9.2.0] CreateWakeupTimerEx |
| + | |- |
| + | | 12 || [3.0.0-9.2.0] GetLastEnabledWakeupTimerType |
| + | |- |
| + | | 13 || [3.0.0-9.2.0] CleanAllWakeupTimers |
| + | |- |
| + | | 14 || [6.0.0+] |
| + | |- |
| + | | 15 || [10.0.0+] |
| |} | | |} |
| + | |
| + | == EnableWakeupTimerOnDevice == |
| + | No input, returns a total of 0x10-bytes of output. [3.0.0+] Now returns a total of 0xC-bytes of output. |
| | | |
| = bpc:r = | | = bpc:r = |
Line 36: |
Line 49: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || GetExternalRtcValue | + | | 0 || GetRtcTime |
| + | |- |
| + | | 1 || SetRtcTime |
| + | |- |
| + | | 2 || GetRtcResetDetected |
| + | |- |
| + | | 3 || [2.0.0+] ClearRtcResetDetected |
| + | |- |
| + | | 4 || [3.0.0+] SetUpRtcResetOnShutdown |
| + | |} |
| + | |
| + | = bpc:c = |
| + | This is "nn::bpc::IBoardPowerControlManager". |
| + | |
| + | [2.0.0+] This service was replaced by [[#bpc|bpc]]. |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || ShutdownSystem |
| + | |- |
| + | | 1 || RebootSystem |
| + | |- |
| + | | 2 || GetWakeupReason |
| + | |- |
| + | | 3 || GetShutdownReason |
| + | |- |
| + | | 4 || GetAcOk |
| + | |- |
| + | | 5 || GetBoardPowerControlEvent |
| + | |} |
| + | |
| + | = bpc:b = |
| + | This is "nn::bpc::IPowerButtonManager". |
| + | |
| + | [2.0.0+] This service was merged into [[#bpc|bpc]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 1 || SetExternalRtcValue | + | ! Cmd || Name |
| |- | | |- |
− | | 2 || ReadExternalRtcResetFlag | + | | 0 || GetSleepButtonState |
| |- | | |- |
− | | 3 || ClearExternalRtcResetFlag | + | | 1 || GetPowerEvent |
| |} | | |} |
| | | |
− | GetExternalRtcValue / SetExternalRtcValue directly accesses the max77620_rtc0 device.
| + | = bpc:w = |
| + | This is "nn::bpc::IWakeupConfigManager". |
| + | |
| + | [2.0.0+] This service was merged into [[#bpc|bpc]]. |
| + | |
| + | {| class="wikitable" border="1" |
| + | |- |
| + | ! Cmd || Name |
| + | |- |
| + | | 0 || CreateWakeupTimer |
| + | |- |
| + | | 1 || CancelWakeupTimer |
| + | |- |
| + | | 2 || [[#EnableWakeupTimerOnDevice]] |
| + | |} |
| | | |
| = pcv = | | = pcv = |
Line 54: |
Line 119: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || SetPowerEnabled | + | | [1.0.0-7.0.1] 0 || SetPowerEnabled |
| |- | | |- |
− | | 1 || SetClockEnabled | + | | [1.0.0-7.0.1] 1 || SetClockEnabled |
| |- | | |- |
− | | 2 || SetClockRate | + | | [1.0.0-7.0.1] 2 || SetClockRate |
| |- | | |- |
− | | 3 || GetClockRate | + | | [1.0.0-7.0.1] 3 || GetClockRate |
| |- | | |- |
− | | 4 || GetState | + | | [1.0.0-7.0.1] 4 || GetState |
| |- | | |- |
− | | 5 || GetPossibleClockRates | + | | [1.0.0-7.0.1] 5 || GetPossibleClockRates |
| |- | | |- |
− | | 6 || SetMinVClockRate | + | | [1.0.0-7.0.1] 6 || SetMinVClockRate |
| |- | | |- |
− | | 7 || SetReset | + | | [1.0.0-7.0.1] 7 || SetReset |
| |- | | |- |
− | | 8 || SetVoltageEnabled | + | | [1.0.0-7.0.1] 8 || SetVoltageEnabled |
| |- | | |- |
− | | 9 || GetVoltageEnabled | + | | [1.0.0-7.0.1] 9 || GetVoltageEnabled |
| |- | | |- |
− | | 10 || GetVoltageRange | + | | [1.0.0-7.0.1] 10 || GetVoltageRange |
| |- | | |- |
− | | 11 || SetVoltageValue | + | | [1.0.0-7.0.1] 11 || SetVoltageValue |
| |- | | |- |
− | | 12 || GetVoltageValue | + | | [1.0.0-7.0.1] 12 || GetVoltageValue |
| |- | | |- |
− | | 13 || GetTemperatureThresholds | + | | [1.0.0-7.0.1] 13 || GetTemperatureThresholds |
| |- | | |- |
− | | 14 || SetTemperature | + | | [1.0.0-7.0.1] 14 || SetTemperature |
| |- | | |- |
− | | 15 || Initialize | + | | [1.0.0-5.1.0] 15 || Initialize |
| |- | | |- |
− | | 16 || IsInitialized | + | | [1.0.0-5.1.0] 16 || IsInitialized |
| |- | | |- |
− | | 17 || Finalize | + | | [1.0.0-5.1.0] 17 || Finalize |
| |- | | |- |
− | | 18 || PowerOn | + | | [3.0.0-7.0.1] 18 || PowerOn |
| |- | | |- |
− | | 19 || PowerOff | + | | [3.0.0-7.0.1] 19 || PowerOff |
| |- | | |- |
− | | 20 || ChangeVoltage | + | | [3.0.0-7.0.1] 20 || ChangeVoltage |
| |- | | |- |
− | | 21 || GetPowerClockInfoEvent | + | | [3.0.0-7.0.1] 21 || GetPowerClockInfoEvent |
| |- | | |- |
− | | 22 || GetOscillatorClock | + | | [3.0.0-7.0.1] 22 || GetOscillatorClock |
| |- | | |- |
− | | 23 || GetDvfsTable | + | | [3.0.0-7.0.1] 23 || GetDvfsTable |
| |- | | |- |
− | | 24 || GetModuleStateTable | + | | [3.0.0-7.0.1] 24 || GetModuleStateTable |
| |- | | |- |
− | | 25 || GetPowerDomainStateTable | + | | [3.0.0-7.0.1] 25 || GetPowerDomainStateTable |
| |- | | |- |
− | | 26 || GetFuseInfo | + | | 26 || [3.0.0+] GetFuseInfo |
| |- | | |- |
| + | | 27 || [5.0.0+] GetDramId |
| + | |- |
| + | | [6.0.0-7.0.1] 28 || [[#IsPoweredOn]] |
| + | |- |
| + | | [6.0.0-7.0.1] 29 || [[#GetVoltage]] |
| |} | | |} |
| | | |
− | == User Name to Block Maps == | + | [7.0.0+] The type-0xA output buffers were replaced with type-0x22 output buffers, for the following: GetDvfsTable, GetModuleStateTable, and GetPowerDomainStateTable. |
| + | |
| + | == IsPoweredOn == |
| + | Takes a [[#PowerDomain|PowerDomain]] and returns a bool indicating the status of the requested voltage block. |
| + | |
| + | == GetVoltage == |
| + | Takes a [[#PowerDomain|PowerDomain]] and returns an u32 voltage value for the requested voltage block. |
| + | |
| + | = pcv:arb = |
| + | This is "nn::pcv::IArbitrationManager". |
| | | |
− | === Power Switch / Clocking / Reset ===
| + | This service no longer exists in [8.0.0+]. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Name || Block || Rail || Notes | + | ! Cmd || Name |
| |- | | |- |
− | | 0 || CpuBus || vdd_cpu || | + | | 0 || ReleaseControl |
| + | |} |
| + | |
| + | = pcv:imm = |
| + | This is "nn::pcv::IImmediateManager". |
| + | |
| + | This service no longer exists in [8.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 1 || GPU || vdd_gpu ||
| + | ! Cmd || Name |
| |- | | |- |
− | | 2 || I2S1 || vdd_soc || | + | | 0 || SetClockRate |
| + | |} |
| + | |
| + | = clkrst, clkrst:i = |
| + | These are "nn::clkrst::IClkrstManager" and "nn::clkrst::IImmediateManager". |
| + | |
| + | These were added with [8.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 3 || I2S2 || vdd_soc ||
| + | ! Cmd || Name |
| |- | | |- |
− | | 4 || I2S3 || vdd_soc || | + | | 0 || [[#OpenSession]] |
| |- | | |- |
− | | 5 || PWM || vdd_soc || | + | | 1 || GetTemperatureThresholds |
| |- | | |- |
− | | 6 || I2C1 || vdd_soc || | + | | 2 || SetTemperature |
| |- | | |- |
− | | 7 || I2C2 || vdd_soc || | + | | 3 || GetPossibleClockRates |
| |- | | |- |
− | | 8 || I2C3 || vdd_soc || | + | | 4 || GetClockInfoEvent |
| |- | | |- |
− | | 9 || I2C4 || vdd_soc || | + | | 5 || GetClockModuleNumLimit |
| + | |} |
| + | |
| + | == OpenSession == |
| + | Takes a [[#Module|DeviceCode]] and an u32. Returns an [[#IClkrstSession]]. |
| + | |
| + | == GetClockModuleNumLimit == |
| + | Returns 0x1A. |
| + | |
| + | == IClkrstSession == |
| + | This is "nn::clkrst::IClkrstSession". |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 10 || I2C5 || vdd_soc ||
| + | ! Cmd || Name |
| |- | | |- |
− | | 11 || I2C6 || vdd_soc || | + | | 0 || SetClockEnabled |
| |- | | |- |
− | | 12 || SPI1 || vdd_soc || | + | | 1 || SetClockDisabled |
| |- | | |- |
− | | 13 || SPI2 || vdd_soc || | + | | 2 || SetResetAsserted |
| |- | | |- |
− | | 14 || SPI3 || vdd_soc || | + | | 3 || SetResetDeasserted |
| |- | | |- |
− | | 15 || SPI4 || vdd_soc || | + | | 4 || SetPowerEnabled |
| |- | | |- |
− | | 16 || DISP1 || vdd_soc || | + | | 5 || SetPowerDisabled |
| |- | | |- |
− | | 17 || DISP2 || vdd_soc || | + | | 6 || GetState |
| |- | | |- |
− | | 20 || SDMMC1 || vdd_soc || | + | | 7 || SetClockRate |
| |- | | |- |
− | | 21 || SDMMC2 || vdd_soc || | + | | 8 || GetClockRate |
| |- | | |- |
− | | 22 || SDMMC3 || vdd_soc || | + | | 9 || SetMinVClockRate |
| |- | | |- |
− | | 23 || SDMMC4 || vdd_soc || | + | | 10 || GetPossibleClockRates |
| |- | | |- |
− | | 24 || - || - || Not actual block. Used for debug and stuff. | + | | 11 || GetDvfsTable |
| + | |} |
| + | |
| + | = clkrst:a = |
| + | This is "nn::clkrst::IArbitrationManager". |
| + | |
| + | This was added with [8.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 25 || CSITE || vdd_soc ||
| + | ! Cmd || Name |
| |- | | |- |
− | | 26 || TSEC || vdd_soc || | + | | 0 || [[#ReleaseControl]] |
| + | |} |
| + | |
| + | == ReleaseControl == |
| + | Takes a [[#Module|Module]]. No output. |
| + | |
| + | = rgltr = |
| + | This is "nn::regulator::IRegulatorManager". |
| + | |
| + | This was added with [8.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 27 || MSELECT || vdd_soc ||
| + | ! Cmd || Name |
| |- | | |- |
− | | 28 || HDA2CODEC_2X || vdd_soc || | + | | 0 || [[#OpenSession]] |
| |- | | |- |
− | | 29 || ACTMON || vdd_soc || | + | | 1 || GetPowerDomainStateTable |
| |- | | |- |
− | | 30 || I2C_SLOW || vdd_soc || | + | | 2 || GetPowerInfoEvent |
| |- | | |- |
− | | 31 || SOR1 || vdd_soc || | + | | 3 || GetPowerModuleNumLimit |
| + | |} |
| + | |
| + | == OpenSession == |
| + | Takes a [[#PowerDomain|DeviceCode]] and returns an [[#IRegulatorSession]]. |
| + | |
| + | == GetPowerModuleNumLimit == |
| + | Returns 0x3. |
| + | |
| + | == IRegulatorSession == |
| + | This is "nn::regulator::IRegulatorSession". |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 33 || HDA || vdd_soc ||
| + | ! Cmd || Name |
| |- | | |- |
− | | 34 || XUSB_CORE_HOST || vdd_soc || | + | | 0 || [[#SetVoltageEnabled]] |
| |- | | |- |
− | | 35 || XUSB_FALCON || vdd_soc || | + | | 1 || |
| |- | | |- |
− | | 36 || XUSB_FS || vdd_soc || | + | | 2 || [[#GetVoltageEnabled]] |
| |- | | |- |
− | | 37 || XUSB_CORE_DEV || vdd_soc || | + | | 3 || GetVoltageRange |
| |- | | |- |
− | | 38 || XUSB_SS_HOSTDEV || vdd_soc || | + | | 4 || GetVoltageValue |
| |- | | |- |
− | | 39 || UARTA || vdd_soc || | + | | 5 || [[#SetVoltageValue]] |
| |- | | |- |
− | | 40 || UARTB || vdd_soc || | + | | 6 || ChangeVoltage |
| + | |} |
| + | |
| + | === SetVoltageEnabled === |
| + | Takes a bool. Enables/disables the LDO this session was opened for. |
| + | |
| + | === GetVoltageEnabled === |
| + | Returns a bool. True if voltage is enabled, false if not. |
| + | |
| + | === SetVoltageValue === |
| + | Takes in a voltage in microvolts and sets the LDO to this voltage. |
| + | |
| + | = rtc = |
| + | This was added with [8.0.0+]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 41 || UARTC || vdd_soc ||
| + | ! Cmd || Name |
| |- | | |- |
− | | 42 || UARTD || vdd_soc || | + | | 0 || [[#GetRtcTime]] |
| |- | | |- |
− | | 43 || HOST1X || vdd_soc || | + | | 1 || [[#SetRtcTime]] |
| |- | | |- |
− | | 44 || ENTROPY || vdd_soc || | + | | 2 || [[#SetUpRtcResetOnShutdown]] |
| |- | | |- |
− | | 45 || SOC_THERM || vdd_soc || | + | | 3 || [[#GetRtcResetDetected]] |
| |- | | |- |
− | | 46 || VIC || vdd_soc || | + | | 4 || [[#ClearRtcResetDetected]] |
| + | |} |
| + | |
| + | == GetRtcTime == |
| + | Same as GetRtcTime from [[#bpc:r|bpc:r]], but takes an extra [[Bus_services#I2cDevice|DeviceCode]], which [[#bpc:r|bpc:r]] hardcodes to 0x3B000001 (max77620_rtc0) instead. |
| + | |
| + | == SetRtcTime == |
| + | Same as SetRtcTime from [[#bpc:r|bpc:r]], but takes an extra [[Bus_services#I2cDevice|DeviceCode]], which [[#bpc:r|bpc:r]] hardcodes to 0x3B000001 (max77620_rtc0) instead. |
| + | |
| + | == SetUpRtcResetOnShutdown == |
| + | Takes an u8 '''DoReset''' and a [[Bus_services#I2cDevice|DeviceCode]]. Similar to SetUpRtcResetOnShutdown from [[#bpc:r|bpc:r]], but this version assigns the provided boolean value on a per-client basis (instead of a global variable) and checks it when the current [[PSC_services#Power_Management_States|power state]] is "ReadyShutdown". |
| + | |
| + | == GetRtcResetDetected == |
| + | Same as GetRtcResetDetected from [[#bpc:r|bpc:r]], but takes an extra [[Bus_services#I2cDevice|DeviceCode]], which [[#bpc:r|bpc:r]] hardcodes to 0x3B000001 (max77620_rtc0) instead. |
| + | |
| + | == ClearRtcResetDetected == |
| + | Same as ClearRtcResetDetected from [[#bpc:r|bpc:r]], but takes an extra [[Bus_services#I2cDevice|DeviceCode]], which [[#bpc:r|bpc:r]] hardcodes to 0x3B000001 (max77620_rtc0) instead. |
| + | |
| + | = time:u, time:a, time:s = |
| + | This is "nn::timesrv::detail::service::IStaticService". |
| + | |
| + | [9.0.0+] These services were moved to [[Glue_services|Glue]] and [[PSC_services|PSC]]. |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 47 || NVENC || vdd_soc || | + | ! Cmd || Name || Notes |
| |- | | |- |
− | | 48 || NVJPG || vdd_soc || | + | | 0 || GetStandardUserSystemClock || Returns an [[#ISystemClock]]. |
| |- | | |- |
− | | 49 || NVDEC || vdd_soc || | + | | 1 || GetStandardNetworkSystemClock || Returns an [[#ISystemClock]]. |
| |- | | |- |
− | | 50 || QSPI || vdd_soc || | + | | 2 || GetStandardSteadyClock || Returns an [[#ISteadyClock]]. |
| |- | | |- |
− | | 52 || TSECB || vdd_soc || | + | | 3 || GetTimeZoneService || Returns an [[#ITimeZoneService]]. |
| |- | | |- |
− | | 53 || APE || vdd_soc || | + | | 4 || GetStandardLocalSystemClock || Returns an [[#ISystemClock]]. |
| |- | | |- |
− | | 54 || ACLK || vdd_soc || | + | | 5 || [4.0.0+] GetEphemeralNetworkSystemClock || Returns an [[#ISystemClock]]. |
| |- | | |- |
− | | 55 || UARTAPE || vdd_soc || | + | | 20 || [6.0.0+] GetSharedMemoryNativeHandle || |
| |- | | |- |
− | | 56 || EMC || vdd_soc || | + | | 30 || [6.0.0+] GetStandardNetworkClockOperationEventReadableHandle || |
| |- | | |- |
− | | 57 || PLLE0 || vdd_soc || | + | | 31 || [6.0.0+] GetEphemeralNetworkClockOperationEventReadableHandle || |
| |- | | |- |
− | | 58 || PLLE0 || vdd_soc || | + | | 50 || [4.0.0+] SetStandardSteadyClockInternalOffset || |
| |- | | |- |
− | | 59 || DSI || vdd_soc || | + | | 100 || IsStandardUserSystemClockAutomaticCorrectionEnabled || |
| |- | | |- |
− | | 60 || MAUD || vdd_soc || | + | | 101 || SetStandardUserSystemClockAutomaticCorrectionEnabled || |
| |- | | |- |
− | | 61 || DPAUX1 || vdd_soc || | + | | 102 || [5.0.0+] GetStandardUserSystemClockInitialYear || |
| |- | | |- |
− | | 62 || MIPI_CAL || vdd_soc || | + | | 200 || [3.0.0+] IsStandardNetworkSystemClockAccuracySufficient || |
| |- | | |- |
− | | 63 || UART_FST_MIPI_CAL || vdd_soc || | + | | 201 || [6.0.0+] GetStandardUserSystemClockAutomaticCorrectionUpdatedTime || |
| |- | | |- |
− | | 64 || OSC || vdd_soc || | + | | 300 || [4.0.0+] CalculateMonotonicSystemClockBaseTimePoint || |
| |- | | |- |
− | | 65 || SCLK || vdd_soc || | + | | 400 || [4.0.0+] GetClockSnapshot || |
| |- | | |- |
− | | 66 || SOR_SAFE || vdd_soc || | + | | 401 || [4.0.0+] GetClockSnapshotFromSystemClockContext || |
| |- | | |- |
− | | 67 || XUSB_SS || vdd_soc || | + | | 500 || [4.0.0+] CalculateStandardUserSystemClockDifferenceByUser || |
| |- | | |- |
− | | 68 || XUSB_HOST || vdd_soc || | + | | 501 || [4.0.0+] CalculateSpanBetween || |
| + | |} |
| + | |
| + | == ISteadyClock == |
| + | This is "nn::timesrv::detail::service::ISteadyClock". |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 69 || XUSB_DEV || vdd_soc || | + | ! Cmd || Name || Notes |
| |- | | |- |
− | | 70 || EXTPERIPH1 || vdd_soc || | + | | 0 || GetCurrentTimePoint || No input, returns an output [[#SteadyClockTimePoint]]. |
| |- | | |- |
− | | 71 || AHUB || vdd_soc || | + | | 2 || GetTestOffset || No input, returns an output [[#TimeSpanType]]. |
| |- | | |- |
− | | 72 || HDA2HDMICODEC || vdd_soc || | + | | 3 || SetTestOffset || Takes an input [[#TimeSpanType]], no output. |
| |- | | |- |
− | | 73 || PLLP5 || vdd_soc || | + | | 100 || [2.0.0+] GetRtcValue || No input, returns an output s64. |
| |- | | |- |
− | | 74 || USBD || vdd_soc || | + | | 101 || [2.0.0+] IsRtcResetDetected || No input, returns an output u8 bool. |
| |- | | |- |
− | | 75 || USB2 || vdd_soc || | + | | 102 || [2.0.0+] GetSetupResultValue || No input, returns an output u32. |
| |- | | |- |
− | | 76 || PCIE || vdd_soc || | + | | 200 || [3.0.0+] GetInternalOffset || No input, returns an output [[#TimeSpanType]]. |
| |- | | |- |
− | | 77 || AFI || vdd_soc || | + | | 201 || [3.0.0-3.0.2] SetInternalOffset || Takes an input [[#TimeSpanType]], no output. |
| + | |} |
| + | |
| + | === SteadyClockTimePoint === |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 78 || PCIEXCLK || vdd_soc || | + | ! Offset || Size || Description |
| |- | | |- |
− | | 79 || PEX_USB_UPHY || vdd_soc || | + | | 0x0 || 0x8|| A u64 representing a point in time. |
| |- | | |- |
− | | 80 || XUSB_PADCTL || vdd_soc || | + | | 0x8 || 0x10 || An ID representing the clock source. |
| + | |} |
| + | |
| + | This is a 0x18-byte struct. |
| + | |
| + | === TimeSpanType === |
| + | This is an u64. |
| + | |
| + | == ISystemClock == |
| + | This is "nn::timesrv::detail::service::ISystemClock". |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 81 || APBDMA || vdd_soc || | + | ! Cmd || Name || Notes |
| |- | | |- |
− | | 82 || USB2_TRK || vdd_soc || | + | | 0 || GetCurrentTime || Returns an output [[#PosixTime]]. |
| |- | | |- |
− | | 83 || PLLE0 || vdd_soc || | + | | 1 || SetCurrentTime || Takes an input [[#PosixTime]]. |
| |- | | |- |
− | | 84 || PLLE0 || vdd_soc || | + | | 2 || GetSystemClockContext || Returns an output [[#SystemClockContext]]. |
| |- | | |- |
− | | 85 || CEC || vdd_soc || | + | | 3 || SetSystemClockContext || Takes an input [[#SystemClockContext]]. |
| |- | | |- |
| + | | 4 || [9.0.0+] GetOperationEventReadableHandle || |
| |} | | |} |
| | | |
− | === Voltage === | + | === PosixTime === |
| + | This is an s64 for UTC POSIX time. |
| + | |
| + | === SystemClockContext === |
| + | This is an 0x20-byte struct. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Name || Block || Notes | + | ! Offset || Size || Description |
| |- | | |- |
− | | 0 || max77620_sd0 || | + | | 0x0 || 0x8|| a [[#PosixTime]] representing the system clock epoch. |
| |- | | |- |
− | | 1 || max77620_sd1 || | + | | 0x8 || 0x18 || a [[#SteadyClockTimePoint]] |
| + | |} |
| + | |
| + | == ITimeZoneService == |
| + | This is "nn::timesrv::detail::service::ITimeZoneService". |
| + | |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 2 || max77620_sd2 || | + | ! Cmd || Name || Notes |
| |- | | |- |
− | | 3 || max77620_sd3 || | + | | 0 || GetDeviceLocationName || No input, returns an output [[#LocationName]]. |
| |- | | |- |
− | | 4 || max77620_ldo0 || | + | | 1 || SetDeviceLocationName || Takes an input [[#LocationName]], no output. |
| |- | | |- |
− | | 5 || max77620_ldo1 || | + | | 2 || GetTotalLocationNameCount || No input, returns an output s32. |
| |- | | |- |
− | | 6 || max77620_ldo2 || | + | | 3 || LoadLocationNameList || |
| |- | | |- |
− | | 7 || max77620_ldo3 || | + | | 4 || LoadTimeZoneRule || Takes an input [[#LocationName]] and a type-0x16 output buffer for [[#TimeZoneRule]], no output. |
| |- | | |- |
− | | 8 || max77620_ldo4 || | + | | 5 || [2.0.0+] GetTimeZoneRuleVersion || No input, returns an output [[#TimeZoneRuleVersion]]. |
| |- | | |- |
− | | 9 || max77620_ldo5 || | + | | 6 || [5.0.0+] GetDeviceLocationNameAndUpdatedTime || |
| |- | | |- |
− | | 10 || max77620_ldo6 || | + | | 100 || ToCalendarTime || Takes an input [[#PosixTime]] and a type-0x15 input buffer for [[#TimeZoneRule]], returns an output [[#CalendarTime]] and [[#CalendarAdditionalInfo]]. |
| |- | | |- |
− | | 11 || max77620_ldo7 || | + | | 101 || ToCalendarTimeWithMyRule || Takes an input [[#PosixTime]], returns an output [[#CalendarTime]] and [[#CalendarAdditionalInfo]]. |
| |- | | |- |
− | | 12 || max77620_ldo8 || | + | | 201 || ToPosixTime || Takes an input [[#CalendarTime]], a type-0x15 input buffer for [[#TimeZoneRule]], an type-0xA output buffer for [[#PosixTime]] array, and returns an output s32. |
− | |-
| |
− | | 13 || max77621_cpu ||
| |
− | |-
| |
− | | 14 || max77621_gpu ||
| |
| |- | | |- |
| + | | 202 || ToPosixTimeWithMyRule || Takes an input [[#CalendarTime]], an type-0xA output buffer for [[#PosixTime]] array, and returns an output s32. |
| |} | | |} |
| | | |
− | Note: max77620 GPIOs are only used internally by the driver during init, and not exposed via an API.
| + | === LoadLocationNameList === |
| + | Takes an input s32 LocationName_index and a type-0x6 output buffer for [[#LocationName]], returns an output s32 for total output entries. |
| + | |
| + | === LocationName === |
| + | This contains a TimeZone location string with a max size of 0x24 bytes. |
| + | |
| + | === TimeZoneRule === |
| + | This is an 0x4000-byte struct. Official sw uses fixed-size 0x4000 for the buffer size with the above commands. |
| + | |
| + | This is loaded from the [[Title_list|TimeZoneBinary]] title with the specified LocationName under the zoneinfo/ directory, the content is then converted into this TimeZoneRule structure. |
| + | |
| + | The files contained under zoneinfo/ directory are Tzif2 files without Tzif1 header and data at the begining of them (see [https://tools.ietf.org/html/rfc8536 RFC8536] for more information). |
| | | |
− | = pcv:arb =
| + | The conversion of a Tzif2 file to a TimeZoneRule structure is based on [https://github.com/eggert/tz/blob/master/localtime.c tz database code] with some custom modifications (Leap seconds aren't handled, no usage of "posixrules" and Tzif1 support stripped out). |
− | This is "nn::pcv::IArbitrationManager".
| |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name | + | ! Offset || Size || Description |
| + | |- |
| + | | 0x0 || 0x4 || timecnt |
| + | |- |
| + | | 0x4 || 0x4 || typecnt |
| + | |- |
| + | | 0x8 || 0x4 || charcnt |
| + | |- |
| + | | 0xC || 0x1 || goback |
| + | |- |
| + | | 0xD || 0x1 || goahead |
| + | |- |
| + | | 0xE || 0x2 || Padding |
| + | |- |
| + | | 0x10 || 0x8 * 1000 || ats |
| + | |- |
| + | | 0x1f50 || 0x1 * 1000 || types |
| + | |- |
| + | | 0x2338 || 0x10 * 128 || ttis (time type information), struct ttinfo[1000] |
| + | |- |
| + | | 0x2b38 || 0x1 * 512 || chars |
| |- | | |- |
− | | 0 || ReleaseControl | + | | 0x2d38 || 0x4 || defaulttype |
| |- | | |- |
| + | | 0x2d3c || 0x12c4 || Reserved / Unused |
| |} | | |} |
| | | |
− | = pcv:imm = | + | === ttinfo === |
− | This is "nn::pcv::IImmediateManager". | + | This is an 0x10-byte struct. |
| + | Represent a Time Type Information used in [[#TimeZoneRule]]. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name | + | ! Offset || Size || Description |
| + | |- |
| + | | 0x0 || 0x4 || tt_gmtoff |
| + | |- |
| + | | 0x4 || 0x1 || tt_isdst |
| + | |- |
| + | | 0x5 || 0x3 || Padding |
| + | |- |
| + | | 0x8 || 0x4 || tt_abbrind |
| + | |- |
| + | | 0xC || 0x1 || tt_ttisstd |
| |- | | |- |
− | | 0 || SetClockRate | + | | 0xD || 0x1 || tt_ttisgmt |
| |- | | |- |
| + | | 0xE || 0x2 || Padding |
| |} | | |} |
| | | |
− | = time:u, time:a, time:s = | + | === TimeZoneRuleVersion === |
− | This is "nn::timesrv::detail::service::IStaticService". | + | This is an u128. |
| | | |
| + | === CalendarTime === |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name || Notes | + | ! Offset || Size || Description |
| + | |- |
| + | | 0x0 || 0x2 || Year |
| + | |- |
| + | | 0x2 || 0x1 || Month |
| + | |- |
| + | | 0x3 || 0x1 || Day |
| + | |- |
| + | | 0x4 || 0x1 || Hour |
| |- | | |- |
− | | 0 || GetStandardUserSystemClock || Returns an [[#ISystemClock]]. | + | | 0x5 || 0x1 || Minute |
| |- | | |- |
− | | 1 || GetStandardNetworkSystemClock || Returns an [[#ISystemClock]]. | + | | 0x6 || 0x1 || Second |
| |- | | |- |
− | | 2 || GetStandardSteadyClock || Returns an [[#ISteadyClock]]. | + | | 0x7 || 0x1 || Padding / unknown? |
| + | |} |
| + | |
| + | This is an 0x8-byte struct. |
| + | |
| + | === CalendarAdditionalInfo === |
| + | {| class="wikitable" border="1" |
| |- | | |- |
− | | 3 || GetTimeZoneService || Returns an [[#ITimeZoneService]]. | + | ! Offset || Size || Description |
| |- | | |- |
− | | 4 || GetStandardLocalSystemClock || Returns an [[#ISystemClock]]. | + | | 0x0 || 0x4 || 0-based day-of-week. |
| |- | | |- |
− | | 100 || IsStandardUserSystemClockAutomaticCorrectionEnabled || | + | | 0x4 || 0x4 || 0-based day-of-year. |
| |- | | |- |
− | | 101 || SetStandardUserSystemClockAutomaticCorrectionEnabled || | + | | 0x8 || 0x8 || Timezone name string. |
| |- | | |- |
− | | 200 || IsStandardNetworkSystemClockAccuracySufficient || | + | | 0x10 || 0x4 || 0 = no DST, 1 = DST. |
| |- | | |- |
| + | | 0x14 || 0x4 || s32 seconds relative to UTC for this timezone. |
| |} | | |} |
| | | |
− | == ISteadyClock == | + | This is an 0x18-byte struct. This stores timezone info. |
| + | |
| + | = Module = |
| + | This is "nn::pcv::Module". |
| + | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name || Notes | + | ! Name || DeviceCode || Block || Rail || Notes |
| + | |- |
| + | | 0 || 0x40000001 || CpuBus || vdd_cpu || |
| + | |- |
| + | | 1 || 0x40000002 || GPU || vdd_gpu || |
| + | |- |
| + | | 2 || 0x40000003 || I2S1 || vdd_soc || |
| + | |- |
| + | | 3 || 0x40000004 || I2S2 || vdd_soc || |
| + | |- |
| + | | 4 || 0x40000005 || I2S3 || vdd_soc || |
| + | |- |
| + | | 5 || 0x40000006 || PWM || vdd_soc || |
| + | |- |
| + | | 6 || 0x02000001 || I2C1 || vdd_soc || |
| + | |- |
| + | | 7 || 0x02000002 || I2C2 || vdd_soc || |
| + | |- |
| + | | 8 || 0x02000003 || I2C3 || vdd_soc || |
| + | |- |
| + | | 9 || 0x02000004 || I2C4 || vdd_soc || |
| + | |- |
| + | | 10 || 0x02000005 || I2C5 || vdd_soc || |
| + | |- |
| + | | 11 || 0x02000006 || I2C6 || vdd_soc || |
| + | |- |
| + | | 12 || 0x07000000 || SPI1 || vdd_soc || |
| + | |- |
| + | | 13 || 0x07000001 || SPI2 || vdd_soc || |
| + | |- |
| + | | 14 || 0x07000002 || SPI3 || vdd_soc || |
| + | |- |
| + | | 15 || 0x07000003 || SPI4 || vdd_soc || |
| + | |- |
| + | | 16 || 0x40000011 || DISP1 || vdd_soc || |
| + | |- |
| + | | 17 || 0x40000012 || DISP2 || vdd_soc || |
| + | |- |
| + | | 18 || 0x40000013 || ISP || - || Not an actual block. Used for debug. |
| + | |- |
| + | | 19 || 0x40000014 || VI || - || Not an actual block. Used for debug. |
| + | |- |
| + | | 20 || 0x40000015 || SDMMC1 || vdd_soc || |
| + | |- |
| + | | 21 || 0x40000016 || SDMMC2 || vdd_soc || |
| + | |- |
| + | | 22 || 0x40000017 || SDMMC3 || vdd_soc || |
| + | |- |
| + | | 23 || 0x40000018 || SDMMC4 || vdd_soc || |
| + | |- |
| + | | 24 || 0x40000019 || OWR || - || Not an actual block. Used for debug. |
| + | |- |
| + | | 25 || 0x4000001A || CSITE || vdd_soc || |
| + | |- |
| + | | 26 || 0x4000001B || TSEC || vdd_soc || |
| + | |- |
| + | | 27 || 0x4000001C || MSELECT || vdd_soc || |
| + | |- |
| + | | 28 || 0x4000001D || HDA2CODEC_2X || vdd_soc || |
| + | |- |
| + | | 29 || 0x4000001E || ACTMON || vdd_soc || |
| + | |- |
| + | | 30 || 0x4000001F || I2C_SLOW || vdd_soc || |
| + | |- |
| + | | 31 || 0x40000020 || SOR1 || vdd_soc || |
| + | |- |
| + | | 32 || 0x40000021 || SATA || - || Not an actual block. Used for debug. |
| + | |- |
| + | | 33 || 0x40000022 || HDA || vdd_soc || |
| + | |- |
| + | | 34 || 0x40000023 || XUSB_CORE_HOST || vdd_soc || |
| + | |- |
| + | | 35 || 0x40000024 || XUSB_FALCON || vdd_soc || |
| + | |- |
| + | | 36 || 0x40000025 || XUSB_FS || vdd_soc || |
| + | |- |
| + | | 37 || 0x40000026 || XUSB_CORE_DEV || vdd_soc || |
| + | |- |
| + | | 38 || 0x40000027 || XUSB_SS_HOSTDEV || vdd_soc || |
| + | |- |
| + | | 39 || 0x03000001 || UARTA || vdd_soc || |
| + | |- |
| + | | 40 || 0x35000405 || UARTB || vdd_soc || |
| + | |- |
| + | | 41 || 0x3500040F || UARTC || vdd_soc || |
| + | |- |
| + | | 42 || 0x37000001 || UARTD || vdd_soc || |
| + | |- |
| + | | 43 || 0x4000002C || HOST1X || vdd_soc || |
| + | |- |
| + | | 44 || 0x4000002D || ENTROPY || vdd_soc || |
| + | |- |
| + | | 45 || 0x4000002E || SOC_THERM || vdd_soc || |
| + | |- |
| + | | 46 || 0x4000002F || VIC || vdd_soc || |
| + | |- |
| + | | 47 || 0x40000030 || NVENC || vdd_soc || |
| + | |- |
| + | | 48 || 0x40000031 || NVJPG || vdd_soc || |
| + | |- |
| + | | 49 || 0x40000032 || NVDEC || vdd_soc || |
| + | |- |
| + | | 50 || 0x40000033 || QSPI || vdd_soc || |
| + | |- |
| + | | 51 || 0x40000034 || VI_I2C || - || Not an actual block. Used for debug. |
| + | |- |
| + | | 52 || 0x40000035 || TSECB || vdd_soc || |
| + | |- |
| + | | 53 || 0x40000036 || APE || vdd_soc || |
| + | |- |
| + | | 54 || 0x40000037 || ACLK || vdd_soc || |
| + | |- |
| + | | 55 || 0x40000038 || UARTAPE || vdd_soc || |
| + | |- |
| + | | 56 || 0x40000039 || EMC || vdd_soc || |
| + | |- |
| + | | 57 || 0x4000003A || PLLE0 || vdd_soc || |
| + | |- |
| + | | 58 || 0x4000003B || PLLE0 || vdd_soc || |
| + | |- |
| + | | 59 || 0x4000003C || DSI || vdd_soc || |
| + | |- |
| + | | 60 || 0x4000003D || MAUD || vdd_soc || |
| + | |- |
| + | | 61 || 0x4000003E || DPAUX1 || vdd_soc || |
| + | |- |
| + | | 62 || 0x4000003F || MIPI_CAL || vdd_soc || |
| + | |- |
| + | | 63 || 0x40000040 || UART_FST_MIPI_CAL || vdd_soc || |
| + | |- |
| + | | 64 || 0x40000041 || OSC || vdd_soc || |
| + | |- |
| + | | 65 || 0x40000042 || SCLK || vdd_soc || |
| + | |- |
| + | | 66 || 0x40000043 || SOR_SAFE || vdd_soc || |
| + | |- |
| + | | 67 || 0x40000044 || XUSB_SS || vdd_soc || |
| + | |- |
| + | | 68 || 0x40000045 || XUSB_HOST || vdd_soc || |
| + | |- |
| + | | 69 || 0x40000046 || XUSB_DEV || vdd_soc || |
| + | |- |
| + | | 70 || 0x40000047 || EXTPERIPH1 || vdd_soc || |
| + | |- |
| + | | 71 || 0x40000048 || AHUB || vdd_soc || |
| + | |- |
| + | | 72 || 0x40000049 || HDA2HDMICODEC || vdd_soc || |
| + | |- |
| + | | 73 || 0x4000004A || PLLP5 || vdd_soc || |
| + | |- |
| + | | 74 || 0x4000004B || USBD || vdd_soc || |
| + | |- |
| + | | 75 || 0x4000004C || USB2 || vdd_soc || |
| + | |- |
| + | | 76 || 0x4000004D || PCIE || vdd_soc || |
| + | |- |
| + | | 77 || 0x4000004E || AFI || vdd_soc || |
| |- | | |- |
− | | 0 || GetCurrentTimePoint || No input, returns an output [[#SteadyClockTimePoint]]. | + | | 78 || 0x4000004F || PCIEXCLK || vdd_soc || |
| |- | | |- |
− | | 2 || GetTestOffset || No input, returns an output [[#TimeSpanType]]. | + | | 79 || 0x40000050 || PEX_USB_UPHY || vdd_soc || |
| |- | | |- |
− | | 3 || SetTestOffset || Takes an input [[#TimeSpanType]], no output. | + | | 80 || 0x40000051 || XUSB_PADCTL || vdd_soc || |
| |- | | |- |
− | | 100 || GetRtcValue || No input, returns an output s64. | + | | 81 || 0x40000052 || APBDMA || vdd_soc || |
| |- | | |- |
− | | 101 || IsRtcResetDetected || No input, returns an output u8 bool. | + | | 82 || 0x40000053 || USB2_TRK || vdd_soc || |
| |- | | |- |
− | | 102 || GetSetupResultValue || No input, returns an output u32. | + | | 83 || 0x40000054 || PLLE0 || vdd_soc || |
| |- | | |- |
− | | 200 || GetInternalOffset || No input, returns an output [[#TimeSpanType]]. | + | | 84 || 0x40000055 || PLLE0 || vdd_soc || |
| |- | | |- |
− | | 201 || SetInternalOffset || Takes an input [[#TimeSpanType]], no output. | + | | 85 || 0x40000056 || CEC || vdd_soc || |
| |- | | |- |
| + | | [6.0.0+] 86 || 0x40000057 || EXTPERIPH2 || vdd_soc || |
| |} | | |} |
| | | |
− | === SteadyClockTimePoint === | + | = PowerDomain = |
− | This is a 0x18-byte struct. | + | This is "nn::pcv::PowerDomain". |
| | | |
− | === TimeSpanType ===
| |
− | This is an u64.
| |
− |
| |
− | == ISystemClock ==
| |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
| |- | | |- |
− | ! Cmd || Name || Notes | + | ! Name || DeviceCode || Block || Notes |
| + | |- |
| + | | 0 || 0x3A000080 || max77620_sd0 || |
| + | |- |
| + | | 1 || 0x3A000081 || max77620_sd1 || |
| + | |- |
| + | | 2 || 0x3A000082 || max77620_sd2 || |
| + | |- |
| + | | 3 || 0x3A000083 || max77620_sd3 || |
| |- | | |- |
− | | 0 || GetCurrentTime || Returns an nn::time::PosixTime (time since epoch). | + | | 4 || 0x3A0000A0 || max77620_ldo0 || 1.2v |
| |- | | |- |
− | | 1 || SetCurrentTime || Takes an nn::time::PosixTime. | + | | 5 || 0x3A0000A1 || max77620_ldo1 || |
| |- | | |- |
− | | 2 || GetSystemClockContext || Returns an 0x20 byte struct (nn::time::SystemClockContext). | + | | 6 || 0x3A0000A2 || max77620_ldo2 || SDcard power, 1.8v - 3.3v |
| |- | | |- |
− | | 3 || SetSystemClockContext || Takes an nn::time::SystemClockContext | + | | 7 || 0x3A0000A3 || max77620_ldo3 || GC ASIC 3.1v |
| |- | | |- |
− | |} | + | | 8 || 0x3A0000A4 || max77620_ldo4 || RTC power, 0.85v |
− | | |
− | == ITimeZoneService ==
| |
− | {| class="wikitable" border="1"
| |
| |- | | |- |
− | ! Cmd || Name || Notes
| + | | 9 || 0x3A0000A5 || max77620_ldo5 || GC ASIC 1.8v |
| |- | | |- |
− | | 0 || GetDeviceLocationName || Returns an nn::time::LocationName (0x24 bytes). | + | | 10 || 0x3A0000A6 || max77620_ldo6 || AVDD touchscreen, 2.9v |
| |- | | |- |
− | | 1 || SetDeviceLocationName || Takes an nn::time::LocationName. | + | | 11 || 0x3A0000A7 || max77620_ldo7 || |
| |- | | |- |
− | | 2 || GetTotalLocationNameCount || Returns an 0x20 byte struct (nn::time::SystemClockContext). | + | | 12 || 0x3A0000A8 || max77620_ldo8 || DisplayPort, 1.05v |
| |- | | |- |
− | | 3 || LoadLocationNameList || | + | | 13 || 0x3A000003 || max77621_cpu || |
| |- | | |- |
− | | 4 || LoadTimeZoneRule || | + | | 14 || 0x3A000004 || max77621_gpu || |
| |- | | |- |
− | | 5 || GetTimeZoneRuleVersion || | + | | [6.0.0+] 15 || 0x3A000003 || max77812_cpu || |
| |- | | |- |
− | | 100 || ToCalendarTime || | + | | [6.0.0+] 16 || 0x3A000004 || max77812_gpu || |
| |- | | |- |
− | | 101 || ToCalendarTimeWithMyRule || | + | | [6.0.0+] 17 || 0x3A000005 || max77812_dram || |
| |- | | |- |
− | | 200 || ToPosixTime || | + | | [8.0.0+] - || 0x3C000004 || || SDCard |
| |- | | |- |
− | | 201 || ToPosixTimeWithMyRule || | + | | [8.0.0+] - || 0x34000007 || || HDMI |
| |- | | |- |
| + | | [8.0.0+] - || 0x3500041A || || MCU |
| |} | | |} |
| + | |
| + | [[Category:Services]] |