nand: zynq: Send address cycles as per onfi parameter page
Send address cycles as per value read from onfi parameter page for Read and write commands instead of using a hard coded value. This may vary for different parts and hence use it from onfi parameter page value. Signed-off-by: Siva Durga Prasad Paladugu <siva.durga.paladugu@xilinx.com> Signed-off-by: Michal Simek <michal.simek@xilinx.com>
This commit is contained in:
parent
9ca8388059
commit
9fdde6c4bb
@ -84,6 +84,9 @@
|
||||
#define ZYNQ_NAND_ECC_BUSY (1 << 6) /* ECC block is busy */
|
||||
#define ZYNQ_NAND_ECC_MASK 0x00FFFFFF /* ECC value mask */
|
||||
|
||||
#define ZYNQ_NAND_ROW_ADDR_CYCL_MASK 0x0F
|
||||
#define ZYNQ_NAND_COL_ADDR_CYCL_MASK 0xF0
|
||||
|
||||
#define ZYNQ_NAND_MIO_NUM_NAND_8BIT 13
|
||||
#define ZYNQ_NAND_MIO_NUM_NAND_16BIT 8
|
||||
|
||||
@ -778,6 +781,7 @@ static void zynq_nand_cmd_function(struct mtd_info *mtd, unsigned int command,
|
||||
{
|
||||
struct nand_chip *chip = mtd->priv;
|
||||
const struct zynq_nand_command_format *curr_cmd = NULL;
|
||||
u8 addr_cycles = 0;
|
||||
struct zynq_nand_info *xnand = (struct zynq_nand_info *)chip->priv;
|
||||
void *cmd_addr;
|
||||
unsigned long cmd_data = 0;
|
||||
@ -828,8 +832,18 @@ static void zynq_nand_cmd_function(struct mtd_info *mtd, unsigned int command,
|
||||
else
|
||||
end_cmd = curr_cmd->end_cmd;
|
||||
|
||||
if (command == NAND_CMD_READ0 ||
|
||||
command == NAND_CMD_SEQIN) {
|
||||
addr_cycles = chip->onfi_params.addr_cycles &
|
||||
ZYNQ_NAND_ROW_ADDR_CYCL_MASK;
|
||||
addr_cycles += ((chip->onfi_params.addr_cycles &
|
||||
ZYNQ_NAND_COL_ADDR_CYCL_MASK) >> 4);
|
||||
} else {
|
||||
addr_cycles = curr_cmd->addr_cycles;
|
||||
}
|
||||
|
||||
cmd_phase_addr = (unsigned long)xnand->nand_base |
|
||||
(curr_cmd->addr_cycles << ADDR_CYCLES_SHIFT) |
|
||||
(addr_cycles << ADDR_CYCLES_SHIFT) |
|
||||
(end_cmd_valid << END_CMD_VALID_SHIFT) |
|
||||
(COMMAND_PHASE) |
|
||||
(end_cmd << END_CMD_SHIFT) |
|
||||
|
Loading…
Reference in New Issue
Block a user