summaryrefslogtreecommitdiffstats
path: root/arch/ppc/include/asm/fsl_ddr_dimm_params.h
blob: 9e6f6b4d34204711f6d7e57df22f5f359ed78f44 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 * Copyright 2008 Freescale Semiconductor, Inc.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * Version 2 as published by the Free Software Foundation.
 */

#ifndef DDR2_DIMM_PARAMS_H
#define DDR2_DIMM_PARAMS_H

#define EDC_ECC		2

/* Parameters for a DDR2 dimm computed from the SPD */
struct dimm_params_s {
	char mpart[19];
	uint32_t n_ranks;
	uint64_t rank_density;
	uint64_t capacity;
	uint32_t data_width;
	uint32_t primary_sdram_width;
	uint32_t ec_sdram_width;
	uint32_t registered_dimm;
	uint32_t device_width;
	/* SDRAM device parameters */
	uint32_t n_row_addr;
	uint32_t n_col_addr;
	uint32_t edc_config;		/* 0 = none, 1 = parity, 2 = ECC */
	uint32_t n_banks_per_sdram_device;
	uint32_t burst_lengths_bitmask;	/* BL=4 bit 2, BL=8 = bit 3 */
	uint32_t row_density;
	uint64_t base_address;
	uint32_t mirrored_dimm;
	uint32_t mtb_ps;
	uint32_t ftb_10th_ps;
	uint32_t taa_ps;
	uint32_t tfaw_ps;
	/* SDRAM clock periods */
	uint32_t tCKmin_X_ps;
	uint32_t tCKmin_X_minus_1_ps;
	uint32_t tCKmin_X_minus_2_ps;
	uint32_t tCKmax_ps;
	/* SPD-defined CAS latencies */
	uint32_t caslat_X;
	uint32_t caslat_X_minus_1;
	uint32_t caslat_X_minus_2;
	uint32_t caslat_lowest_derated;
	/* basic timing parameters */
	uint32_t tRCD_ps;
	uint32_t tRP_ps;
	uint32_t tRAS_ps;
	uint32_t tWR_ps;	/* maximum = 63750 ps */
	uint32_t tWTR_ps;	/* maximum = 63750 ps */
	uint32_t tRFC_ps;	/* max = 255 ns + 256 ns + .75 ns = 511750 ps */
	uint32_t tRRD_ps;	/* maximum = 63750 ps */
	uint32_t tRC_ps;	/* maximum = 254 ns + .75 ns = 254750 ps */
	uint32_t refresh_rate_ps;
	uint32_t extended_op_srt;
	uint32_t tIS_ps;	/* byte 32, spd->ca_setup */
	uint32_t tIH_ps;	/* byte 33, spd->ca_hold */
	uint32_t tDS_ps;	/* byte 34, spd->data_setup */
	uint32_t tDH_ps;	/* byte 35, spd->data_hold */
	uint32_t tRTP_ps;	/* byte 38, spd->trtp */
	uint32_t tDQSQ_max_ps;	/* byte 44, spd->tdqsq */
	uint32_t tQHS_ps;	/* byte 45, spd->tqhs */
	uint32_t rcw[16];
};

#endif