Lines Matching full:pvt
440 struct i5400_pvt *pvt; in i5400_get_error_info() local
443 pvt = mci->pvt_info; in i5400_get_error_info()
446 pci_read_config_dword(pvt->branchmap_werrors, FERR_FAT_FBD, &value); in i5400_get_error_info()
459 pci_read_config_dword(pvt->branchmap_werrors, in i5400_get_error_info()
461 pci_read_config_word(pvt->branchmap_werrors, in i5400_get_error_info()
463 pci_read_config_dword(pvt->branchmap_werrors, in i5400_get_error_info()
467 pci_write_config_dword(pvt->branchmap_werrors, in i5400_get_error_info()
477 pci_read_config_dword(pvt->branchmap_werrors, FERR_NF_FBD, &value); in i5400_get_error_info()
485 pci_read_config_dword(pvt->branchmap_werrors, in i5400_get_error_info()
487 pci_read_config_word(pvt->branchmap_werrors, in i5400_get_error_info()
489 pci_read_config_dword(pvt->branchmap_werrors, in i5400_get_error_info()
491 pci_read_config_dword(pvt->branchmap_werrors, in i5400_get_error_info()
495 pci_write_config_dword(pvt->branchmap_werrors, in i5400_get_error_info()
702 struct i5400_pvt *pvt; in i5400_put_devices() local
704 pvt = mci->pvt_info; in i5400_put_devices()
707 pci_dev_put(pvt->branch_1); in i5400_put_devices()
708 pci_dev_put(pvt->branch_0); in i5400_put_devices()
709 pci_dev_put(pvt->fsb_error_regs); in i5400_put_devices()
710 pci_dev_put(pvt->branchmap_werrors); in i5400_put_devices()
721 struct i5400_pvt *pvt; in i5400_get_devices() local
724 pvt = mci->pvt_info; in i5400_get_devices()
725 pvt->branchmap_werrors = NULL; in i5400_get_devices()
726 pvt->fsb_error_regs = NULL; in i5400_get_devices()
727 pvt->branch_0 = NULL; in i5400_get_devices()
728 pvt->branch_1 = NULL; in i5400_get_devices()
751 pvt->branchmap_werrors = pdev; in i5400_get_devices()
767 pci_dev_put(pvt->branchmap_werrors); in i5400_get_devices()
775 pvt->fsb_error_regs = pdev; in i5400_get_devices()
778 pci_name(pvt->system_address), in i5400_get_devices()
779 pvt->system_address->vendor, pvt->system_address->device); in i5400_get_devices()
781 pci_name(pvt->branchmap_werrors), in i5400_get_devices()
782 pvt->branchmap_werrors->vendor, in i5400_get_devices()
783 pvt->branchmap_werrors->device); in i5400_get_devices()
785 pci_name(pvt->fsb_error_regs), in i5400_get_devices()
786 pvt->fsb_error_regs->vendor, pvt->fsb_error_regs->device); in i5400_get_devices()
788 pvt->branch_0 = pci_get_device(PCI_VENDOR_ID_INTEL, in i5400_get_devices()
790 if (!pvt->branch_0) { in i5400_get_devices()
796 pci_dev_put(pvt->fsb_error_regs); in i5400_get_devices()
797 pci_dev_put(pvt->branchmap_werrors); in i5400_get_devices()
804 if (pvt->maxch < CHANNELS_PER_BRANCH) in i5400_get_devices()
807 pvt->branch_1 = pci_get_device(PCI_VENDOR_ID_INTEL, in i5400_get_devices()
809 if (!pvt->branch_1) { in i5400_get_devices()
817 pci_dev_put(pvt->branch_0); in i5400_get_devices()
818 pci_dev_put(pvt->fsb_error_regs); in i5400_get_devices()
819 pci_dev_put(pvt->branchmap_werrors); in i5400_get_devices()
839 static int determine_amb_present_reg(struct i5400_pvt *pvt, int channel) in determine_amb_present_reg() argument
845 amb_present = pvt->b0_ambpresent1; in determine_amb_present_reg()
847 amb_present = pvt->b0_ambpresent0; in determine_amb_present_reg()
850 amb_present = pvt->b1_ambpresent1; in determine_amb_present_reg()
852 amb_present = pvt->b1_ambpresent0; in determine_amb_present_reg()
859 * determine_mtr(pvt, dimm, channel)
863 static int determine_mtr(struct i5400_pvt *pvt, int dimm, int channel) in determine_mtr() argument
880 mtr = pvt->b0_mtr[n]; in determine_mtr()
882 mtr = pvt->b1_mtr[n]; in determine_mtr()
920 static void handle_channel(struct i5400_pvt *pvt, int dimm, int channel, in handle_channel() argument
927 mtr = determine_mtr(pvt, dimm, channel); in handle_channel()
929 amb_present_reg = determine_amb_present_reg(pvt, channel); in handle_channel()
958 static void calculate_dimm_size(struct i5400_pvt *pvt) in calculate_dimm_size() argument
980 max_dimms = pvt->maxdimmperch; in calculate_dimm_size()
998 for (channel = 0; channel < pvt->maxch; channel++) { in calculate_dimm_size()
999 dinfo = &pvt->dimm_info[dimm][channel]; in calculate_dimm_size()
1000 handle_channel(pvt, dimm, channel, dinfo); in calculate_dimm_size()
1023 for (channel = 0; channel < pvt->maxch; channel++) { in calculate_dimm_size()
1055 struct i5400_pvt *pvt; in i5400_get_mc_regs() local
1061 pvt = mci->pvt_info; in i5400_get_mc_regs()
1063 pci_read_config_dword(pvt->system_address, AMBASE, in i5400_get_mc_regs()
1064 &pvt->u.ambase_bottom); in i5400_get_mc_regs()
1065 pci_read_config_dword(pvt->system_address, AMBASE + sizeof(u32), in i5400_get_mc_regs()
1066 &pvt->u.ambase_top); in i5400_get_mc_regs()
1069 (long unsigned int)pvt->ambase, pvt->maxch, pvt->maxdimmperch); in i5400_get_mc_regs()
1072 pci_read_config_word(pvt->branchmap_werrors, TOLM, &pvt->tolm); in i5400_get_mc_regs()
1073 pvt->tolm >>= 12; in i5400_get_mc_regs()
1075 pvt->tolm, pvt->tolm); in i5400_get_mc_regs()
1077 actual_tolm = (u32) ((1000l * pvt->tolm) >> (30 - 28)); in i5400_get_mc_regs()
1079 actual_tolm/1000, actual_tolm % 1000, pvt->tolm << 28); in i5400_get_mc_regs()
1081 pci_read_config_word(pvt->branchmap_werrors, MIR0, &pvt->mir0); in i5400_get_mc_regs()
1082 pci_read_config_word(pvt->branchmap_werrors, MIR1, &pvt->mir1); in i5400_get_mc_regs()
1085 limit = (pvt->mir0 >> 4) & 0x0fff; in i5400_get_mc_regs()
1086 way0 = pvt->mir0 & 0x1; in i5400_get_mc_regs()
1087 way1 = pvt->mir0 & 0x2; in i5400_get_mc_regs()
1090 limit = (pvt->mir1 >> 4) & 0xfff; in i5400_get_mc_regs()
1091 way0 = pvt->mir1 & 0x1; in i5400_get_mc_regs()
1092 way1 = pvt->mir1 & 0x2; in i5400_get_mc_regs()
1101 pci_read_config_word(pvt->branch_0, where, in i5400_get_mc_regs()
1102 &pvt->b0_mtr[slot_row]); in i5400_get_mc_regs()
1105 slot_row, where, pvt->b0_mtr[slot_row]); in i5400_get_mc_regs()
1107 if (pvt->maxch < CHANNELS_PER_BRANCH) { in i5400_get_mc_regs()
1108 pvt->b1_mtr[slot_row] = 0; in i5400_get_mc_regs()
1113 pci_read_config_word(pvt->branch_1, where, in i5400_get_mc_regs()
1114 &pvt->b1_mtr[slot_row]); in i5400_get_mc_regs()
1116 slot_row, where, pvt->b1_mtr[slot_row]); in i5400_get_mc_regs()
1123 decode_mtr(slot_row, pvt->b0_mtr[slot_row]); in i5400_get_mc_regs()
1125 pci_read_config_word(pvt->branch_0, AMBPRESENT_0, in i5400_get_mc_regs()
1126 &pvt->b0_ambpresent0); in i5400_get_mc_regs()
1127 edac_dbg(2, "\t\tAMB-Branch 0-present0 0x%x:\n", pvt->b0_ambpresent0); in i5400_get_mc_regs()
1128 pci_read_config_word(pvt->branch_0, AMBPRESENT_1, in i5400_get_mc_regs()
1129 &pvt->b0_ambpresent1); in i5400_get_mc_regs()
1130 edac_dbg(2, "\t\tAMB-Branch 0-present1 0x%x:\n", pvt->b0_ambpresent1); in i5400_get_mc_regs()
1133 if (pvt->maxch < CHANNELS_PER_BRANCH) { in i5400_get_mc_regs()
1134 pvt->b1_ambpresent0 = 0; in i5400_get_mc_regs()
1135 pvt->b1_ambpresent1 = 0; in i5400_get_mc_regs()
1140 decode_mtr(slot_row, pvt->b1_mtr[slot_row]); in i5400_get_mc_regs()
1142 pci_read_config_word(pvt->branch_1, AMBPRESENT_0, in i5400_get_mc_regs()
1143 &pvt->b1_ambpresent0); in i5400_get_mc_regs()
1145 pvt->b1_ambpresent0); in i5400_get_mc_regs()
1146 pci_read_config_word(pvt->branch_1, AMBPRESENT_1, in i5400_get_mc_regs()
1147 &pvt->b1_ambpresent1); in i5400_get_mc_regs()
1149 pvt->b1_ambpresent1); in i5400_get_mc_regs()
1154 calculate_dimm_size(pvt); in i5400_get_mc_regs()
1168 struct i5400_pvt *pvt; in i5400_init_dimms() local
1175 pvt = mci->pvt_info; in i5400_init_dimms()
1180 * FIXME: remove pvt->dimm_info[slot][channel] and use the 3 in i5400_init_dimms()
1186 mtr = determine_mtr(pvt, slot, channel); in i5400_init_dimms()
1194 size_mb = pvt->dimm_info[slot][channel].megabytes; in i5400_init_dimms()
1231 struct i5400_pvt *pvt; in i5400_enable_error_reporting() local
1234 pvt = mci->pvt_info; in i5400_enable_error_reporting()
1237 pci_read_config_dword(pvt->branchmap_werrors, EMASK_FBD, in i5400_enable_error_reporting()
1243 pci_write_config_dword(pvt->branchmap_werrors, EMASK_FBD, in i5400_enable_error_reporting()
1257 struct i5400_pvt *pvt; in i5400_probe1() local
1285 mci = edac_mc_alloc(0, ARRAY_SIZE(layers), layers, sizeof(*pvt)); in i5400_probe1()
1293 pvt = mci->pvt_info; in i5400_probe1()
1294 pvt->system_address = pdev; /* Record this device in our private */ in i5400_probe1()
1295 pvt->maxch = MAX_CHANNELS; in i5400_probe1()
1296 pvt->maxdimmperch = DIMMS_PER_CHANNEL; in i5400_probe1()