132 lines
6.0 KiB
C
Raw Normal View History

/*
* Copyright : (C) 2022 Phytium Information Technology, Inc.
* All Rights Reserved.
*
* This program is OPEN SOURCE software: you can redistribute it and/or modify it
* under the terms of the Phytium Public License as published by the Phytium Technology Co.,Ltd,
* either version 1.0 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the Phytium Public License for more details.
*
*
* FilePath: fsdio_selftest.c
* Date: 2022-06-02 11:49:44
* LastEditTime: 2022-06-02 11:49:45
* Description:  This file is for SDIO self-test function
*
* Modify History:
* Ver   Who        Date         Changes
* ----- ------     --------    --------------------------------------
* 1.1 zhugengyu 2022/6/6 modify according to tech manual.
*/
/***************************** Include Files *********************************/
#include "fio.h"
#include "fdebug.h"
#include "fassert.h"
#include "ftypes.h"
#include "fsdio_hw.h"
#include "fsdio.h"
/************************** Constant Definitions *****************************/
/**************************** Type Definitions *******************************/
/***************** Macros (Inline Functions) Definitions *********************/
#define FSDIO_DEBUG_TAG "FSDIO-TEST"
#define FSDIO_ERROR(format, ...) FT_DEBUG_PRINT_E(FSDIO_DEBUG_TAG, format, ##__VA_ARGS__)
#define FSDIO_WARN(format, ...) FT_DEBUG_PRINT_W(FSDIO_DEBUG_TAG, format, ##__VA_ARGS__)
#define FSDIO_INFO(format, ...) FT_DEBUG_PRINT_I(FSDIO_DEBUG_TAG, format, ##__VA_ARGS__)
#define FSDIO_DEBUG(format, ...) FT_DEBUG_PRINT_D(FSDIO_DEBUG_TAG, format, ##__VA_ARGS__)
#define FSDIO_DUMPER(base_addr, reg_off, reg_name) \
FSDIO_DEBUG("\t\t[%s]@0x%x\t=\t0x%x", reg_name, (reg_off), FSDIO_READ_REG((base_addr), (reg_off)))
/************************** Function Prototypes ******************************/
/*****************************************************************************/
/**
* @name: FSdioDumpRegister
* @msg: Dump all register value of SDIO instance
* @return {NONE}
* @param {uintptr} base_addr, base address of SDIO controller
*/
void FSdioDumpRegister(uintptr base_addr)
{
FSDIO_DEBUG("Dump register info @0x%x", base_addr);
FSDIO_DUMPER(base_addr, FSDIO_CNTRL_OFFSET, "cntrl");
FSDIO_DUMPER(base_addr, FSDIO_PWREN_OFFSET, "pwren");
FSDIO_DUMPER(base_addr, FSDIO_CLKDIV_OFFSET, "clkdiv");
FSDIO_DUMPER(base_addr, FSDIO_CLKENA_OFFSET, "clkena");
FSDIO_DUMPER(base_addr, FSDIO_TMOUT_OFFSET, "tmout");
FSDIO_DUMPER(base_addr, FSDIO_CTYPE_OFFSET, "ctype");
FSDIO_DUMPER(base_addr, FSDIO_BLK_SIZ_OFFSET, "blksz");
FSDIO_DUMPER(base_addr, FSDIO_BYT_CNT_OFFSET, "blkcnt");
FSDIO_DUMPER(base_addr, FSDIO_INT_MASK_OFFSET, "intmask");
FSDIO_DUMPER(base_addr, FSDIO_CMD_ARG_OFFSET, "cmdarg");
FSDIO_DUMPER(base_addr, FSDIO_CMD_OFFSET, "cmd");
FSDIO_DUMPER(base_addr, FSDIO_RESP0_OFFSET, "resp0");
FSDIO_DUMPER(base_addr, FSDIO_RESP1_OFFSET, "reps1");
FSDIO_DUMPER(base_addr, FSDIO_RESP2_OFFSET, "resp2");
FSDIO_DUMPER(base_addr, FSDIO_RESP3_OFFSET, "resp3");
FSDIO_DUMPER(base_addr, FSDIO_MASKED_INTS_OFFSET, "maskints");
FSDIO_DUMPER(base_addr, FSDIO_RAW_INTS_OFFSET, "rawints");
FSDIO_DUMPER(base_addr, FSDIO_STATUS_OFFSET, "status");
FSDIO_DUMPER(base_addr, FSDIO_FIFOTH_OFFSET, "fifoth");
FSDIO_DUMPER(base_addr, FSDIO_CARD_DETECT_OFFSET, "carddet");
FSDIO_DUMPER(base_addr, FSDIO_CARD_WRTPRT_OFFSET, "wrtprt");
FSDIO_DUMPER(base_addr, FSDIO_GPIO_OFFSET, "gpio");
FSDIO_DUMPER(base_addr, FSDIO_TRAN_CARD_CNT_OFFSET, "trans_cardcnt");
FSDIO_DUMPER(base_addr, FSDIO_TRAN_FIFO_CNT_OFFSET, "trans_fifocnt");
FSDIO_DUMPER(base_addr, FSDIO_DEBNCE_OFFSET, "debnce");
FSDIO_DUMPER(base_addr, FSDIO_UID_OFFSET, "uid");
FSDIO_DUMPER(base_addr, FSDIO_VID_OFFSET, "vid");
FSDIO_DUMPER(base_addr, FSDIO_HWCONF_OFFSET, "hwconf");
FSDIO_DUMPER(base_addr, FSDIO_UHS_REG_OFFSET, "uhsreg");
FSDIO_DUMPER(base_addr, FSDIO_CARD_RESET_OFFSET, "cardreset");
FSDIO_DUMPER(base_addr, FSDIO_BUS_MODE_OFFSET, "busmode");
FSDIO_DUMPER(base_addr, FSDIO_DESC_LIST_ADDRL_OFFSET, "descaddrl");
FSDIO_DUMPER(base_addr, FSDIO_DESC_LIST_ADDRH_OFFSET, "descaddrh");
FSDIO_DUMPER(base_addr, FSDIO_DMAC_STATUS_OFFSET, "dmacstatus");
FSDIO_DUMPER(base_addr, FSDIO_DMAC_INT_EN_OFFSET, "dmacinten");
FSDIO_DUMPER(base_addr, FSDIO_CUR_DESC_ADDRL_OFFSET, "curdescaddrl");
FSDIO_DUMPER(base_addr, FSDIO_CUR_DESC_ADDRH_OFFSET, "curdescaddrh");
FSDIO_DUMPER(base_addr, FSDIO_CUR_BUF_ADDRL_OFFSET, "curbufaddrl");
FSDIO_DUMPER(base_addr, FSDIO_CUR_BUF_ADDRH_OFFSET, "curbufaddrh");
FSDIO_DUMPER(base_addr, FSDIO_CARD_THRCTL_OFFSET, "card_thrctl");
FSDIO_DUMPER(base_addr, FSDIO_UHS_REG_EXT_OFFSET, "uhsregext");
FSDIO_DUMPER(base_addr, FSDIO_EMMC_DDR_REG_OFFSET, "emmcddr");
FSDIO_DUMPER(base_addr, FSDIO_ENABLE_SHIFT_OFFSET, "enableshift");
}
/**
* @name: FSdioDumpCmdInfo
* @msg: Dump command and data info
* @return {NONE}
* @param {FSdioCmdData *const} cmd_data, info data of SD command and data
*/
void FSdioDumpCmdInfo(FSdioCmdData *const cmd_data)
{
FSDIO_DEBUG("cmd struct @%p", cmd_data);
FSDIO_DEBUG(" opcode: %d", cmd_data->cmdidx);
FSDIO_DEBUG(" arg: 0x%x", cmd_data->cmdarg);
FSDIO_DEBUG(" resp@%p: 0x%x 0x%x 0x%x 0x%x",
cmd_data->response,
cmd_data->response[0],
cmd_data->response[1],
cmd_data->response[2],
cmd_data->response[3]);
FSDIO_DEBUG(" flag: 0x%x", cmd_data->flag);
FSDIO_DEBUG(" data @%p", cmd_data->data_p);
if (cmd_data->data_p)
{
FSDIO_DEBUG(" buf: %p, len: %d", cmd_data->data_p->buf,
cmd_data->data_p->datalen);
FSDIO_DEBUG(" blk sz: %d", cmd_data->data_p->blksz);
FSDIO_DEBUG(" blk cnt: %d", cmd_data->data_p->blkcnt);
}
}