18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * Register bitfield descriptions for Pondicherry2 memory controller.
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (c) 2016, Intel Corporation.
68c2ecf20Sopenharmony_ci */
78c2ecf20Sopenharmony_ci
88c2ecf20Sopenharmony_ci#ifndef _PND2_REGS_H
98c2ecf20Sopenharmony_ci#define _PND2_REGS_H
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_cistruct b_cr_touud_lo_pci {
128c2ecf20Sopenharmony_ci	u32	lock : 1;
138c2ecf20Sopenharmony_ci	u32	reserved_1 : 19;
148c2ecf20Sopenharmony_ci	u32	touud : 12;
158c2ecf20Sopenharmony_ci};
168c2ecf20Sopenharmony_ci
178c2ecf20Sopenharmony_ci#define b_cr_touud_lo_pci_port 0x4c
188c2ecf20Sopenharmony_ci#define b_cr_touud_lo_pci_offset 0xa8
198c2ecf20Sopenharmony_ci#define b_cr_touud_lo_pci_r_opcode 0x04
208c2ecf20Sopenharmony_ci
218c2ecf20Sopenharmony_cistruct b_cr_touud_hi_pci {
228c2ecf20Sopenharmony_ci	u32	touud : 7;
238c2ecf20Sopenharmony_ci	u32	reserved_0 : 25;
248c2ecf20Sopenharmony_ci};
258c2ecf20Sopenharmony_ci
268c2ecf20Sopenharmony_ci#define b_cr_touud_hi_pci_port 0x4c
278c2ecf20Sopenharmony_ci#define b_cr_touud_hi_pci_offset 0xac
288c2ecf20Sopenharmony_ci#define b_cr_touud_hi_pci_r_opcode 0x04
298c2ecf20Sopenharmony_ci
308c2ecf20Sopenharmony_cistruct b_cr_tolud_pci {
318c2ecf20Sopenharmony_ci	u32	lock : 1;
328c2ecf20Sopenharmony_ci	u32	reserved_0 : 19;
338c2ecf20Sopenharmony_ci	u32	tolud : 12;
348c2ecf20Sopenharmony_ci};
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_ci#define b_cr_tolud_pci_port 0x4c
378c2ecf20Sopenharmony_ci#define b_cr_tolud_pci_offset 0xbc
388c2ecf20Sopenharmony_ci#define b_cr_tolud_pci_r_opcode 0x04
398c2ecf20Sopenharmony_ci
408c2ecf20Sopenharmony_cistruct b_cr_mchbar_lo_pci {
418c2ecf20Sopenharmony_ci	u32 enable : 1;
428c2ecf20Sopenharmony_ci	u32 pad_3_1 : 3;
438c2ecf20Sopenharmony_ci	u32 pad_14_4: 11;
448c2ecf20Sopenharmony_ci	u32 base: 17;
458c2ecf20Sopenharmony_ci};
468c2ecf20Sopenharmony_ci
478c2ecf20Sopenharmony_cistruct b_cr_mchbar_hi_pci {
488c2ecf20Sopenharmony_ci	u32 base : 7;
498c2ecf20Sopenharmony_ci	u32 pad_31_7 : 25;
508c2ecf20Sopenharmony_ci};
518c2ecf20Sopenharmony_ci
528c2ecf20Sopenharmony_ci/* Symmetric region */
538c2ecf20Sopenharmony_cistruct b_cr_slice_channel_hash {
548c2ecf20Sopenharmony_ci	u64	slice_1_disabled : 1;
558c2ecf20Sopenharmony_ci	u64	hvm_mode : 1;
568c2ecf20Sopenharmony_ci	u64	interleave_mode : 2;
578c2ecf20Sopenharmony_ci	u64	slice_0_mem_disabled : 1;
588c2ecf20Sopenharmony_ci	u64	reserved_0 : 1;
598c2ecf20Sopenharmony_ci	u64	slice_hash_mask : 14;
608c2ecf20Sopenharmony_ci	u64	reserved_1 : 11;
618c2ecf20Sopenharmony_ci	u64	enable_pmi_dual_data_mode : 1;
628c2ecf20Sopenharmony_ci	u64	ch_1_disabled : 1;
638c2ecf20Sopenharmony_ci	u64	reserved_2 : 1;
648c2ecf20Sopenharmony_ci	u64	sym_slice0_channel_enabled : 2;
658c2ecf20Sopenharmony_ci	u64	sym_slice1_channel_enabled : 2;
668c2ecf20Sopenharmony_ci	u64	ch_hash_mask : 14;
678c2ecf20Sopenharmony_ci	u64	reserved_3 : 11;
688c2ecf20Sopenharmony_ci	u64	lock : 1;
698c2ecf20Sopenharmony_ci};
708c2ecf20Sopenharmony_ci
718c2ecf20Sopenharmony_ci#define b_cr_slice_channel_hash_port 0x4c
728c2ecf20Sopenharmony_ci#define b_cr_slice_channel_hash_offset 0x4c58
738c2ecf20Sopenharmony_ci#define b_cr_slice_channel_hash_r_opcode 0x06
748c2ecf20Sopenharmony_ci
758c2ecf20Sopenharmony_cistruct b_cr_mot_out_base_mchbar {
768c2ecf20Sopenharmony_ci	u32	reserved_0 : 14;
778c2ecf20Sopenharmony_ci	u32	mot_out_base : 15;
788c2ecf20Sopenharmony_ci	u32	reserved_1 : 1;
798c2ecf20Sopenharmony_ci	u32	tr_en : 1;
808c2ecf20Sopenharmony_ci	u32	imr_en : 1;
818c2ecf20Sopenharmony_ci};
828c2ecf20Sopenharmony_ci
838c2ecf20Sopenharmony_ci#define b_cr_mot_out_base_mchbar_port 0x4c
848c2ecf20Sopenharmony_ci#define b_cr_mot_out_base_mchbar_offset 0x6af0
858c2ecf20Sopenharmony_ci#define b_cr_mot_out_base_mchbar_r_opcode 0x00
868c2ecf20Sopenharmony_ci
878c2ecf20Sopenharmony_cistruct b_cr_mot_out_mask_mchbar {
888c2ecf20Sopenharmony_ci	u32	reserved_0 : 14;
898c2ecf20Sopenharmony_ci	u32	mot_out_mask : 15;
908c2ecf20Sopenharmony_ci	u32	reserved_1 : 1;
918c2ecf20Sopenharmony_ci	u32	ia_iwb_en : 1;
928c2ecf20Sopenharmony_ci	u32	gt_iwb_en : 1;
938c2ecf20Sopenharmony_ci};
948c2ecf20Sopenharmony_ci
958c2ecf20Sopenharmony_ci#define b_cr_mot_out_mask_mchbar_port 0x4c
968c2ecf20Sopenharmony_ci#define b_cr_mot_out_mask_mchbar_offset 0x6af4
978c2ecf20Sopenharmony_ci#define b_cr_mot_out_mask_mchbar_r_opcode 0x00
988c2ecf20Sopenharmony_ci
998c2ecf20Sopenharmony_cistruct b_cr_asym_mem_region0_mchbar {
1008c2ecf20Sopenharmony_ci	u32	pad : 4;
1018c2ecf20Sopenharmony_ci	u32	slice0_asym_base : 11;
1028c2ecf20Sopenharmony_ci	u32	pad_18_15 : 4;
1038c2ecf20Sopenharmony_ci	u32	slice0_asym_limit : 11;
1048c2ecf20Sopenharmony_ci	u32	slice0_asym_channel_select : 1;
1058c2ecf20Sopenharmony_ci	u32	slice0_asym_enable : 1;
1068c2ecf20Sopenharmony_ci};
1078c2ecf20Sopenharmony_ci
1088c2ecf20Sopenharmony_ci#define b_cr_asym_mem_region0_mchbar_port 0x4c
1098c2ecf20Sopenharmony_ci#define b_cr_asym_mem_region0_mchbar_offset 0x6e40
1108c2ecf20Sopenharmony_ci#define b_cr_asym_mem_region0_mchbar_r_opcode 0x00
1118c2ecf20Sopenharmony_ci
1128c2ecf20Sopenharmony_cistruct b_cr_asym_mem_region1_mchbar {
1138c2ecf20Sopenharmony_ci	u32	pad : 4;
1148c2ecf20Sopenharmony_ci	u32	slice1_asym_base : 11;
1158c2ecf20Sopenharmony_ci	u32	pad_18_15 : 4;
1168c2ecf20Sopenharmony_ci	u32	slice1_asym_limit : 11;
1178c2ecf20Sopenharmony_ci	u32	slice1_asym_channel_select : 1;
1188c2ecf20Sopenharmony_ci	u32	slice1_asym_enable : 1;
1198c2ecf20Sopenharmony_ci};
1208c2ecf20Sopenharmony_ci
1218c2ecf20Sopenharmony_ci#define b_cr_asym_mem_region1_mchbar_port 0x4c
1228c2ecf20Sopenharmony_ci#define b_cr_asym_mem_region1_mchbar_offset 0x6e44
1238c2ecf20Sopenharmony_ci#define b_cr_asym_mem_region1_mchbar_r_opcode 0x00
1248c2ecf20Sopenharmony_ci
1258c2ecf20Sopenharmony_ci/* Some bit fields moved in above two structs on Denverton */
1268c2ecf20Sopenharmony_cistruct b_cr_asym_mem_region_denverton {
1278c2ecf20Sopenharmony_ci	u32	pad : 4;
1288c2ecf20Sopenharmony_ci	u32	slice_asym_base : 8;
1298c2ecf20Sopenharmony_ci	u32	pad_19_12 : 8;
1308c2ecf20Sopenharmony_ci	u32	slice_asym_limit : 8;
1318c2ecf20Sopenharmony_ci	u32	pad_28_30 : 3;
1328c2ecf20Sopenharmony_ci	u32	slice_asym_enable : 1;
1338c2ecf20Sopenharmony_ci};
1348c2ecf20Sopenharmony_ci
1358c2ecf20Sopenharmony_cistruct b_cr_asym_2way_mem_region_mchbar {
1368c2ecf20Sopenharmony_ci	u32	pad : 2;
1378c2ecf20Sopenharmony_ci	u32	asym_2way_intlv_mode : 2;
1388c2ecf20Sopenharmony_ci	u32	asym_2way_base : 11;
1398c2ecf20Sopenharmony_ci	u32	pad_16_15 : 2;
1408c2ecf20Sopenharmony_ci	u32	asym_2way_limit : 11;
1418c2ecf20Sopenharmony_ci	u32	pad_30_28 : 3;
1428c2ecf20Sopenharmony_ci	u32	asym_2way_interleave_enable : 1;
1438c2ecf20Sopenharmony_ci};
1448c2ecf20Sopenharmony_ci
1458c2ecf20Sopenharmony_ci#define b_cr_asym_2way_mem_region_mchbar_port 0x4c
1468c2ecf20Sopenharmony_ci#define b_cr_asym_2way_mem_region_mchbar_offset 0x6e50
1478c2ecf20Sopenharmony_ci#define b_cr_asym_2way_mem_region_mchbar_r_opcode 0x00
1488c2ecf20Sopenharmony_ci
1498c2ecf20Sopenharmony_ci/* Apollo Lake d-unit */
1508c2ecf20Sopenharmony_ci
1518c2ecf20Sopenharmony_cistruct d_cr_drp0 {
1528c2ecf20Sopenharmony_ci	u32	rken0 : 1;
1538c2ecf20Sopenharmony_ci	u32	rken1 : 1;
1548c2ecf20Sopenharmony_ci	u32	ddmen : 1;
1558c2ecf20Sopenharmony_ci	u32	rsvd3 : 1;
1568c2ecf20Sopenharmony_ci	u32	dwid : 2;
1578c2ecf20Sopenharmony_ci	u32	dden : 3;
1588c2ecf20Sopenharmony_ci	u32	rsvd13_9 : 5;
1598c2ecf20Sopenharmony_ci	u32	rsien : 1;
1608c2ecf20Sopenharmony_ci	u32	bahen : 1;
1618c2ecf20Sopenharmony_ci	u32	rsvd18_16 : 3;
1628c2ecf20Sopenharmony_ci	u32	caswizzle : 2;
1638c2ecf20Sopenharmony_ci	u32	eccen : 1;
1648c2ecf20Sopenharmony_ci	u32	dramtype : 3;
1658c2ecf20Sopenharmony_ci	u32	blmode : 3;
1668c2ecf20Sopenharmony_ci	u32	addrdec : 2;
1678c2ecf20Sopenharmony_ci	u32	dramdevice_pr : 2;
1688c2ecf20Sopenharmony_ci};
1698c2ecf20Sopenharmony_ci
1708c2ecf20Sopenharmony_ci#define d_cr_drp0_offset 0x1400
1718c2ecf20Sopenharmony_ci#define d_cr_drp0_r_opcode 0x00
1728c2ecf20Sopenharmony_ci
1738c2ecf20Sopenharmony_ci/* Denverton d-unit */
1748c2ecf20Sopenharmony_ci
1758c2ecf20Sopenharmony_cistruct d_cr_dsch {
1768c2ecf20Sopenharmony_ci	u32	ch0en : 1;
1778c2ecf20Sopenharmony_ci	u32	ch1en : 1;
1788c2ecf20Sopenharmony_ci	u32	ddr4en : 1;
1798c2ecf20Sopenharmony_ci	u32	coldwake : 1;
1808c2ecf20Sopenharmony_ci	u32	newbypdis : 1;
1818c2ecf20Sopenharmony_ci	u32	chan_width : 1;
1828c2ecf20Sopenharmony_ci	u32	rsvd6_6 : 1;
1838c2ecf20Sopenharmony_ci	u32	ooodis : 1;
1848c2ecf20Sopenharmony_ci	u32	rsvd18_8 : 11;
1858c2ecf20Sopenharmony_ci	u32	ic : 1;
1868c2ecf20Sopenharmony_ci	u32	rsvd31_20 : 12;
1878c2ecf20Sopenharmony_ci};
1888c2ecf20Sopenharmony_ci
1898c2ecf20Sopenharmony_ci#define d_cr_dsch_port 0x16
1908c2ecf20Sopenharmony_ci#define d_cr_dsch_offset 0x0
1918c2ecf20Sopenharmony_ci#define d_cr_dsch_r_opcode 0x0
1928c2ecf20Sopenharmony_ci
1938c2ecf20Sopenharmony_cistruct d_cr_ecc_ctrl {
1948c2ecf20Sopenharmony_ci	u32	eccen : 1;
1958c2ecf20Sopenharmony_ci	u32	rsvd31_1 : 31;
1968c2ecf20Sopenharmony_ci};
1978c2ecf20Sopenharmony_ci
1988c2ecf20Sopenharmony_ci#define d_cr_ecc_ctrl_offset 0x180
1998c2ecf20Sopenharmony_ci#define d_cr_ecc_ctrl_r_opcode 0x0
2008c2ecf20Sopenharmony_ci
2018c2ecf20Sopenharmony_cistruct d_cr_drp {
2028c2ecf20Sopenharmony_ci	u32	rken0 : 1;
2038c2ecf20Sopenharmony_ci	u32	rken1 : 1;
2048c2ecf20Sopenharmony_ci	u32	rken2 : 1;
2058c2ecf20Sopenharmony_ci	u32	rken3 : 1;
2068c2ecf20Sopenharmony_ci	u32	dimmdwid0 : 2;
2078c2ecf20Sopenharmony_ci	u32	dimmdden0 : 2;
2088c2ecf20Sopenharmony_ci	u32	dimmdwid1 : 2;
2098c2ecf20Sopenharmony_ci	u32	dimmdden1 : 2;
2108c2ecf20Sopenharmony_ci	u32	rsvd15_12 : 4;
2118c2ecf20Sopenharmony_ci	u32	dimmflip : 1;
2128c2ecf20Sopenharmony_ci	u32	rsvd31_17 : 15;
2138c2ecf20Sopenharmony_ci};
2148c2ecf20Sopenharmony_ci
2158c2ecf20Sopenharmony_ci#define d_cr_drp_offset 0x158
2168c2ecf20Sopenharmony_ci#define d_cr_drp_r_opcode 0x0
2178c2ecf20Sopenharmony_ci
2188c2ecf20Sopenharmony_cistruct d_cr_dmap {
2198c2ecf20Sopenharmony_ci	u32	ba0 : 5;
2208c2ecf20Sopenharmony_ci	u32	ba1 : 5;
2218c2ecf20Sopenharmony_ci	u32	bg0 : 5; /* if ddr3, ba2 = bg0 */
2228c2ecf20Sopenharmony_ci	u32	bg1 : 5; /* if ddr3, ba3 = bg1 */
2238c2ecf20Sopenharmony_ci	u32	rs0 : 5;
2248c2ecf20Sopenharmony_ci	u32	rs1 : 5;
2258c2ecf20Sopenharmony_ci	u32	rsvd : 2;
2268c2ecf20Sopenharmony_ci};
2278c2ecf20Sopenharmony_ci
2288c2ecf20Sopenharmony_ci#define d_cr_dmap_offset 0x174
2298c2ecf20Sopenharmony_ci#define d_cr_dmap_r_opcode 0x0
2308c2ecf20Sopenharmony_ci
2318c2ecf20Sopenharmony_cistruct d_cr_dmap1 {
2328c2ecf20Sopenharmony_ci	u32	ca11 : 6;
2338c2ecf20Sopenharmony_ci	u32	bxor : 1;
2348c2ecf20Sopenharmony_ci	u32	rsvd : 25;
2358c2ecf20Sopenharmony_ci};
2368c2ecf20Sopenharmony_ci
2378c2ecf20Sopenharmony_ci#define d_cr_dmap1_offset 0xb4
2388c2ecf20Sopenharmony_ci#define d_cr_dmap1_r_opcode 0x0
2398c2ecf20Sopenharmony_ci
2408c2ecf20Sopenharmony_cistruct d_cr_dmap2 {
2418c2ecf20Sopenharmony_ci	u32	row0 : 5;
2428c2ecf20Sopenharmony_ci	u32	row1 : 5;
2438c2ecf20Sopenharmony_ci	u32	row2 : 5;
2448c2ecf20Sopenharmony_ci	u32	row3 : 5;
2458c2ecf20Sopenharmony_ci	u32	row4 : 5;
2468c2ecf20Sopenharmony_ci	u32	row5 : 5;
2478c2ecf20Sopenharmony_ci	u32	rsvd : 2;
2488c2ecf20Sopenharmony_ci};
2498c2ecf20Sopenharmony_ci
2508c2ecf20Sopenharmony_ci#define d_cr_dmap2_offset 0x148
2518c2ecf20Sopenharmony_ci#define d_cr_dmap2_r_opcode 0x0
2528c2ecf20Sopenharmony_ci
2538c2ecf20Sopenharmony_cistruct d_cr_dmap3 {
2548c2ecf20Sopenharmony_ci	u32	row6 : 5;
2558c2ecf20Sopenharmony_ci	u32	row7 : 5;
2568c2ecf20Sopenharmony_ci	u32	row8 : 5;
2578c2ecf20Sopenharmony_ci	u32	row9 : 5;
2588c2ecf20Sopenharmony_ci	u32	row10 : 5;
2598c2ecf20Sopenharmony_ci	u32	row11 : 5;
2608c2ecf20Sopenharmony_ci	u32	rsvd : 2;
2618c2ecf20Sopenharmony_ci};
2628c2ecf20Sopenharmony_ci
2638c2ecf20Sopenharmony_ci#define d_cr_dmap3_offset 0x14c
2648c2ecf20Sopenharmony_ci#define d_cr_dmap3_r_opcode 0x0
2658c2ecf20Sopenharmony_ci
2668c2ecf20Sopenharmony_cistruct d_cr_dmap4 {
2678c2ecf20Sopenharmony_ci	u32	row12 : 5;
2688c2ecf20Sopenharmony_ci	u32	row13 : 5;
2698c2ecf20Sopenharmony_ci	u32	row14 : 5;
2708c2ecf20Sopenharmony_ci	u32	row15 : 5;
2718c2ecf20Sopenharmony_ci	u32	row16 : 5;
2728c2ecf20Sopenharmony_ci	u32	row17 : 5;
2738c2ecf20Sopenharmony_ci	u32	rsvd : 2;
2748c2ecf20Sopenharmony_ci};
2758c2ecf20Sopenharmony_ci
2768c2ecf20Sopenharmony_ci#define d_cr_dmap4_offset 0x150
2778c2ecf20Sopenharmony_ci#define d_cr_dmap4_r_opcode 0x0
2788c2ecf20Sopenharmony_ci
2798c2ecf20Sopenharmony_cistruct d_cr_dmap5 {
2808c2ecf20Sopenharmony_ci	u32	ca3 : 4;
2818c2ecf20Sopenharmony_ci	u32	ca4 : 4;
2828c2ecf20Sopenharmony_ci	u32	ca5 : 4;
2838c2ecf20Sopenharmony_ci	u32	ca6 : 4;
2848c2ecf20Sopenharmony_ci	u32	ca7 : 4;
2858c2ecf20Sopenharmony_ci	u32	ca8 : 4;
2868c2ecf20Sopenharmony_ci	u32	ca9 : 4;
2878c2ecf20Sopenharmony_ci	u32	rsvd : 4;
2888c2ecf20Sopenharmony_ci};
2898c2ecf20Sopenharmony_ci
2908c2ecf20Sopenharmony_ci#define d_cr_dmap5_offset 0x154
2918c2ecf20Sopenharmony_ci#define d_cr_dmap5_r_opcode 0x0
2928c2ecf20Sopenharmony_ci
2938c2ecf20Sopenharmony_ci#endif /* _PND2_REGS_H */
294