50a4e8c662
Co-authored-by: 朱耿宇 <zhugengyu@phytium.com.cn>
132 lines
6.0 KiB
C
132 lines
6.0 KiB
C
/*
|
||
* 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);
|
||
}
|
||
} |