Lines Matching +full:2 +full:- +full:dimensional
6 * 2006-2008 (c) MontaVista Software, Inc. This file is licensed under
7 * the terms of the GNU General Public License version 2. This program
26 #define EDAC_OPSTATE_INVAL -1
29 #define EDAC_OPSTATE_INT 2
60 * enum dev_type - describe the type of memory DRAM chips used at the stick
63 * @DEV_X2: 2 bits for data
93 * enum hw_event_mc_err_type - type of the detected error
95 * @HW_EVENT_ERR_CORRECTED: Corrected Error - Indicates that an ECC
97 * @HW_EVENT_ERR_UNCORRECTED: Uncorrected Error - Indicates an error that
101 * it for example, by re-trying the operation).
102 * @HW_EVENT_ERR_DEFERRED: Deferred Error - Indicates an uncorrectable
108 * @HW_EVENT_ERR_FATAL: Fatal Error - Uncorrected error that could not
110 * @HW_EVENT_ERR_INFO: Informational - The CPER spec defines a forth
139 * enum mem_type - memory types. For a more detailed reference, please see
145 * @MEM_FPM: FPM - Fast Page Mode, used on systems up to 1995.
146 * @MEM_EDO: EDO - Extended data out, used on systems up to 1998.
147 * @MEM_BEDO: BEDO - Burst Extended data out, an EDO variant.
148 * @MEM_SDR: SDR - Single data rate SDRAM
149 * http://en.wikipedia.org/wiki/Synchronous_dynamic_random-access_memory
150 * They use 3 pins for chip select: Pins 0 and 2 are
152 * is dual-rank.
161 * @MEM_DDR2: DDR2 RAM, as described at JEDEC JESD79-2F.
162 * Those memories are labeled as "PC2-" instead of "PC" to
164 * @MEM_FB_DDR2: Fully-Buffered DDR2, as described at JEDEC Std No. 205
177 * @MEM_LRDDR3: Load-Reduced DDR3 memory.
178 * @MEM_LPDDR3: Low-Power DDR3 memory.
182 * @MEM_LRDDR4: Load-Reduced DDR4 memory.
183 * @MEM_LPDDR4: Low-Power DDR4 memory.
186 * @MEM_LRDDR5: Load-Reduced DDR5 memory.
187 * @MEM_NVDIMM: Non-volatile RAM
188 * @MEM_WIO2: Wide I/O 2.
189 * @MEM_HBM2: High bandwidth Memory Gen 2.
253 * enum edac_type - Error Detection and Correction capabilities and mode
258 * @EDAC_EC: Error Checking - no correction
260 * @EDAC_S2ECD2ED: Chipkill x2 devices - do these exist?
289 * enum scrub_type - scrubbing capabilities
323 /* FIXME - should have notify capabilities: NMI, LOG, PROC, etc */
333 * enum edac_mc_layer_type - memory controller hierarchy layer
355 * struct edac_mc_layer - describes the memory controller hierarchy
358 * if the channel layer has two channels, size = 2
405 * struct rank_info - contains the information for one DIMM rank
411 * the (csrow->csrow_idx, chan_idx) vector.
433 unsigned long page_mask; /* used for interleaving -
436 int csrow_idx; /* the chip-select row */
449 * struct errcount_attribute - used to store the several error counts
458 * struct edac_raw_error_desc - Raw error report structure
464 * @low_layer: low layer of the error (layer[2])
472 * @other_detail: other driver-specific detail about the error
503 unsigned long edac_cap; /* configuration capabilities - this is
534 /* FIXME - why not send the phys page to begin with? */
561 * FIXME - what about controllers on other busses? - IDs must be
597 * Used to report an error - by being at the global struct
612 for ((dimm) = (mci)->dimms[0]; \
614 (dimm) = (dimm)->idx + 1 < (mci)->tot_dimms \
615 ? (mci)->dimms[(dimm)->idx + 1] \
619 * edac_get_dimm - Get DIMM info from a memory controller given by
624 * @layer1: layer1 position. Unused if n_layers < 2
629 * For 2 layers, this function is similar to allocating a two-dimensional
632 * For 3 layers, this function is similar to allocating a tri-dimensional
641 || (mci->n_layers > 1 && layer1 < 0) in edac_get_dimm()
642 || (mci->n_layers > 2 && layer2 < 0)) in edac_get_dimm()
647 if (mci->n_layers > 1) in edac_get_dimm()
648 index = index * mci->layers[1].size + layer1; in edac_get_dimm()
650 if (mci->n_layers > 2) in edac_get_dimm()
651 index = index * mci->layers[2].size + layer2; in edac_get_dimm()
653 if (index < 0 || index >= mci->tot_dimms) in edac_get_dimm()
656 if (WARN_ON_ONCE(mci->dimms[index]->idx != index)) in edac_get_dimm()
659 return mci->dimms[index]; in edac_get_dimm()