forked from CTCaer/hekate
bdk: migrate timers/sleeps to timer driver
This commit is contained in:
parent
061e10152f
commit
b0c0a86108
@ -51,6 +51,7 @@
|
|||||||
#include <soc/kfuse.h>
|
#include <soc/kfuse.h>
|
||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <soc/uart.h>
|
#include <soc/uart.h>
|
||||||
#include <storage/emmc.h>
|
#include <storage/emmc.h>
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
#include <utils/util.h>
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* Joy-Con UART driver for Nintendo Switch
|
* Joy-Con UART driver for Nintendo Switch
|
||||||
*
|
*
|
||||||
* Copyright (c) 2019-2021 CTCaer
|
* Copyright (c) 2019-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -27,9 +27,9 @@
|
|||||||
#include <soc/fuse.h>
|
#include <soc/fuse.h>
|
||||||
#include <soc/gpio.h>
|
#include <soc/gpio.h>
|
||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/uart.h>
|
#include <soc/uart.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
// For disabling driver when logging is enabled.
|
// For disabling driver when logging is enabled.
|
||||||
#include <libs/lv_conf.h>
|
#include <libs/lv_conf.h>
|
||||||
@ -82,9 +82,9 @@
|
|||||||
#define JC_BTN_MASK_L 0xFF2900 // 0xFFE900: with charge status.
|
#define JC_BTN_MASK_L 0xFF2900 // 0xFFE900: with charge status.
|
||||||
#define JC_BTN_MASK_R 0x0056FF
|
#define JC_BTN_MASK_R 0x0056FF
|
||||||
|
|
||||||
#define JC_ID_L 0x01
|
#define JC_ID_L 0x01 // Joycon (L). Mask for Hori (L).
|
||||||
#define JC_ID_R 0x02
|
#define JC_ID_R 0x02 // Joycon (R). Mask for Hori (R).
|
||||||
#define JC_ID_HORI 0x20
|
#define JC_ID_HORI 0x20 // Mask for Hori. Actual ids: 0x21, 0x22.
|
||||||
|
|
||||||
#define JC_CRC8_POLY 0x8D
|
#define JC_CRC8_POLY 0x8D
|
||||||
|
|
||||||
|
@ -24,9 +24,9 @@
|
|||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
#include <power/max7762x.h>
|
#include <power/max7762x.h>
|
||||||
#include <soc/gpio.h>
|
#include <soc/gpio.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/btn.h>
|
#include <utils/btn.h>
|
||||||
#include <utils/util.h>
|
|
||||||
#include "touch.h"
|
#include "touch.h"
|
||||||
|
|
||||||
|
|
||||||
@ -35,12 +35,12 @@
|
|||||||
|
|
||||||
static touch_panel_info_t _panels[] =
|
static touch_panel_info_t _panels[] =
|
||||||
{
|
{
|
||||||
{ 0, 1, 1, 1, "NISSHA NFT-K12D" },
|
{ 0, 1, 1, 1, "NISSHA NFT-K12D" },// 0.
|
||||||
{ 1, 0, 1, 1, "GiS GGM6 B2X" },
|
{ 1, 0, 1, 1, "GiS GGM6 B2X" },// 1.
|
||||||
{ 2, 0, 0, 0, "NISSHA NBF-K9A" },
|
{ 2, 0, 0, 0, "NISSHA NBF-K9A" },// 3.
|
||||||
{ 3, 1, 0, 0, "GiS 5.5\"" },
|
{ 3, 1, 0, 0, "GiS 5.5\"" },// 4.
|
||||||
{ 4, 0, 0, 1, "Samsung BH2109" },
|
{ 4, 0, 0, 1, "Samsung BH2109" },// 5?
|
||||||
{ -1, 1, 0, 1, "GiS VA 6.2\"" }
|
{ -1, 1, 0, 1, "GiS VA 6.2\"" } // 2.
|
||||||
};
|
};
|
||||||
|
|
||||||
static int touch_command(u8 cmd, u8 *buf, u8 size)
|
static int touch_command(u8 cmd, u8 *buf, u8 size)
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
#ifndef LV_CONF_H
|
#ifndef LV_CONF_H
|
||||||
#define LV_CONF_H
|
#define LV_CONF_H
|
||||||
|
|
||||||
#include <utils/types.h>
|
#include <soc/timer.h>
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
/*===================
|
/*===================
|
||||||
Dynamic memory
|
Dynamic memory
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2018-2021 CTCaer
|
* Copyright (c) 2018-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -17,9 +17,9 @@
|
|||||||
|
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
#include <mem/mc.h>
|
#include <mem/mc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <soc/clock.h>
|
#include <soc/clock.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
void mc_config_tsec_carveout(u32 bom, u32 size1mb, bool lock)
|
void mc_config_tsec_carveout(u32 bom, u32 size1mb, bool lock)
|
||||||
{
|
{
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2018 balika011
|
* Copyright (c) 2018 balika011
|
||||||
* Copyright (c) 2019-2021 CTCaer
|
* Copyright (c) 2019-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -31,8 +31,8 @@
|
|||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
#define CONFIG_SDRAM_KEEP_ALIVE
|
#define CONFIG_SDRAM_KEEP_ALIVE
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2020-2021 CTCaer
|
* Copyright (c) 2020-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2020-2021 CTCaer
|
* Copyright (c) 2020-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -541,8 +541,12 @@ static const sdram_params_t210_t _dram_cfg_0_samsung_4gb = {
|
|||||||
.mc_video_protect_bom = 0xFFF00000,
|
.mc_video_protect_bom = 0xFFF00000,
|
||||||
.mc_video_protect_bom_adr_hi = 0x00000000,
|
.mc_video_protect_bom_adr_hi = 0x00000000,
|
||||||
.mc_video_protect_size_mb = 0x00000000,
|
.mc_video_protect_size_mb = 0x00000000,
|
||||||
|
|
||||||
|
// AFI, BPMP, HC, ISP2, CCPLEX, PPCS (AHB), SATA, VI, XUSB_HOST, XUSB_DEV, ADSP, PPCS1 (AHB), DC1, SDMMC1A, SDMMC2A, SDMMC3A.
|
||||||
.mc_video_protect_vpr_override = 0xE4BAC343,
|
.mc_video_protect_vpr_override = 0xE4BAC343,
|
||||||
|
// SDMMC4A, ISP2B, PPCS2 (AHB), APE, SE, HC1, SE1, AXIAP, ETR.
|
||||||
.mc_video_protect_vpr_override1 = 0x00001ED3,
|
.mc_video_protect_vpr_override1 = 0x00001ED3,
|
||||||
|
|
||||||
.mc_video_protect_gpu_override0 = 0x00000000,
|
.mc_video_protect_gpu_override0 = 0x00000000,
|
||||||
.mc_video_protect_gpu_override1 = 0x00000000,
|
.mc_video_protect_gpu_override1 = 0x00000000,
|
||||||
.mc_sec_carveout_bom = 0xFFF00000,
|
.mc_sec_carveout_bom = 0xFFF00000,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2020-2021 CTCaer
|
* Copyright (c) 2020-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -594,8 +594,12 @@ static const sdram_params_t210b01_t _dram_cfg_08_10_12_14_samsung_hynix_4gb = {
|
|||||||
.mc_video_protect_bom = 0xFFF00000,
|
.mc_video_protect_bom = 0xFFF00000,
|
||||||
.mc_video_protect_bom_adr_hi = 0x00000000,
|
.mc_video_protect_bom_adr_hi = 0x00000000,
|
||||||
.mc_video_protect_size_mb = 0x00000000,
|
.mc_video_protect_size_mb = 0x00000000,
|
||||||
|
|
||||||
|
// AFI, BPMP, HC, ISP2, CCPLEX, PPCS (AHB), SATA, VI, XUSB_HOST, XUSB_DEV, ADSP, PPCS1 (AHB), DC1, SDMMC1A, SDMMC2A, SDMMC3A.
|
||||||
.mc_video_protect_vpr_override = 0xE4BAC343,
|
.mc_video_protect_vpr_override = 0xE4BAC343,
|
||||||
.mc_video_protect_vpr_override1 = 0x06001ED3, // Add SE2, SE2B.
|
// SDMMC4A, ISP2B, PPCS2 (AHB), APE, SE, HC1, SE1, AXIAP, ETR. Plus SE2, SE2B.
|
||||||
|
.mc_video_protect_vpr_override1 = 0x06001ED3,
|
||||||
|
|
||||||
.mc_video_protect_gpu_override0 = 0x00000000,
|
.mc_video_protect_gpu_override0 = 0x00000000,
|
||||||
.mc_video_protect_gpu_override1 = 0x00000000,
|
.mc_video_protect_gpu_override1 = 0x00000000,
|
||||||
.mc_sec_carveout_bom = 0xFFF00000,
|
.mc_sec_carveout_bom = 0xFFF00000,
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2018 balika011
|
* Copyright (c) 2018 balika011
|
||||||
|
* Copyright (c) 2018-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -18,10 +19,10 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <soc/ccplex.h>
|
#include <soc/ccplex.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <mem/mc_t210.h>
|
#include <mem/mc_t210.h>
|
||||||
#include <mem/smmu.h>
|
#include <mem/smmu.h>
|
||||||
#include <utils/util.h>
|
|
||||||
#include <utils/aarch64_util.h>
|
#include <utils/aarch64_util.h>
|
||||||
|
|
||||||
bool smmu_used = false;
|
bool smmu_used = false;
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
|
|
||||||
// REG 1 masks.
|
// REG 1 masks.
|
||||||
#define BQ24193_PORCONFIG_BOOST_MASK (1<<0)
|
#define BQ24193_PORCONFIG_BOOST_MASK (1<<0)
|
||||||
#define BQ24193_PORCONFIG_SYSMIN_MASK (7<<1)
|
#define BQ24193_PORCONFIG_SYSMIN_MASK (7<<1) // 3000uV HOS default.
|
||||||
#define BQ24193_PORCONFIG_CHGCONFIG_MASK (3<<4)
|
#define BQ24193_PORCONFIG_CHGCONFIG_MASK (3<<4)
|
||||||
#define BQ24193_PORCONFIG_CHGCONFIG_CHARGER_EN (1<<4)
|
#define BQ24193_PORCONFIG_CHGCONFIG_CHARGER_EN (1<<4)
|
||||||
#define BQ24193_PORCONFIG_I2CWATCHDOG_MASK (1<<6)
|
#define BQ24193_PORCONFIG_I2CWATCHDOG_MASK (1<<6)
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
|
|
||||||
#include "max17050.h"
|
#include "max17050.h"
|
||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
#include <utils/util.h>
|
#include <soc/timer.h>
|
||||||
|
|
||||||
#define BASE_SNS_UOHM 5000
|
#define BASE_SNS_UOHM 5000
|
||||||
|
|
||||||
|
@ -20,8 +20,8 @@
|
|||||||
#include <power/max77812.h>
|
#include <power/max77812.h>
|
||||||
#include <soc/fuse.h>
|
#include <soc/fuse.h>
|
||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
#define REGULATOR_SD 0
|
#define REGULATOR_SD 0
|
||||||
#define REGULATOR_LDO 1
|
#define REGULATOR_LDO 1
|
||||||
|
@ -23,8 +23,8 @@
|
|||||||
#include <soc/bpmp.h>
|
#include <soc/bpmp.h>
|
||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
typedef struct _se_ll_t
|
typedef struct _se_ll_t
|
||||||
{
|
{
|
||||||
|
@ -25,11 +25,11 @@
|
|||||||
#include <soc/clock.h>
|
#include <soc/clock.h>
|
||||||
#include <soc/kfuse.h>
|
#include <soc/kfuse.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <mem/heap.h>
|
#include <mem/heap.h>
|
||||||
#include <mem/mc.h>
|
#include <mem/mc.h>
|
||||||
#include <mem/smmu.h>
|
#include <mem/smmu.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
// #include <gfx_utils.h>
|
// #include <gfx_utils.h>
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* BPMP-Lite Cache/MMU and Frequency driver for Tegra X1
|
* BPMP-Lite Cache/MMU and Frequency driver for Tegra X1
|
||||||
*
|
*
|
||||||
* Copyright (c) 2019-2021 CTCaer
|
* Copyright (c) 2019-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -18,9 +18,9 @@
|
|||||||
|
|
||||||
#include <soc/bpmp.h>
|
#include <soc/bpmp.h>
|
||||||
#include <soc/clock.h>
|
#include <soc/clock.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
#define BPMP_MMU_CACHE_LINE_SIZE 0x20
|
#define BPMP_MMU_CACHE_LINE_SIZE 0x20
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2018-2020 CTCaer
|
* Copyright (c) 2018-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
@ -18,9 +18,9 @@
|
|||||||
#include <soc/clock.h>
|
#include <soc/clock.h>
|
||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <storage/sdmmc.h>
|
#include <storage/sdmmc.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
typedef struct _clock_osc_t
|
typedef struct _clock_osc_t
|
||||||
{
|
{
|
||||||
@ -528,9 +528,9 @@ void clock_enable_pllu()
|
|||||||
CLOCK(CLK_RST_CONTROLLER_PLLU_BASE) = pllu_cfg | PLLCX_BASE_ENABLE; // Enable.
|
CLOCK(CLK_RST_CONTROLLER_PLLU_BASE) = pllu_cfg | PLLCX_BASE_ENABLE; // Enable.
|
||||||
|
|
||||||
// Wait for PLL to stabilize.
|
// Wait for PLL to stabilize.
|
||||||
u32 timeout = (u32)TMR(TIMERUS_CNTR_1US) + 1300;
|
u32 timeout = get_tmr_us() + 1300;
|
||||||
while (!(CLOCK(CLK_RST_CONTROLLER_PLLU_BASE) & PLLCX_BASE_LOCK)) // PLL_LOCK.
|
while (!(CLOCK(CLK_RST_CONTROLLER_PLLU_BASE) & PLLCX_BASE_LOCK)) // PLL_LOCK.
|
||||||
if ((u32)TMR(TIMERUS_CNTR_1US) > timeout)
|
if (get_tmr_us() > timeout)
|
||||||
break;
|
break;
|
||||||
usleep(10);
|
usleep(10);
|
||||||
|
|
||||||
|
@ -117,6 +117,7 @@
|
|||||||
#define CLK_RST_CONTROLLER_LVL2_CLK_GATE_OVRD 0x3A4
|
#define CLK_RST_CONTROLLER_LVL2_CLK_GATE_OVRD 0x3A4
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_MSELECT 0x3B4
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_MSELECT 0x3B4
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_I2C4 0x3C4
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_I2C4 0x3C4
|
||||||
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_AHUB 0x3D0
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_ACTMON 0x3E8
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_ACTMON 0x3E8
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_EXTPERIPH1 0x3EC
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_EXTPERIPH1 0x3EC
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_EXTPERIPH2 0x3F0
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_EXTPERIPH2 0x3F0
|
||||||
@ -157,6 +158,7 @@
|
|||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_UART_FST_MIPI_CAL 0x66C
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_UART_FST_MIPI_CAL 0x66C
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_SDMMC_LEGACY_TM 0x694
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_SDMMC_LEGACY_TM 0x694
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_NVENC 0x6A0
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_NVENC 0x6A0
|
||||||
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_APE 0x6C0
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_USB2_HSIC_TRK 0x6CC
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_USB2_HSIC_TRK 0x6CC
|
||||||
#define CLK_RST_CONTROLLER_SE_SUPER_CLK_DIVIDER 0x704
|
#define CLK_RST_CONTROLLER_SE_SUPER_CLK_DIVIDER 0x704
|
||||||
#define CLK_RST_CONTROLLER_CLK_SOURCE_UARTAPE 0x710
|
#define CLK_RST_CONTROLLER_CLK_SOURCE_UARTAPE 0x710
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
#include <soc/uart.h>
|
#include <soc/uart.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <mem/mc.h>
|
#include <mem/mc.h>
|
||||||
#include <mem/minerva.h>
|
#include <mem/minerva.h>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2018-2020 CTCaer
|
* Copyright (c) 2018-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -18,7 +18,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
#include <utils/util.h>
|
#include <soc/timer.h>
|
||||||
|
|
||||||
#define I2C_PACKET_PROT_I2C BIT(4)
|
#define I2C_PACKET_PROT_I2C BIT(4)
|
||||||
#define I2C_HEADER_CONT_XFER BIT(15)
|
#define I2C_HEADER_CONT_XFER BIT(15)
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "irq.h"
|
#include "irq.h"
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <gfx_utils.h>
|
#include <gfx_utils.h>
|
||||||
#include <mem/heap.h>
|
#include <mem/heap.h>
|
||||||
|
@ -16,8 +16,8 @@
|
|||||||
|
|
||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
void pmc_scratch_lock(pmc_sec_lock_t lock_mask)
|
void pmc_scratch_lock(pmc_sec_lock_t lock_mask)
|
||||||
{
|
{
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
|
* Copyright (c) 2018-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -244,28 +245,6 @@
|
|||||||
#define SYSCTR0_COUNTERID10 0xFF8
|
#define SYSCTR0_COUNTERID10 0xFF8
|
||||||
#define SYSCTR0_COUNTERID11 0xFFC
|
#define SYSCTR0_COUNTERID11 0xFFC
|
||||||
|
|
||||||
/*! TMR registers. */
|
|
||||||
#define TIMERUS_CNTR_1US (0x10 + 0x0)
|
|
||||||
#define TIMERUS_USEC_CFG (0x10 + 0x4)
|
|
||||||
#define TIMER_TMR8_TMR_PTV 0x78
|
|
||||||
#define TIMER_TMR9_TMR_PTV 0x80
|
|
||||||
#define TIMER_PER_EN BIT(30)
|
|
||||||
#define TIMER_EN BIT(31)
|
|
||||||
#define TIMER_TMR8_TMR_PCR 0x7C
|
|
||||||
#define TIMER_TMR9_TMR_PCR 0x8C
|
|
||||||
#define TIMER_INTR_CLR BIT(30)
|
|
||||||
|
|
||||||
#define TIMER_WDT4_CONFIG (0x100 + 0x80)
|
|
||||||
#define TIMER_SRC(TMR) ((TMR) & 0xF)
|
|
||||||
#define TIMER_PER(PER) (((PER) & 0xFF) << 4)
|
|
||||||
#define TIMER_SYSRESET_EN BIT(14)
|
|
||||||
#define TIMER_PMCRESET_EN BIT(15)
|
|
||||||
#define TIMER_WDT4_COMMAND (0x108 + 0x80)
|
|
||||||
#define TIMER_START_CNT BIT(0)
|
|
||||||
#define TIMER_CNT_DISABLE BIT(1)
|
|
||||||
#define TIMER_WDT4_UNLOCK_PATTERN (0x10C + 0x80)
|
|
||||||
#define TIMER_MAGIC_PTRN 0xC45A
|
|
||||||
|
|
||||||
/*! I2S registers. */
|
/*! I2S registers. */
|
||||||
#define I2S1_CG 0x88
|
#define I2S1_CG 0x88
|
||||||
#define I2S1_CTRL 0xA0
|
#define I2S1_CTRL 0xA0
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2019-2020 CTCaer
|
* Copyright (c) 2019-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -17,8 +17,8 @@
|
|||||||
|
|
||||||
#include <soc/uart.h>
|
#include <soc/uart.h>
|
||||||
#include <soc/clock.h>
|
#include <soc/clock.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
/* UART A, B, C, D and E. */
|
/* UART A, B, C, D and E. */
|
||||||
static const u32 uart_baseoff[5] = { 0, 0x40, 0x200, 0x300, 0x400 };
|
static const u32 uart_baseoff[5] = { 0, 0x40, 0x200, 0x300, 0x400 };
|
||||||
|
@ -16,6 +16,9 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#include <mem/heap.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <storage/emmc.h>
|
#include <storage/emmc.h>
|
||||||
#include <storage/sdmmc.h>
|
#include <storage/sdmmc.h>
|
||||||
#include <storage/mmc.h>
|
#include <storage/mmc.h>
|
||||||
@ -23,8 +26,6 @@
|
|||||||
#include <storage/sd_def.h>
|
#include <storage/sd_def.h>
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
#include <gfx_utils.h>
|
#include <gfx_utils.h>
|
||||||
#include <mem/heap.h>
|
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
//#define DPRINTF(...) gfx_printf(__VA_ARGS__)
|
//#define DPRINTF(...) gfx_printf(__VA_ARGS__)
|
||||||
#define DPRINTF(...)
|
#define DPRINTF(...)
|
||||||
|
@ -27,8 +27,8 @@
|
|||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
//#define DPRINTF(...) gfx_printf(__VA_ARGS__)
|
//#define DPRINTF(...) gfx_printf(__VA_ARGS__)
|
||||||
//#define ERROR_EXTRA_PRINTING
|
//#define ERROR_EXTRA_PRINTING
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* Fan driver for Nintendo Switch
|
* Fan driver for Nintendo Switch
|
||||||
*
|
*
|
||||||
* Copyright (c) 2018-2021 CTCaer
|
* Copyright (c) 2018-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -24,8 +24,8 @@
|
|||||||
#include <soc/gpio.h>
|
#include <soc/gpio.h>
|
||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
void set_fan_duty(u32 duty)
|
void set_fan_duty(u32 duty)
|
||||||
{
|
{
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* USB Gadget HID driver for Tegra X1
|
* USB Gadget HID driver for Tegra X1
|
||||||
*
|
*
|
||||||
* Copyright (c) 2019-2020 CTCaer
|
* Copyright (c) 2019-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -23,8 +23,8 @@
|
|||||||
#include <input/joycon.h>
|
#include <input/joycon.h>
|
||||||
#include <input/touch.h>
|
#include <input/touch.h>
|
||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
|
|
||||||
|
@ -24,13 +24,13 @@
|
|||||||
#include <usb/usbd.h>
|
#include <usb/usbd.h>
|
||||||
#include <gfx_utils.h>
|
#include <gfx_utils.h>
|
||||||
#include <soc/hw_init.h>
|
#include <soc/hw_init.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <storage/sd.h>
|
#include <storage/sd.h>
|
||||||
#include <storage/sdmmc.h>
|
#include <storage/sdmmc.h>
|
||||||
#include <storage/sdmmc_driver.h>
|
#include <storage/sdmmc_driver.h>
|
||||||
#include <utils/btn.h>
|
#include <utils/btn.h>
|
||||||
#include <utils/sprintf.h>
|
#include <utils/sprintf.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* Enhanced USB Device (EDCI) driver for Tegra X1
|
* Enhanced USB Device (EDCI) driver for Tegra X1
|
||||||
*
|
*
|
||||||
* Copyright (c) 2019-2021 CTCaer
|
* Copyright (c) 2019-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -30,9 +30,9 @@
|
|||||||
#include <soc/gpio.h>
|
#include <soc/gpio.h>
|
||||||
#include <soc/pinmux.h>
|
#include <soc/pinmux.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/btn.h>
|
#include <utils/btn.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* eXtensible USB Device driver (XDCI) for Tegra X1
|
* eXtensible USB Device driver (XDCI) for Tegra X1
|
||||||
*
|
*
|
||||||
* Copyright (c) 2020-2021 CTCaer
|
* Copyright (c) 2020-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
@ -28,9 +28,9 @@
|
|||||||
#include <soc/clock.h>
|
#include <soc/clock.h>
|
||||||
#include <soc/fuse.h>
|
#include <soc/fuse.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/btn.h>
|
#include <utils/btn.h>
|
||||||
#include <utils/util.h>
|
|
||||||
|
|
||||||
#include <memory_map.h>
|
#include <memory_map.h>
|
||||||
|
|
||||||
|
@ -18,8 +18,8 @@
|
|||||||
#include "btn.h"
|
#include "btn.h"
|
||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
#include <soc/gpio.h>
|
#include <soc/gpio.h>
|
||||||
|
#include <soc/timer.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <utils/util.h>
|
|
||||||
#include <power/max77620.h>
|
#include <power/max77620.h>
|
||||||
|
|
||||||
u8 btn_read()
|
u8 btn_read()
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2018-2021 CTCaer
|
* Copyright (c) 2018-2022 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
Loading…
Reference in New Issue
Block a user