Lines Matching refs:dct
90 static void f15h_select_dct(struct amd64_pvt *pvt, u8 dct) in f15h_select_dct() argument
96 reg |= dct; in f15h_select_dct()
114 static inline int amd64_read_dct_pci_cfg(struct amd64_pvt *pvt, u8 dct, in amd64_read_dct_pci_cfg() argument
119 if (dct || offset >= 0x100) in amd64_read_dct_pci_cfg()
124 if (dct) { in amd64_read_dct_pci_cfg()
142 dct = (dct && pvt->model == 0x30) ? 3 : dct; in amd64_read_dct_pci_cfg()
143 f15h_select_dct(pvt, dct); in amd64_read_dct_pci_cfg()
147 if (dct) in amd64_read_dct_pci_cfg()
391 static void get_cs_base_and_mask(struct amd64_pvt *pvt, int csrow, u8 dct, in get_cs_base_and_mask() argument
398 csbase = pvt->csels[dct].csbases[csrow]; in get_cs_base_and_mask()
399 csmask = pvt->csels[dct].csmasks[csrow]; in get_cs_base_and_mask()
410 csbase = pvt->csels[dct].csbases[csrow]; in get_cs_base_and_mask()
411 csmask = pvt->csels[dct].csmasks[csrow >> 1]; in get_cs_base_and_mask()
426 csbase = pvt->csels[dct].csbases[csrow]; in get_cs_base_and_mask()
427 csmask = pvt->csels[dct].csmasks[csrow >> 1]; in get_cs_base_and_mask()
447 #define for_each_chip_select(i, dct, pvt) \ argument
448 for (i = 0; i < pvt->csels[dct].b_cnt; i++)
450 #define chip_select_base(i, dct, pvt) \ argument
451 pvt->csels[dct].csbases[i]
453 #define for_each_chip_select_mask(i, dct, pvt) \ argument
454 for (i = 0; i < pvt->csels[dct].m_cnt; i++)
1346 static int k8_dbam_to_chip_select(struct amd64_pvt *pvt, u8 dct, in k8_dbam_to_chip_select() argument
1349 u32 dclr = dct ? pvt->dclr1 : pvt->dclr0; in k8_dbam_to_chip_select()
1513 static int f10_dbam_to_chip_select(struct amd64_pvt *pvt, u8 dct, in f10_dbam_to_chip_select() argument
1516 u32 dclr = dct ? pvt->dclr1 : pvt->dclr0; in f10_dbam_to_chip_select()
1529 static int f15_dbam_to_chip_select(struct amd64_pvt *pvt, u8 dct, in f15_dbam_to_chip_select() argument
1538 static int f15_m60h_dbam_to_chip_select(struct amd64_pvt *pvt, u8 dct, in f15_m60h_dbam_to_chip_select() argument
1542 u32 dcsm = pvt->csels[dct].csmasks[cs_mask_nr]; in f15_m60h_dbam_to_chip_select()
1571 static int f16_dbam_to_chip_select(struct amd64_pvt *pvt, u8 dct, in f16_dbam_to_chip_select() argument
1800 static int f10_process_possible_spare(struct amd64_pvt *pvt, u8 dct, int csrow) in f10_process_possible_spare() argument
1804 if (online_spare_swap_done(pvt, dct) && in f10_process_possible_spare()
1805 csrow == online_spare_bad_dramcs(pvt, dct)) { in f10_process_possible_spare()
1807 for_each_chip_select(tmp_cs, dct, pvt) { in f10_process_possible_spare()
1808 if (chip_select_base(tmp_cs, dct, pvt) & 0x2) { in f10_process_possible_spare()
1825 static int f1x_lookup_addr_in_dct(u64 in_addr, u8 nid, u8 dct) in f1x_lookup_addr_in_dct() argument
1839 edac_dbg(1, "input addr: 0x%llx, DCT: %d\n", in_addr, dct); in f1x_lookup_addr_in_dct()
1841 for_each_chip_select(csrow, dct, pvt) { in f1x_lookup_addr_in_dct()
1842 if (!csrow_enabled(csrow, dct, pvt)) in f1x_lookup_addr_in_dct()
1845 get_cs_base_and_mask(pvt, csrow, dct, &cs_base, &cs_mask); in f1x_lookup_addr_in_dct()
1860 cs_found = f10_process_possible_spare(pvt, dct, csrow); in f1x_lookup_addr_in_dct()
2879 static u32 get_csrow_nr_pages(struct amd64_pvt *pvt, u8 dct, int csrow_nr_orig) in get_csrow_nr_pages() argument
2881 u32 dbam = dct ? pvt->dbam1 : pvt->dbam0; in get_csrow_nr_pages()
2889 cs_mode = f17_get_cs_mode(csrow_nr >> 1, dct, pvt); in get_csrow_nr_pages()
2892 nr_pages = pvt->ops->dbam_to_cs(pvt, dct, cs_mode, csrow_nr); in get_csrow_nr_pages()
2896 csrow_nr_orig, dct, cs_mode); in get_csrow_nr_pages()