OpenOCD
orion.c
Go to the documentation of this file.
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 
3 /***************************************************************************
4  * Copyright (C) 2009 by Marvell Semiconductors, Inc. *
5  * Written by Nicolas Pitre <nico at marvell.com> *
6  ***************************************************************************/
7 
8 /*
9  * NAND controller interface for Marvell Orion/Kirkwood SoCs.
10  */
11 
12 #ifdef HAVE_CONFIG_H
13 #include "config.h"
14 #endif
15 
16 #include "imp.h"
17 #include "arm_io.h"
18 #include <target/arm.h>
19 
21  struct arm_nand_data io;
22 
23  uint32_t cmd;
24  uint32_t addr;
25  uint32_t data;
26 };
27 
28 #define CHECK_HALTED \
29  do { \
30  if (target->state != TARGET_HALTED) { \
31  LOG_ERROR("NAND flash access requires halted target"); \
32  return ERROR_NAND_OPERATION_FAILED; \
33  } \
34  } while (0)
35 
36 static int orion_nand_command(struct nand_device *nand, uint8_t command)
37 {
38  struct orion_nand_controller *hw = nand->controller_priv;
39  struct target *target = nand->target;
40 
43  return ERROR_OK;
44 }
45 
46 static int orion_nand_address(struct nand_device *nand, uint8_t address)
47 {
48  struct orion_nand_controller *hw = nand->controller_priv;
49  struct target *target = nand->target;
50 
53  return ERROR_OK;
54 }
55 
56 static int orion_nand_read(struct nand_device *nand, void *data)
57 {
58  struct orion_nand_controller *hw = nand->controller_priv;
59  struct target *target = nand->target;
60 
62  target_read_u8(target, hw->data, data);
63  return ERROR_OK;
64 }
65 
66 static int orion_nand_write(struct nand_device *nand, uint16_t data)
67 {
68  struct orion_nand_controller *hw = nand->controller_priv;
69  struct target *target = nand->target;
70 
72  target_write_u8(target, hw->data, data);
73  return ERROR_OK;
74 }
75 
76 static int orion_nand_slow_block_write(struct nand_device *nand, uint8_t *data, int size)
77 {
78  while (size--)
79  orion_nand_write(nand, *data++);
80  return ERROR_OK;
81 }
82 
83 static int orion_nand_fast_block_write(struct nand_device *nand, uint8_t *data, int size)
84 {
85  struct orion_nand_controller *hw = nand->controller_priv;
86  int retval;
87 
88  hw->io.chunk_size = nand->page_size;
89 
90  retval = arm_nandwrite(&hw->io, data, size);
91  if (retval == ERROR_NAND_NO_BUFFER)
92  retval = orion_nand_slow_block_write(nand, data, size);
93 
94  return retval;
95 }
96 
97 static int orion_nand_reset(struct nand_device *nand)
98 {
99  return orion_nand_command(nand, NAND_CMD_RESET);
100 }
101 
102 NAND_DEVICE_COMMAND_HANDLER(orion_nand_device_command)
103 {
104  struct orion_nand_controller *hw;
105  uint32_t base;
106  uint8_t ale, cle;
107 
108  if (CMD_ARGC != 3)
110 
111  hw = calloc(1, sizeof(*hw));
112  if (!hw) {
113  LOG_ERROR("no memory for nand controller");
115  }
116 
117  nand->controller_priv = hw;
118 
119  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[2], base);
120  cle = 0;
121  ale = 1;
122 
123  hw->data = base;
124  hw->cmd = base + (1 << cle);
125  hw->addr = base + (1 << ale);
126 
127  hw->io.target = nand->target;
128  hw->io.data = hw->data;
129  hw->io.op = ARM_NAND_NONE;
130 
131  return ERROR_OK;
132 }
133 
134 static int orion_nand_init(struct nand_device *nand)
135 {
136  return ERROR_OK;
137 }
138 
140  .name = "orion",
141  .usage = "<target_id> <NAND_address>",
142  .command = orion_nand_command,
143  .address = orion_nand_address,
144  .read_data = orion_nand_read,
145  .write_data = orion_nand_write,
146  .write_block_data = orion_nand_fast_block_write,
147  .reset = orion_nand_reset,
148  .nand_device_command = orion_nand_device_command,
149  .init = orion_nand_init,
150 };
Holds the interface to ARM cores.
int arm_nandwrite(struct arm_nand_data *nand, uint8_t *data, int size)
ARM-specific bulk write from buffer to address of 8-bit wide NAND.
Definition: arm_io.c:80
@ ARM_NAND_NONE
No operation performed.
Definition: arm_io.h:13
#define CMD_ARGV
Use this macro to access the arguments for the command being handled, rather than accessing the varia...
Definition: command.h:156
#define ERROR_COMMAND_SYNTAX_ERROR
Definition: command.h:400
#define CMD_ARGC
Use this macro to access the number of arguments for the command being handled, rather than accessing...
Definition: command.h:151
#define COMMAND_PARSE_NUMBER(type, in, out)
parses the string in into out as a type, or prints a command error and passes the error code to the c...
Definition: command.h:440
uint32_t size
Size of dw_spi_transaction::buffer.
Definition: dw-spi-helper.h:4
uint32_t address
Starting address. Sector aligned.
Definition: dw-spi-helper.h:0
#define LOG_ERROR(expr ...)
Definition: log.h:134
#define ERROR_OK
Definition: log.h:169
#define ERROR_NAND_NO_BUFFER
Definition: nand/core.h:222
@ NAND_CMD_RESET
Definition: nand/core.h:152
#define ERROR_NAND_DEVICE_INVALID
Definition: nand/core.h:216
static int orion_nand_read(struct nand_device *nand, void *data)
Definition: orion.c:56
static int orion_nand_write(struct nand_device *nand, uint16_t data)
Definition: orion.c:66
static int orion_nand_slow_block_write(struct nand_device *nand, uint8_t *data, int size)
Definition: orion.c:76
static int orion_nand_command(struct nand_device *nand, uint8_t command)
Definition: orion.c:36
static int orion_nand_fast_block_write(struct nand_device *nand, uint8_t *data, int size)
Definition: orion.c:83
NAND_DEVICE_COMMAND_HANDLER(orion_nand_device_command)
Definition: orion.c:102
#define CHECK_HALTED
Definition: orion.c:28
static int orion_nand_address(struct nand_device *nand, uint8_t address)
Definition: orion.c:46
static int orion_nand_reset(struct nand_device *nand)
Definition: orion.c:97
static int orion_nand_init(struct nand_device *nand)
Definition: orion.c:134
The arm_nand_data struct is used for defining NAND I/O operations on an ARM core.
Definition: arm_io.h:22
struct target * target
Target is proxy for some ARM core.
Definition: arm_io.h:24
unsigned int chunk_size
The chunk size is the page size or ECC chunk.
Definition: arm_io.h:30
enum arm_nand_op op
Last operation executed using this struct.
Definition: arm_io.h:36
uint32_t data
Where data is read from or written to.
Definition: arm_io.h:33
void * controller_priv
Definition: nand/core.h:51
int page_size
Definition: nand/core.h:56
struct target * target
Definition: nand/core.h:49
Interface for NAND flash controllers.
Definition: nand/driver.h:23
uint32_t cmd
Definition: orion.c:23
uint32_t data
Definition: orion.c:25
uint32_t addr
Definition: orion.c:24
struct arm_nand_data io
Definition: orion.c:21
Definition: target.h:119
int target_write_u8(struct target *target, target_addr_t address, uint8_t value)
Definition: target.c:2692
int target_read_u8(struct target *target, target_addr_t address, uint8_t *value)
Definition: target.c:2607