mirror of
https://github.com/CTCaer/hekate
synced 2024-11-05 03:16:35 +00:00
132 lines
3.4 KiB
C
132 lines
3.4 KiB
C
/*
|
|
* Copyright (c) 2018 naehrwert
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef _SDMMC_T210_H_
|
|
#define _SDMMC_T210_H_
|
|
|
|
#include "../utils/types.h"
|
|
|
|
#define TEGRA_MMC_PWRCTL_SD_BUS_POWER 0x1
|
|
#define TEGRA_MMC_PWRCTL_SD_BUS_VOLTAGE_V1_8 0xA
|
|
#define TEGRA_MMC_PWRCTL_SD_BUS_VOLTAGE_V3_0 0xC
|
|
#define TEGRA_MMC_PWRCTL_SD_BUS_VOLTAGE_V3_3 0xE
|
|
#define TEGRA_MMC_PWRCTL_SD_BUS_VOLTAGE_MASK 0xF1
|
|
|
|
#define TEGRA_MMC_HOSTCTL_1BIT 0x00
|
|
#define TEGRA_MMC_HOSTCTL_4BIT 0x02
|
|
#define TEGRA_MMC_HOSTCTL_8BIT 0x20
|
|
|
|
#define TEGRA_MMC_CLKCON_INTERNAL_CLOCK_ENABLE 0x1
|
|
#define TEGRA_MMC_CLKCON_INTERNAL_CLOCK_STABLE 0x2
|
|
#define TEGRA_MMC_CLKCON_SD_CLOCK_ENABLE 0x4
|
|
#define TEGRA_MMC_CLKCON_CLKGEN_SELECT 0x20
|
|
|
|
#define TEGRA_MMC_SWRST_SW_RESET_FOR_ALL 0x1
|
|
#define TEGRA_MMC_SWRST_SW_RESET_FOR_CMD_LINE 0x2
|
|
#define TEGRA_MMC_SWRST_SW_RESET_FOR_DAT_LINE 0x4
|
|
|
|
#define TEGRA_MMC_TRNMOD_DMA_ENABLE 0x1
|
|
#define TEGRA_MMC_TRNMOD_BLOCK_COUNT_ENABLE 0x2
|
|
#define TEGRA_MMC_TRNMOD_AUTO_CMD12 0x4
|
|
#define TEGRA_MMC_TRNMOD_DATA_XFER_DIR_SEL_WRITE 0x0
|
|
#define TEGRA_MMC_TRNMOD_DATA_XFER_DIR_SEL_READ 0x10
|
|
#define TEGRA_MMC_TRNMOD_MULTI_BLOCK_SELECT 0x20
|
|
|
|
#define TEGRA_MMC_TRNMOD_CMD_CRC_CHECK 0x8
|
|
#define TEGRA_MMC_TRNMOD_CMD_INDEX_CHECK 0x10
|
|
#define TEGRA_MMC_TRNMOD_DATA_PRESENT_SELECT_DATA_TRANSFER 0x20
|
|
|
|
#define TEGRA_MMC_CMDREG_RESP_TYPE_SELECT_MASK 0x3
|
|
#define TEGRA_MMC_CMDREG_RESP_TYPE_SELECT_NO_RESPONSE 0x0
|
|
#define TEGRA_MMC_CMDREG_RESP_TYPE_SELECT_LENGTH_136 0x1
|
|
#define TEGRA_MMC_CMDREG_RESP_TYPE_SELECT_LENGTH_48 0x2
|
|
#define TEGRA_MMC_CMDREG_RESP_TYPE_SELECT_LENGTH_48_BUSY 0x3
|
|
|
|
#define TEGRA_MMC_NORINTSTS_CMD_COMPLETE 0x1
|
|
#define TEGRA_MMC_NORINTSTS_XFER_COMPLETE 0x2
|
|
#define TEGRA_MMC_NORINTSTS_DMA_INTERRUPT 0x8
|
|
#define TEGRA_MMC_NORINTSTS_ERR_INTERRUPT 0x8000
|
|
#define TEGRA_MMC_NORINTSTS_CMD_TIMEOUT 0x10000
|
|
|
|
#define TEGRA_MMC_NORINTSTSEN_BUFFER_READ_READY 0x20
|
|
|
|
typedef struct _t210_sdmmc_t
|
|
{
|
|
vu32 sysad;
|
|
vu16 blksize;
|
|
vu16 blkcnt;
|
|
vu32 argument;
|
|
vu16 trnmod;
|
|
vu16 cmdreg;
|
|
vu32 rspreg0;
|
|
vu32 rspreg1;
|
|
vu32 rspreg2;
|
|
vu32 rspreg3;
|
|
vu32 bdata;
|
|
vu32 prnsts;
|
|
vu8 hostctl;
|
|
vu8 pwrcon;
|
|
vu8 blkgap;
|
|
vu8 wakcon;
|
|
vu16 clkcon;
|
|
vu8 timeoutcon;
|
|
vu8 swrst;
|
|
vu16 norintsts;
|
|
vu16 errintsts;
|
|
vu16 norintstsen;
|
|
vu16 errintstsen;
|
|
vu16 norintsigen;
|
|
vu16 errintsigen;
|
|
vu16 acmd12errsts;
|
|
vu16 hostctl2;
|
|
vu32 capareg;
|
|
vu32 capareg_1;
|
|
vu32 maxcurr;
|
|
vu8 res3[4];
|
|
vu16 setacmd12err;
|
|
vu16 setinterr;
|
|
vu8 admaerr;
|
|
vu8 res4[3];
|
|
vu32 admaaddr;
|
|
vu32 admaaddr_hi;
|
|
vu8 res5[156];
|
|
vu16 slotintstatus;
|
|
vu16 hcver;
|
|
vu32 venclkctl;
|
|
vu32 venspictl;
|
|
vu32 venspiintsts;
|
|
vu32 venceatactl;
|
|
vu32 venbootctl;
|
|
vu32 venbootacktout;
|
|
vu32 venbootdattout;
|
|
vu32 vendebouncecnt;
|
|
vu32 venmiscctl;
|
|
vu32 res6[34];
|
|
vu32 veniotrimctl;
|
|
vu32 vendllcal;
|
|
vu8 res7[8];
|
|
vu32 dllcfgstatus;
|
|
vu32 ventunctl0;
|
|
vu32 field_1C4;
|
|
vu8 field_1C8[24];
|
|
vu32 sdmemcmppadctl;
|
|
vu32 autocalcfg;
|
|
vu32 autocalintval;
|
|
vu32 autocalsts;
|
|
vu32 iospare;
|
|
} t210_sdmmc_t;
|
|
|
|
#endif
|