Skip to content
Snippets Groups Projects
Commit 58c86c7d authored by Ilya Ledvich's avatar Ilya Ledvich Committed by Tom Rini
Browse files

am33xx: fix the ddr_cmdtctrl structure


Fix the wrong mapping between the DDR I/O control registers on AM33XX
SoCs and the software representation in the SPL code.
The most recent public TRM defines the following DDR I/O control registers
offsets:
 * ddr_cmd0_ioctrl : offset 0x44E11404
 * ddr_cmd1_ioctrl : offset 0x44E11408
 * ddr_cmd2_ioctrl : offset 0x44E1140C
 * ddr_data0_ioctrl: offset 0x44E11440
 * ddr_data1_ioctrl: offset 0x44E11444

While the struct ddr_cmdtctrl has also some reserved bits in the beginning.
The struct is mapped to the address 0x44E11404. As a result "cm0ioctl" points
to the ddr_cmd1_ioctrl register, "cm1ioctl" to the ddr_cmd2_ioctrl and etc.
Registers ddr_cmd0_ioctrl and ddr_data0_ioctrl are never configured because
of this mapping mismatch.

Signed-off-by: default avatarIlya Ledvich <ilya@compulab.co.il>
Reviewed-by: default avatarPeter Korsgaard <jacmet@sunsite.dk>
parent b0857c45
No related branches found
No related tags found
No related merge requests found
...@@ -284,7 +284,6 @@ void config_ddr_data(const struct ddr_data *data, int nr); ...@@ -284,7 +284,6 @@ void config_ddr_data(const struct ddr_data *data, int nr);
* This structure represents the DDR io control on AM33XX devices. * This structure represents the DDR io control on AM33XX devices.
*/ */
struct ddr_cmdtctrl { struct ddr_cmdtctrl {
unsigned int resv1[1];
unsigned int cm0ioctl; unsigned int cm0ioctl;
unsigned int cm1ioctl; unsigned int cm1ioctl;
unsigned int cm2ioctl; unsigned int cm2ioctl;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment