xref: /illumos-gate/usr/src/common/mc/zen_umc/zen_umc_decode.c (revision 806838751b3ce15414781bffd4adfac166204c62)
1 /*
2  * This file and its contents are supplied under the terms of the
3  * Common Development and Distribution License ("CDDL"), version 1.0.
4  * You may only use this file in accordance with the terms of version
5  * 1.0 of the CDDL.
6  *
7  * A full copy of the text of the CDDL should have accompanied this
8  * source.  A copy of the CDDL is also available via the Internet at
9  * http://www.illumos.org/license/CDDL.
10  */
11 
12 /*
13  * Copyright 2022 Oxide Computer Company
14  */
15 
16 /*
17  * Zen UMC Decoding logic. See zen_umc.c for an overview of everything. This
18  * implements shared userland/kernel decoding.
19  */
20 
21 #include "zen_umc.h"
22 
23 #ifndef _KERNEL
24 #include <strings.h>
25 #endif
26 
27 /*
28  * Address constants.
29  */
30 #define	ZEN_UMC_TOM2_START	0x100000000ULL
31 #define	ZEN_UMC_TOM2_RSVD_BEGIN	0xfd00000000ULL
32 #define	ZEN_UMC_TOM2_RSVD_END	0x10000000000ULL
33 
34 /*
35  * COD based hashing constants.
36  */
37 #define	ZEN_UMC_COD_NBITS	3
38 #define	ZEN_UMC_NPS_MOD_NBITS	3
39 
40 /*
41  * We want to apply some initial heuristics to determine if a physical address
42  * is DRAM before we proceed because of the MMIO hole and related. The DRAM
43  * ranges can overlap with these system reserved ranges so we have to manually
44  * check these.  Effectively this means that we have a few valid ranges:
45  *
46  *  o [ 0, TOM )
47  *  o [ 4 GiB, TOM2 )
48  *
49  * However, the above 4 GiB runs into trouble depending on size. There is a 12
50  * GiB system reserved address region right below 1 TiB. So it really turns
51  * into the following when we have more than 1 TiB of DRAM:
52  *
53  *  o [ 0, TOM )
54  *  o [ 4 GiB, 1 TiB - 12 GiB )
55  *  o [ 1 TiB, TOM2 )
56  *
57  * Note, this does not currently scan MTRRs or MMIO rules for what might be
58  * redirected to MMIO.
59  */
60 static boolean_t
61 zen_umc_decode_is_dram(const zen_umc_t *umc, zen_umc_decoder_t *dec)
62 {
63 	if (dec->dec_pa < umc->umc_tom) {
64 		return (B_TRUE);
65 	}
66 
67 	if (dec->dec_pa >= umc->umc_tom2) {
68 		dec->dec_fail = ZEN_UMC_DECODE_F_OUTSIDE_DRAM;
69 		return (B_FALSE);
70 	}
71 
72 	/*
73 	 * If the address is in the reserved hole around 1 TiB, do not proceed.
74 	 */
75 	if (dec->dec_pa >= ZEN_UMC_TOM2_RSVD_BEGIN &&
76 	    dec->dec_pa < ZEN_UMC_TOM2_RSVD_END) {
77 		dec->dec_fail = ZEN_UMC_DECODE_F_OUTSIDE_DRAM;
78 		return (B_FALSE);
79 	}
80 
81 	/*
82 	 * Now that we've validated we're not in the hole, check to see if we're
83 	 * actually in a valid region for TOM2.
84 	 */
85 	if (dec->dec_pa >= ZEN_UMC_TOM2_START &&
86 	    dec->dec_pa < umc->umc_tom2) {
87 		return (B_TRUE);
88 	}
89 
90 	/*
91 	 * At this point we have eliminated all known DRAM regions described by
92 	 * TOM and TOM2, so we have to conclude that whatever we're looking at
93 	 * is now not part of DRAM.
94 	 */
95 	dec->dec_fail = ZEN_UMC_DECODE_F_OUTSIDE_DRAM;
96 	return (B_FALSE);
97 }
98 
99 /*
100  * In our first stop on decoding, we need to go through and take a physical
101  * address and figure out what the corresponding initial DF rule that applies
102  * is. This rule will then be used to figure out which target on the data fabric
103  * we should be going to and what interleaving rules apply.
104  *
105  * Our DRAM rule may reflect that the DRAM hole is active. In this case the
106  * specified range in the rule will be larger than the actual amount of DRAM
107  * present. MMIO accesses take priority over DRAM accesses in the core and
108  * therefore the MMIO portion of the rule is not actually decoded. When trying
109  * to match a rule we do not need to worry about that and can just look whether
110  * our physical address matches a rule. We will take into account whether
111  * hoisting should adjust the address when we translate from a system address to
112  * a normal address (e.g. an address in the channel) which will be done in a
113  * subsequent step. If an address is in the hole, that has already been
114  * accounted for.
115  *
116  * While gathering information, we have all the DRAM rules for a given CCM that
117  * corresponds to a CPU core. This allows us to review all DRAM rules in one
118  * place rather than walking through what's been assigned to each UMC instance,
119  * which only has the rules that are directed towards that particular channel
120  * and matter for determining channel offsets.
121  */
122 static boolean_t
123 zen_umc_decode_find_df_rule(const zen_umc_t *umc, zen_umc_decoder_t *dec)
124 {
125 	const zen_umc_df_t *df = &umc->umc_dfs[0];
126 
127 	for (uint_t i = 0; i < df->zud_dram_nrules; i++) {
128 		const df_dram_rule_t *rule = &df->zud_rules[i];
129 
130 		/*
131 		 * If this rule is not enabled, skip it.
132 		 */
133 		if ((rule->ddr_flags & DF_DRAM_F_VALID) == 0)
134 			continue;
135 
136 		if (dec->dec_pa >= rule->ddr_base &&
137 		    dec->dec_pa < rule->ddr_limit) {
138 			dec->dec_df_ruleno = i;
139 			dec->dec_df_rule = rule;
140 			dec->dec_df_rulesrc = df;
141 			return (B_TRUE);
142 		}
143 	}
144 
145 	dec->dec_fail = ZEN_UMC_DECODE_F_NO_DF_RULE;
146 	return (B_FALSE);
147 }
148 
149 /*
150  * This function takes care of the common logic of adjusting an address by the
151  * base value in the rule and determining if we need to apply the DRAM hole or
152  * not. This function is used in two different places:
153  *
154  *   o As part of adjusting the system address to construct the interleave
155  *     address for DFv4 and Zen 3 based 6-channel hashing (see
156  *     zen_umc_determine_ileave_addr() below).
157  *   o As part of adjusting the system address at the beginning of normalization
158  *     to a channel address.
159  *
160  * One thing to highlight is that the same adjustment we make in the first case
161  * applies to a subset of things for interleaving; however, it applies to
162  * everything when normalizing.
163  */
164 static boolean_t
165 zen_umc_adjust_dram_addr(const zen_umc_t *umc, zen_umc_decoder_t *dec,
166     uint64_t *addrp, zen_umc_decode_failure_t errno)
167 {
168 	const uint64_t init_addr = *addrp;
169 	const df_dram_rule_t *rule = dec->dec_df_rule;
170 	const zen_umc_df_t *df = dec->dec_df_rulesrc;
171 	uint64_t mod_addr = init_addr;
172 
173 	ASSERT3U(init_addr, >=, rule->ddr_base);
174 	ASSERT3U(init_addr, <, rule->ddr_limit);
175 	mod_addr -= rule->ddr_base;
176 
177 	/*
178 	 * Determine if the hole applies to this rule.
179 	 */
180 	if ((rule->ddr_flags & DF_DRAM_F_HOLE) != 0 &&
181 	    (df->zud_flags & ZEN_UMC_DF_F_HOLE_VALID) != 0 &&
182 	    init_addr >= ZEN_UMC_TOM2_START) {
183 		uint64_t hole_size;
184 		hole_size = ZEN_UMC_TOM2_START -
185 		    umc->umc_dfs[0].zud_hole_base;
186 		if (mod_addr < hole_size) {
187 			dec->dec_fail = errno;
188 			dec->dec_fail_data = dec->dec_df_ruleno;
189 			return (B_FALSE);
190 		}
191 
192 		mod_addr -= hole_size;
193 	}
194 
195 	*addrp = mod_addr;
196 	return (B_TRUE);
197 }
198 
199 /*
200  * Take care of constructing the address we need to use for determining the
201  * interleaving target fabric id. See the big theory statement in zen_umc.c for
202  * more on this.
203  */
204 static boolean_t
205 zen_umc_determine_ileave_addr(const zen_umc_t *umc, zen_umc_decoder_t *dec)
206 {
207 	const df_dram_rule_t *rule = dec->dec_df_rule;
208 
209 	if (umc->umc_df_rev <= DF_REV_3 &&
210 	    rule->ddr_chan_ileave != DF_CHAN_ILEAVE_6CH) {
211 		dec->dec_ilv_pa = dec->dec_pa;
212 		return (B_TRUE);
213 	}
214 
215 	dec->dec_ilv_pa = dec->dec_pa;
216 	if (!zen_umc_adjust_dram_addr(umc, dec, &dec->dec_ilv_pa,
217 	    ZEN_UMC_DECODE_F_ILEAVE_UNDERFLOW)) {
218 		return (B_FALSE);
219 	}
220 
221 	return (B_TRUE);
222 }
223 
224 /*
225  * This is a simple interleaving case where we simply extract bits. No hashing
226  * required! Per zen_umc.c, from lowest to highest, we have channel, die, and
227  * then socket bits.
228  */
229 static boolean_t
230 zen_umc_decode_ileave_nohash(const zen_umc_t *umc, zen_umc_decoder_t *dec)
231 {
232 	uint32_t nchan_bit, ndie_bit, nsock_bit, addr_bit;
233 	const df_dram_rule_t *rule = dec->dec_df_rule;
234 
235 	nsock_bit = rule->ddr_sock_ileave_bits;
236 	ndie_bit = rule->ddr_die_ileave_bits;
237 	switch (rule->ddr_chan_ileave) {
238 	case DF_CHAN_ILEAVE_1CH:
239 		nchan_bit = 0;
240 		break;
241 	case DF_CHAN_ILEAVE_2CH:
242 		nchan_bit = 1;
243 		break;
244 	case DF_CHAN_ILEAVE_4CH:
245 		nchan_bit = 2;
246 		break;
247 	case DF_CHAN_ILEAVE_8CH:
248 		nchan_bit = 3;
249 		break;
250 	case DF_CHAN_ILEAVE_16CH:
251 		nchan_bit = 4;
252 		break;
253 	case DF_CHAN_ILEAVE_32CH:
254 		nchan_bit = 5;
255 		break;
256 	default:
257 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
258 		dec->dec_fail_data = rule->ddr_chan_ileave;
259 		return (B_FALSE);
260 	}
261 
262 	/*
263 	 * Zero all of these out in case no bits are dedicated to this purpose.
264 	 * In those cases, then the value for this is always zero.
265 	 */
266 	dec->dec_ilv_sock = dec->dec_ilv_die = dec->dec_ilv_chan = 0;
267 	addr_bit = rule->ddr_addr_start;
268 	if (nchan_bit > 0) {
269 		dec->dec_ilv_chan = bitx64(dec->dec_ilv_pa,
270 		    addr_bit + nchan_bit - 1, addr_bit);
271 		addr_bit += nchan_bit;
272 	}
273 
274 	if (ndie_bit > 0) {
275 		dec->dec_ilv_die = bitx64(dec->dec_ilv_pa,
276 		    addr_bit + ndie_bit - 1, addr_bit);
277 		addr_bit += ndie_bit;
278 	}
279 
280 	if (nsock_bit > 0) {
281 		dec->dec_ilv_sock = bitx64(dec->dec_ilv_pa,
282 		    addr_bit + nsock_bit - 1, addr_bit);
283 		addr_bit += nsock_bit;
284 	}
285 
286 	return (B_TRUE);
287 }
288 
289 /*
290  * Perform the Zen 2/Zen 3 "COD" based hashing. See the zen_umc.c interleaving
291  * section of the big theory statement for an overview of how this works.
292  */
293 static boolean_t
294 zen_umc_decode_ileave_cod(const zen_umc_t *umc, zen_umc_decoder_t *dec)
295 {
296 	uint32_t nchan_bit;
297 	const df_dram_rule_t *rule = dec->dec_df_rule;
298 	/*
299 	 * The order of bits here is defined by AMD. Yes, we do use the rule's
300 	 * address bit first and then skip to bit 12 for the second hash bit.
301 	 */
302 	const uint32_t addr_bits[3] = { rule->ddr_addr_start, 12, 13 };
303 
304 	if (rule->ddr_sock_ileave_bits != 0 || rule->ddr_die_ileave_bits != 0) {
305 		dec->dec_fail = ZEN_UMC_DECODE_F_COD_BAD_ILEAVE;
306 		dec->dec_fail_data = dec->dec_df_ruleno;
307 		return (B_FALSE);
308 	}
309 
310 	switch (rule->ddr_chan_ileave) {
311 	case DF_CHAN_ILEAVE_COD4_2CH:
312 		nchan_bit = 1;
313 		break;
314 	case DF_CHAN_ILEAVE_COD2_4CH:
315 		nchan_bit = 2;
316 		break;
317 	case DF_CHAN_ILEAVE_COD1_8CH:
318 		nchan_bit = 3;
319 		break;
320 	default:
321 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
322 		dec->dec_fail_data = rule->ddr_chan_ileave;
323 		return (B_FALSE);
324 	}
325 
326 	dec->dec_ilv_sock = dec->dec_ilv_die = dec->dec_ilv_chan = 0;
327 
328 	/*
329 	 * Proceed to calculate the address hash based on the number of bits
330 	 * that we have been told to use based on the DF rule. Use the flags in
331 	 * the rule to determine which additional address ranges to hash in.
332 	 */
333 	for (uint_t i = 0; i < nchan_bit; i++) {
334 		uint8_t hash = 0;
335 
336 		hash = bitx64(dec->dec_ilv_pa, addr_bits[i], addr_bits[i]);
337 		if ((rule->ddr_flags & DF_DRAM_F_HASH_16_18) != 0) {
338 			uint8_t val = bitx64(dec->dec_ilv_pa, 16 + i, 16 + i);
339 			hash ^= val;
340 		}
341 
342 		if ((rule->ddr_flags & DF_DRAM_F_HASH_21_23) != 0) {
343 			uint8_t val = bitx64(dec->dec_ilv_pa, 21 + i, 21 + i);
344 			hash ^= val;
345 		}
346 
347 		if ((rule->ddr_flags & DF_DRAM_F_HASH_30_32) != 0) {
348 			uint8_t val = bitx64(dec->dec_ilv_pa, 30 + i, 30 + i);
349 			hash ^= val;
350 		}
351 
352 		dec->dec_ilv_chan |= hash << i;
353 	}
354 
355 	return (B_TRUE);
356 }
357 
358 /*
359  * This implements the standard NPS hash for power of 2 based channel
360  * configurations that is found in DFv4. For more information, please see the
361  * interleaving portion of the zen_umc.c big theory statement.
362  */
363 static boolean_t
364 zen_umc_decode_ileave_nps(const zen_umc_t *umc, zen_umc_decoder_t *dec)
365 {
366 	uint32_t nchan_bit, nsock_bit;
367 	const df_dram_rule_t *rule = dec->dec_df_rule;
368 	/*
369 	 * The order of bits here is defined by AMD. Yes, this is start with the
370 	 * defined address bit and then skip to bit 12.
371 	 */
372 	const uint32_t addr_bits[4] = { rule->ddr_addr_start, 12, 13, 14 };
373 
374 	if (rule->ddr_die_ileave_bits != 0) {
375 		dec->dec_fail = ZEN_UMC_DECODE_F_NPS_BAD_ILEAVE;
376 		dec->dec_fail_data = dec->dec_df_ruleno;
377 		return (B_FALSE);
378 	}
379 
380 	nsock_bit = rule->ddr_sock_ileave_bits;
381 	switch (rule->ddr_chan_ileave) {
382 	case DF_CHAN_ILEAVE_NPS4_2CH:
383 		nchan_bit = 1;
384 		break;
385 	case DF_CHAN_ILEAVE_NPS2_4CH:
386 		nchan_bit = 2;
387 		break;
388 	case DF_CHAN_ILEAVE_NPS1_8CH:
389 		nchan_bit = 3;
390 		break;
391 	default:
392 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
393 		dec->dec_fail_data = rule->ddr_chan_ileave;
394 		return (B_FALSE);
395 	}
396 
397 	ASSERT3U(nchan_bit + nsock_bit, <=, 4);
398 	dec->dec_ilv_sock = dec->dec_ilv_die = dec->dec_ilv_chan = 0;
399 
400 	for (uint_t i = 0; i < nchan_bit + nsock_bit; i++) {
401 		uint8_t hash = 0;
402 
403 		hash = bitx64(dec->dec_ilv_pa, addr_bits[i], addr_bits[i]);
404 		if ((rule->ddr_flags & DF_DRAM_F_HASH_16_18) != 0) {
405 			uint8_t val = bitx64(dec->dec_ilv_pa, 16 + i, 16 + i);
406 			hash ^= val;
407 		}
408 
409 		if ((rule->ddr_flags & DF_DRAM_F_HASH_21_23) != 0) {
410 			uint8_t val = bitx64(dec->dec_ilv_pa, 21 + i, 21 + i);
411 			hash ^= val;
412 		}
413 
414 		if ((rule->ddr_flags & DF_DRAM_F_HASH_30_32) != 0) {
415 			uint8_t val = bitx64(dec->dec_ilv_pa, 30 + i, 30 + i);
416 			hash ^= val;
417 		}
418 
419 		/*
420 		 * If this is the first bit and we're not doing socket
421 		 * interleaving, then we need to add bit 14 to the running hash.
422 		 */
423 		if (i == 0 && nsock_bit == 0) {
424 			uint8_t val = bitx64(dec->dec_ilv_pa, 14, 14);
425 			hash ^= val;
426 		}
427 
428 		/*
429 		 * If socket interleaving is going on we need to store the first
430 		 * bit as the socket hash and then redirect the remaining bits
431 		 * to the channel, taking into account that the shift will be
432 		 * adjusted as a result.
433 		 */
434 		if (nsock_bit > 0) {
435 			if (i == 0) {
436 				dec->dec_ilv_sock = hash;
437 			} else {
438 				dec->dec_ilv_chan |= hash << (i - 1);
439 			}
440 		} else {
441 			dec->dec_ilv_chan |= hash << i;
442 		}
443 	}
444 
445 	return (B_TRUE);
446 }
447 
448 /*
449  * This implements the logic to perform the Zen 3 6ch special hash. It's worth
450  * calling out that unlike all other hash functions, this does not support the
451  * use of the DF_DRAM_F_HASH_16_18 flag.
452  */
453 static void
454 zen_umc_decode_hash_zen3_6ch(const df_dram_rule_t *rule, uint64_t pa,
455     uint8_t hashes[3])
456 {
457 	uint32_t addr_bit = rule->ddr_addr_start;
458 	/*
459 	 * Yes, we use these in a weird order. No, there is no 64K.
460 	 */
461 	const uint32_t bits_2M[3] = { 23, 21, 22 };
462 	const uint32_t bits_1G[3] = { 32, 30, 31 };
463 
464 	hashes[0] = hashes[1] = hashes[2] = 0;
465 	for (uint_t i = 0; i < ZEN_UMC_COD_NBITS; i++) {
466 		hashes[i] = bitx64(pa, addr_bit + i, addr_bit + i);
467 		if (i == 0) {
468 			uint8_t val = bitx64(pa, addr_bit + 3, addr_bit + 3);
469 			hashes[i] ^= val;
470 		}
471 
472 		if ((rule->ddr_flags & DF_DRAM_F_HASH_21_23) != 0) {
473 			uint8_t val = bitx64(pa, bits_2M[i], bits_2M[i]);
474 			hashes[i] ^= val;
475 		}
476 
477 		if ((rule->ddr_flags & DF_DRAM_F_HASH_30_32) != 0) {
478 			uint8_t val = bitx64(pa, bits_1G[i], bits_1G[i]);
479 			hashes[i] ^= val;
480 		}
481 	}
482 }
483 
484 /*
485  * Perform Zen 3 6-channel hashing. This is pretty weird compared to others. See
486  * the zen_umc.c big theory statement for the thorny details.
487  */
488 static boolean_t
489 zen_umc_decode_ileave_zen3_6ch(const zen_umc_t *umc, zen_umc_decoder_t *dec)
490 {
491 	uint8_t hashes[3] = { 0 };
492 	const df_dram_rule_t *rule = dec->dec_df_rule;
493 	uint32_t addr_bit = rule->ddr_addr_start;
494 
495 	if (rule->ddr_sock_ileave_bits != 0 || rule->ddr_die_ileave_bits != 0) {
496 		dec->dec_fail = ZEN_UMC_DECODE_F_COD_BAD_ILEAVE;
497 		dec->dec_fail_data = dec->dec_df_ruleno;
498 		return (B_FALSE);
499 	}
500 
501 	zen_umc_decode_hash_zen3_6ch(rule, dec->dec_ilv_pa, hashes);
502 	dec->dec_ilv_sock = dec->dec_ilv_die = dec->dec_ilv_chan = 0;
503 	dec->dec_ilv_chan = hashes[0];
504 	if (hashes[1] == 1 && hashes[2] == 1) {
505 		uint64_t mod_addr = dec->dec_ilv_pa >> (addr_bit + 3);
506 		dec->dec_ilv_chan |= (mod_addr % 3) << 1;
507 	} else {
508 		dec->dec_ilv_chan |= hashes[1] << 1;
509 		dec->dec_ilv_chan |= hashes[2] << 2;
510 	}
511 
512 	return (B_TRUE);
513 }
514 
515 /*
516  * This is the standard hash function for the non-power of two based NPS hashes.
517  * See the big theory statement for more information. Unlike the normal NPS hash
518  * which uses bit 14 conditionally based on socket interleaving, here it is
519  * always used.
520  */
521 static void
522 zen_umc_decode_hash_nps_mod(const df_dram_rule_t *rule, uint64_t pa,
523     uint8_t hashes[3])
524 {
525 	const uint32_t addr_bits[3] = { rule->ddr_addr_start, 12, 13 };
526 
527 	for (uint_t i = 0; i < ZEN_UMC_NPS_MOD_NBITS; i++) {
528 		hashes[i] = bitx64(pa, addr_bits[i], addr_bits[i]);
529 		if (i == 0) {
530 			uint8_t val = bitx64(pa, 14, 14);
531 			hashes[i] ^= val;
532 		}
533 
534 		if ((rule->ddr_flags & DF_DRAM_F_HASH_16_18) != 0) {
535 			uint8_t val = bitx64(pa, 16 + i, 16 + i);
536 			hashes[i] ^= val;
537 		}
538 
539 		if ((rule->ddr_flags & DF_DRAM_F_HASH_21_23) != 0) {
540 			uint8_t val = bitx64(pa, 21 + i, 21 + i);
541 			hashes[i] ^= val;
542 		}
543 
544 		if ((rule->ddr_flags & DF_DRAM_F_HASH_30_32) != 0) {
545 			uint8_t val = bitx64(pa, 30 + i, 30 + i);
546 			hashes[i] ^= val;
547 		}
548 	}
549 }
550 
551 /*
552  * See the big theory statement in zen_umc.c which describes the rules for this
553  * computation. This is a little less weird than the Zen 3 one, but still,
554  * unique.
555  */
556 static boolean_t
557 zen_umc_decode_ileave_nps_mod(const zen_umc_t *umc, zen_umc_decoder_t *dec)
558 {
559 	uint8_t hashes[3] = { 0 };
560 	uint32_t nsock_bit, chan_mod;
561 	const df_dram_rule_t *rule = dec->dec_df_rule;
562 
563 	if (rule->ddr_die_ileave_bits != 0) {
564 		dec->dec_fail = ZEN_UMC_DECODE_F_NPS_BAD_ILEAVE;
565 		dec->dec_fail_data = dec->dec_df_ruleno;
566 		return (B_FALSE);
567 	}
568 
569 	nsock_bit = rule->ddr_sock_ileave_bits;
570 	switch (rule->ddr_chan_ileave) {
571 	case DF_CHAN_ILEAVE_NPS4_3CH:
572 	case DF_CHAN_ILEAVE_NPS2_6CH:
573 	case DF_CHAN_ILEAVE_NPS1_12CH:
574 		chan_mod = 3;
575 		break;
576 	case DF_CHAN_ILEAVE_NPS2_5CH:
577 	case DF_CHAN_ILEAVE_NPS1_10CH:
578 		chan_mod = 5;
579 		break;
580 	default:
581 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
582 		dec->dec_fail_data = rule->ddr_chan_ileave;
583 		return (B_FALSE);
584 	}
585 
586 	dec->dec_ilv_sock = dec->dec_ilv_die = dec->dec_ilv_chan = 0;
587 	zen_umc_decode_hash_nps_mod(rule, dec->dec_ilv_pa, hashes);
588 
589 	if (nsock_bit > 0) {
590 		ASSERT3U(nsock_bit, ==, 1);
591 		dec->dec_ilv_sock = hashes[0];
592 	}
593 
594 	dec->dec_ilv_chan = bitx64(dec->dec_ilv_pa, 63, 14) % chan_mod;
595 	if (hashes[0] == 1) {
596 		dec->dec_ilv_chan = (dec->dec_ilv_chan + 1) % chan_mod;
597 	}
598 
599 	/*
600 	 * Use the remaining hash bits based on the number of channels. There is
601 	 * nothing else to do for 3/5 channel configs.
602 	 */
603 	switch (rule->ddr_chan_ileave) {
604 	case DF_CHAN_ILEAVE_NPS4_3CH:
605 	case DF_CHAN_ILEAVE_NPS2_5CH:
606 		break;
607 	case DF_CHAN_ILEAVE_NPS2_6CH:
608 	case DF_CHAN_ILEAVE_NPS1_10CH:
609 		dec->dec_ilv_chan += hashes[2] * chan_mod;
610 		break;
611 	case DF_CHAN_ILEAVE_NPS1_12CH:
612 		dec->dec_ilv_chan += ((hashes[2] << 1) | hashes[1]) * chan_mod;
613 		break;
614 	default:
615 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
616 		dec->dec_fail_data = rule->ddr_chan_ileave;
617 		return (B_FALSE);
618 	}
619 
620 	return (B_TRUE);
621 }
622 
623 /*
624  * Our next task is to attempt to translate the PA and the DF rule from a system
625  * address into a normalized address and a particular DRAM channel that it's
626  * targeting. There are several things that we need to take into account here
627  * when performing interleaving and translation:
628  *
629  *  o The DRAM Hole modifying our base address
630  *  o The various interleave bits
631  *  o Potentially hashing based on channel and global settings
632  *  o Potential CS re-targeting registers (only on some systems)
633  *  o Finally, the question of how to adjust for the DRAM hole and the base
634  *    address changes based on the DF generation and channel configuration. This
635  *    influences what address we start interleaving with.
636  *
637  * Note, this phase does not actually construct the normalized (e.g. channel)
638  * address. That's done in a subsequent step. For more background, please see
639  * the 'Data Fabric Interleaving' section of the zen_umc.c big theory statement.
640  */
641 static boolean_t
642 zen_umc_decode_sysaddr_to_csid(const zen_umc_t *umc, zen_umc_decoder_t *dec)
643 {
644 	uint32_t sock, die, chan, remap_ruleset;
645 	const df_dram_rule_t *rule = dec->dec_df_rule;
646 	const zen_umc_cs_remap_t *remap;
647 
648 	/*
649 	 * First, we must determine what the actual address used for
650 	 * interleaving is. This varies based on the interleaving and DF
651 	 * generation.
652 	 */
653 	if (!zen_umc_determine_ileave_addr(umc, dec)) {
654 		return (B_FALSE);
655 	}
656 
657 	switch (rule->ddr_chan_ileave) {
658 	case DF_CHAN_ILEAVE_1CH:
659 	case DF_CHAN_ILEAVE_2CH:
660 	case DF_CHAN_ILEAVE_4CH:
661 	case DF_CHAN_ILEAVE_8CH:
662 	case DF_CHAN_ILEAVE_16CH:
663 	case DF_CHAN_ILEAVE_32CH:
664 		if (!zen_umc_decode_ileave_nohash(umc, dec)) {
665 			return (B_FALSE);
666 		}
667 		break;
668 	case DF_CHAN_ILEAVE_COD4_2CH:
669 	case DF_CHAN_ILEAVE_COD2_4CH:
670 	case DF_CHAN_ILEAVE_COD1_8CH:
671 		if (!zen_umc_decode_ileave_cod(umc, dec)) {
672 			return (B_FALSE);
673 		}
674 		break;
675 	case DF_CHAN_ILEAVE_NPS4_2CH:
676 	case DF_CHAN_ILEAVE_NPS2_4CH:
677 	case DF_CHAN_ILEAVE_NPS1_8CH:
678 		if (!zen_umc_decode_ileave_nps(umc, dec)) {
679 			return (B_FALSE);
680 		}
681 		break;
682 	case DF_CHAN_ILEAVE_6CH:
683 		if (!zen_umc_decode_ileave_zen3_6ch(umc, dec)) {
684 			return (B_FALSE);
685 		}
686 		break;
687 	case DF_CHAN_ILEAVE_NPS4_3CH:
688 	case DF_CHAN_ILEAVE_NPS2_6CH:
689 	case DF_CHAN_ILEAVE_NPS1_12CH:
690 	case DF_CHAN_ILEAVE_NPS2_5CH:
691 	case DF_CHAN_ILEAVE_NPS1_10CH:
692 		if (!zen_umc_decode_ileave_nps_mod(umc, dec)) {
693 			return (B_FALSE);
694 		}
695 		break;
696 	default:
697 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
698 		dec->dec_fail_data = rule->ddr_chan_ileave;
699 		return (B_FALSE);
700 	}
701 
702 	/*
703 	 * At this point we have dealt with decoding the interleave into the
704 	 * logical elements that it contains. We need to transform that back
705 	 * into a fabric ID, so we can add it to the base fabric ID in our rule.
706 	 * After that, we need to see if there is any CS remapping going on. If
707 	 * there is, we will replace the component part of the decomposed fabric
708 	 * ID. With that done, we can then transform the components back into
709 	 * our target fabric ID, which indicates which UMC we're after.
710 	 */
711 	zen_fabric_id_compose(&umc->umc_decomp, dec->dec_ilv_sock,
712 	    dec->dec_ilv_die, dec->dec_ilv_chan, &dec->dec_ilv_fabid);
713 	dec->dec_log_fabid = dec->dec_ilv_fabid + rule->ddr_dest_fabid;
714 
715 	/*
716 	 * If there's no remapping to do, then we're done. Simply assign the
717 	 * logical ID as our target.
718 	 */
719 	zen_fabric_id_decompose(&umc->umc_decomp, dec->dec_log_fabid, &sock,
720 	    &die, &chan);
721 	if ((rule->ddr_flags & DF_DRAM_F_REMAP_EN) == 0) {
722 		dec->dec_targ_fabid = dec->dec_log_fabid;
723 		return (B_TRUE);
724 	}
725 
726 	/*
727 	 * The DF contains multiple remapping tables. We must figure out which
728 	 * of these to actually use. There are two different ways that this can
729 	 * work. The first way is the one added in DFv4 and is used since then.
730 	 * In that case, the DRAM rule includes both that remapping was enabled
731 	 * and which of the multiple mapping tables to use.
732 	 *
733 	 * This feature also exists prior to DFv4, but only in Milan. In that
734 	 * world, indicated by the DF_DRAM_F_REMAP_SOCK flag, there is one table
735 	 * in each DF per-socket. Based on the destination socket from the data
736 	 * fabric ID, you pick the actual table to use.
737 	 *
738 	 * Once the table has been selected, we maintain the socket and die
739 	 * portions of the fabric ID as constants and replace the component with
740 	 * the one the remapping table indicates.
741 	 *
742 	 * Technically each DF has its own copy of the remapping tables. To make
743 	 * this work we rely on the following assumption: a given DF node has to
744 	 * be able to fully route all DRAM rules to a target. That is, a given
745 	 * DF node doesn't really forward a system address to the remote die for
746 	 * further interleave processing and therefore we must have enough
747 	 * information here to map it totally from the same DF that we got the
748 	 * CCM rules from in the first place, DF 0.
749 	 */
750 	if ((rule->ddr_flags & DF_DRAM_F_REMAP_SOCK) != 0) {
751 		remap_ruleset = sock;
752 	} else {
753 		remap_ruleset = rule->ddr_remap_ent;
754 	}
755 
756 	if (remap_ruleset >= dec->dec_df_rulesrc->zud_cs_nremap) {
757 		dec->dec_fail = ZEN_UMC_DECODE_F_BAD_REMAP_SET;
758 		dec->dec_fail_data = remap_ruleset;
759 		return (B_FALSE);
760 	}
761 
762 	remap = &dec->dec_df_rulesrc->zud_remap[remap_ruleset];
763 	if (chan >= remap->csr_nremaps) {
764 		dec->dec_fail = ZEN_UMC_DECODE_F_BAD_REMAP_ENTRY;
765 		dec->dec_fail_data = chan;
766 		return (B_FALSE);
767 	}
768 
769 	dec->dec_remap_comp = remap->csr_remaps[chan];
770 	if ((dec->dec_remap_comp & ~umc->umc_decomp.dfd_comp_mask) != 0) {
771 		dec->dec_fail = ZEN_UMC_DECODE_F_REMAP_HAS_BAD_COMP;
772 		dec->dec_fail_data = dec->dec_remap_comp;
773 		return (B_FALSE);
774 	}
775 
776 	zen_fabric_id_compose(&umc->umc_decomp, sock, die, dec->dec_remap_comp,
777 	    &dec->dec_targ_fabid);
778 
779 	return (B_TRUE);
780 }
781 
782 /*
783  * Our next step here is to actually take our target ID and find the
784  * corresponding DF, UMC, and actual rule that was used. Note, we don't
785  * decompose the ID and look things up that way for a few reasons. While each
786  * UMC should map linearly to its instance/component ID, there are suggestions
787  * that they can be renumbered. This makes it simplest to just walk over
788  * everything (and there aren't that many things to walk over either).
789  */
790 static boolean_t
791 zen_umc_decode_find_umc_rule(const zen_umc_t *umc, zen_umc_decoder_t *dec)
792 {
793 	for (uint_t dfno = 0; dfno < umc->umc_ndfs; dfno++) {
794 		const zen_umc_df_t *df = &umc->umc_dfs[dfno];
795 		for (uint_t umcno = 0; umcno < df->zud_nchan; umcno++) {
796 			const zen_umc_chan_t *chan = &df->zud_chan[umcno];
797 
798 			if (chan->chan_fabid != dec->dec_targ_fabid) {
799 				continue;
800 			}
801 
802 			/*
803 			 * At this point we have found the UMC that we were
804 			 * looking for. Snapshot that and then figure out which
805 			 * rule index of it corresponds to our mapping so we can
806 			 * properly determine an offset. We will still use the
807 			 * primary CCM rule for all other calculations.
808 			 */
809 			dec->dec_umc_chan = chan;
810 			for (uint32_t ruleno = 0; ruleno < chan->chan_nrules;
811 			    ruleno++) {
812 				const df_dram_rule_t *rule =
813 				    &chan->chan_rules[ruleno];
814 				if ((rule->ddr_flags & DF_DRAM_F_VALID) == 0) {
815 					continue;
816 				}
817 
818 				if (dec->dec_pa >= rule->ddr_base &&
819 				    dec->dec_pa < rule->ddr_limit) {
820 					dec->dec_umc_ruleno = ruleno;
821 					return (B_TRUE);
822 				}
823 			}
824 
825 			dec->dec_fail = ZEN_UMC_DECODE_F_UMC_DOESNT_HAVE_PA;
826 			return (B_FALSE);
827 		}
828 	}
829 
830 	dec->dec_fail = ZEN_UMC_DECODE_F_CANNOT_MAP_FABID;
831 	return (B_FALSE);
832 }
833 
834 /*
835  * Non-hashing interleave modes system address normalization logic. See the
836  * zen_umc.c big theory statement for more information.
837  */
838 static boolean_t
839 zen_umc_decode_normalize_nohash(const zen_umc_t *umc, zen_umc_decoder_t *dec)
840 {
841 	uint_t nbits = 0;
842 	const df_dram_rule_t *rule = dec->dec_df_rule;
843 
844 	nbits += rule->ddr_sock_ileave_bits;
845 	nbits += rule->ddr_die_ileave_bits;
846 	switch (rule->ddr_chan_ileave) {
847 	case DF_CHAN_ILEAVE_1CH:
848 		break;
849 	case DF_CHAN_ILEAVE_2CH:
850 		nbits += 1;
851 		break;
852 	case DF_CHAN_ILEAVE_4CH:
853 		nbits += 2;
854 		break;
855 	case DF_CHAN_ILEAVE_8CH:
856 		nbits += 3;
857 		break;
858 	case DF_CHAN_ILEAVE_16CH:
859 		nbits += 4;
860 		break;
861 	case DF_CHAN_ILEAVE_32CH:
862 		nbits += 5;
863 		break;
864 	default:
865 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
866 		dec->dec_fail_data = rule->ddr_chan_ileave;
867 		return (B_FALSE);
868 	}
869 
870 	/*
871 	 * If we have a really simple configuration (e.g. no interleaving at
872 	 * all), then make sure that we do not actually do anything here.
873 	 */
874 	if (nbits > 0) {
875 		dec->dec_norm_addr = bitdel64(dec->dec_norm_addr,
876 		    rule->ddr_addr_start + nbits - 1, rule->ddr_addr_start);
877 	}
878 
879 	return (B_TRUE);
880 }
881 
882 /*
883  * COD/NPS system address normalization logic. See the zen_umc.c big theory
884  * statement for more information.
885  */
886 static boolean_t
887 zen_umc_decode_normalize_hash(const zen_umc_t *umc, zen_umc_decoder_t *dec)
888 {
889 	uint_t nbits = 0;
890 	const df_dram_rule_t *rule = dec->dec_df_rule;
891 
892 	/*
893 	 * NPS hashes allow for socket interleaving, COD hashes do not. Add
894 	 * socket interleaving, skip die.
895 	 */
896 	nbits += rule->ddr_sock_ileave_bits;
897 	switch (rule->ddr_chan_ileave) {
898 	case DF_CHAN_ILEAVE_COD4_2CH:
899 	case DF_CHAN_ILEAVE_NPS4_2CH:
900 		nbits += 1;
901 		break;
902 	case DF_CHAN_ILEAVE_COD2_4CH:
903 	case DF_CHAN_ILEAVE_NPS2_4CH:
904 		nbits += 2;
905 		break;
906 	case DF_CHAN_ILEAVE_COD1_8CH:
907 	case DF_CHAN_ILEAVE_NPS1_8CH:
908 		nbits += 3;
909 		break;
910 	default:
911 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
912 		dec->dec_fail_data = rule->ddr_chan_ileave;
913 	}
914 
915 	/*
916 	 * Always remove high order bits before low order bits so we don't have
917 	 * to adjust the bits we need to remove.
918 	 */
919 	if (nbits > 1) {
920 		uint_t start = 12;
921 		uint_t end = start + (nbits - 2);
922 		dec->dec_norm_addr = bitdel64(dec->dec_norm_addr, end, start);
923 	}
924 
925 	dec->dec_norm_addr = bitdel64(dec->dec_norm_addr, rule->ddr_addr_start,
926 	    rule->ddr_addr_start);
927 	return (B_TRUE);
928 }
929 
930 /*
931  * Now it's time to perform normalization of our favorite interleaving type.
932  * Please see the comments in zen_umc.c on this to understand what we're doing
933  * here and why.
934  */
935 static boolean_t
936 zen_umc_decode_normalize_zen3_6ch(const zen_umc_t *umc, zen_umc_decoder_t *dec)
937 {
938 	uint8_t hashes[3] = { 0 };
939 	uint_t start, end;
940 	const df_dram_rule_t *rule = dec->dec_df_rule;
941 
942 	/*
943 	 * As per the theory statement, we always remove the hash bits here from
944 	 * the starting address. Because this is a 6-channel config, that turns
945 	 * into 3. Perform the hash again first.
946 	 */
947 	zen_umc_decode_hash_zen3_6ch(rule, dec->dec_norm_addr, hashes);
948 	start = rule->ddr_addr_start;
949 	end = rule->ddr_addr_start + ZEN_UMC_COD_NBITS - 1;
950 	dec->dec_norm_addr = bitdel64(dec->dec_norm_addr, end, start);
951 
952 	/*
953 	 * This is the case the theory statement warned about. This gets
954 	 * normalized to the top of the DIMM's range (its two upper most bits
955 	 * are set).
956 	 */
957 	if (hashes[1] == 1 && hashes[2] == 1) {
958 		uint_t start = 14 - ZEN_UMC_COD_NBITS +
959 		    dec->dec_umc_chan->chan_np2_space0;
960 		dec->dec_norm_addr = bitset64(dec->dec_norm_addr, start + 1,
961 		    start, 0x3);
962 	}
963 
964 	return (B_TRUE);
965 }
966 
967 /*
968  * Based on the algorithm of sorts described in zen_umc.c, we have a few
969  * different phases of extraction and combination. This isn't quite like the
970  * others where we simply delete bits.
971  */
972 static boolean_t
973 zen_umc_decode_normalize_nps_mod(const zen_umc_t *umc, zen_umc_decoder_t *dec)
974 {
975 	uint64_t low, high, mid;
976 	uint_t nbits, chan_mod, sock_bits, nmid_bits;
977 	uint_t mid_start, mid_end;
978 	uint8_t hashes[3] = { 0 };
979 	const df_dram_rule_t *rule = dec->dec_df_rule;
980 
981 	sock_bits = rule->ddr_sock_ileave_bits;
982 	switch (rule->ddr_chan_ileave) {
983 	case DF_CHAN_ILEAVE_NPS4_3CH:
984 		chan_mod = 3;
985 		nbits = 1;
986 		break;
987 	case DF_CHAN_ILEAVE_NPS2_5CH:
988 		chan_mod = 5;
989 		nbits = 1;
990 		break;
991 	case DF_CHAN_ILEAVE_NPS2_6CH:
992 		chan_mod = 3;
993 		nbits = 2;
994 		break;
995 	case DF_CHAN_ILEAVE_NPS1_10CH:
996 		chan_mod = 5;
997 		nbits = 2;
998 		break;
999 	case DF_CHAN_ILEAVE_NPS1_12CH:
1000 		chan_mod = 3;
1001 		nbits = 3;
1002 		break;
1003 	default:
1004 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
1005 		dec->dec_fail_data = rule->ddr_chan_ileave;
1006 		return (B_FALSE);
1007 	}
1008 
1009 	/*
1010 	 * First extract the low bit range that we're using which is everything
1011 	 * below the starting interleave address. We also always extract the
1012 	 * high bits, which are always [63:14] and divide it by the modulus.
1013 	 * Note, we apply the hash after any such division if needed. It becomes
1014 	 * the new least significant bit.
1015 	 */
1016 	low = bitx64(dec->dec_norm_addr, rule->ddr_addr_start - 1, 0);
1017 	high = bitx64(dec->dec_norm_addr, 63, 14) / chan_mod;
1018 	zen_umc_decode_hash_nps_mod(rule, dec->dec_norm_addr, hashes);
1019 	if (sock_bits == 0) {
1020 		high = (high << 1) | hashes[0];
1021 	}
1022 
1023 	/*
1024 	 * Now for the weirdest bit here, extracting the middle bits. Recall
1025 	 * this hash uses bit 8, then 13, then 12 (the hash order is still 8,
1026 	 * 12, 13, but it uses the hashes[2] before hashes[1] in
1027 	 * zen_umc_decode_ileave_nps_mod()). So if we're only using 1 interleave
1028 	 * bit, we just remove bit 8 (assuming that is our starting address) and
1029 	 * our range is [13:9]. If we're using two, our range becomes [12:9],
1030 	 * and if three, [11:9]. The 6 - nbits below comes from the fact that in
1031 	 * a 1 bit interleave we have 5 bits. Because our mid_start/mid_end
1032 	 * range is inclusive, we subtract one at the end from mid_end.
1033 	 */
1034 	nmid_bits = 6 - nbits;
1035 	mid_start = rule->ddr_addr_start + 1;
1036 	mid_end = mid_start + nmid_bits - 1;
1037 	mid = bitx64(dec->dec_norm_addr, mid_end, mid_start);
1038 
1039 	/*
1040 	 * Because we've been removing bits, we don't use any of the start and
1041 	 * ending ranges we calculated above for shifts, as that was what we
1042 	 * needed from the original address.
1043 	 */
1044 	dec->dec_norm_addr = low | (mid << rule->ddr_addr_start) | (high <<
1045 	    (rule->ddr_addr_start + nmid_bits));
1046 
1047 	return (B_TRUE);
1048 }
1049 
1050 /*
1051  * Now we need to go through and try to construct a normalized address using all
1052  * the information that we've gathered to date. To do this we need to take into
1053  * account all of the following transformations on the address that need to
1054  * occur. We apply modifications to the address in the following order:
1055  *
1056  *   o The base address of the rule
1057  *   o DRAM hole changes
1058  *   o Normalization of the address due to interleaving (more fun)
1059  *   o The DRAM offset register of the rule
1060  */
1061 static boolean_t
1062 zen_umc_decode_sysaddr_to_norm(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1063 {
1064 	const zen_umc_chan_t *chan = dec->dec_umc_chan;
1065 	const df_dram_rule_t *rule = dec->dec_df_rule;
1066 
1067 	dec->dec_norm_addr = dec->dec_pa;
1068 	if (!zen_umc_adjust_dram_addr(umc, dec, &dec->dec_norm_addr,
1069 	    ZEN_UMC_DECODE_F_CALC_NORM_UNDERFLOW)) {
1070 		return (B_FALSE);
1071 	}
1072 
1073 	/*
1074 	 * Now for the most annoying part of this whole thing, normalizing based
1075 	 * on our actual interleave format. The reason for this is that when
1076 	 * interleaving is going on, it actually is removing bits that are just
1077 	 * being used to direct it somewhere; however, it's actually generally
1078 	 * speaking the same value in each location. See the big theory
1079 	 * statement in zen_umc.c for more information.
1080 	 */
1081 	switch (rule->ddr_chan_ileave) {
1082 	case DF_CHAN_ILEAVE_1CH:
1083 	case DF_CHAN_ILEAVE_2CH:
1084 	case DF_CHAN_ILEAVE_4CH:
1085 	case DF_CHAN_ILEAVE_8CH:
1086 	case DF_CHAN_ILEAVE_16CH:
1087 	case DF_CHAN_ILEAVE_32CH:
1088 		if (!zen_umc_decode_normalize_nohash(umc, dec)) {
1089 			return (B_FALSE);
1090 		}
1091 		break;
1092 	case DF_CHAN_ILEAVE_COD4_2CH:
1093 	case DF_CHAN_ILEAVE_COD2_4CH:
1094 	case DF_CHAN_ILEAVE_COD1_8CH:
1095 	case DF_CHAN_ILEAVE_NPS4_2CH:
1096 	case DF_CHAN_ILEAVE_NPS2_4CH:
1097 	case DF_CHAN_ILEAVE_NPS1_8CH:
1098 		if (!zen_umc_decode_normalize_hash(umc, dec)) {
1099 			return (B_FALSE);
1100 		}
1101 		break;
1102 	case DF_CHAN_ILEAVE_6CH:
1103 		if (!zen_umc_decode_normalize_zen3_6ch(umc, dec)) {
1104 			return (B_FALSE);
1105 		}
1106 		break;
1107 	case DF_CHAN_ILEAVE_NPS4_3CH:
1108 	case DF_CHAN_ILEAVE_NPS2_6CH:
1109 	case DF_CHAN_ILEAVE_NPS1_12CH:
1110 	case DF_CHAN_ILEAVE_NPS2_5CH:
1111 	case DF_CHAN_ILEAVE_NPS1_10CH:
1112 		if (!zen_umc_decode_normalize_nps_mod(umc, dec)) {
1113 			return (B_FALSE);
1114 		}
1115 		break;
1116 	default:
1117 		dec->dec_fail = ZEN_UMC_DECODE_F_CHAN_ILEAVE_NOTSUP;
1118 		dec->dec_fail_data = rule->ddr_chan_ileave;
1119 		return (B_FALSE);
1120 	}
1121 
1122 	/*
1123 	 * Determine if this rule has an offset to apply. Note, there is never
1124 	 * an offset for rule 0, hence the index into this is one less than the
1125 	 * actual rule number. Unlike other transformations these offsets
1126 	 * describe the start of a normalized range. Therefore we need to
1127 	 * actually add this value instead of subtract.
1128 	 */
1129 	if (dec->dec_umc_ruleno > 0) {
1130 		uint32_t offno = dec->dec_umc_ruleno - 1;
1131 		const chan_offset_t *offset = &chan->chan_offsets[offno];
1132 
1133 		if (offset->cho_valid) {
1134 			dec->dec_norm_addr += offset->cho_offset;
1135 		}
1136 	}
1137 
1138 	return (B_TRUE);
1139 }
1140 
1141 /*
1142  * This applies the formula that determines a chip-select actually matches which
1143  * is defined as (address & ~mask) == (base & ~mask) in the PPR. There is both a
1144  * primary and secondary mask here. We need to pay attention to which is used
1145  * (if any) for later on.
1146  */
1147 static boolean_t
1148 zen_umc_decoder_cs_matches(const umc_cs_t *cs, const uint64_t norm,
1149     boolean_t *matched_sec)
1150 {
1151 	if (cs->ucs_base.udb_valid != 0) {
1152 		uint64_t imask = ~cs->ucs_base_mask;
1153 		if ((norm & imask) == (cs->ucs_base.udb_base & imask)) {
1154 			*matched_sec = B_FALSE;
1155 			return (B_TRUE);
1156 		}
1157 	}
1158 
1159 	if (cs->ucs_sec.udb_valid != 0) {
1160 		uint64_t imask = ~cs->ucs_sec_mask;
1161 		if ((norm & imask) == (cs->ucs_sec.udb_base & imask)) {
1162 			*matched_sec = B_TRUE;
1163 			return (B_TRUE);
1164 		}
1165 	}
1166 
1167 	return (B_FALSE);
1168 }
1169 
1170 /*
1171  * Go through with our normalized address and map it to a given chip-select.
1172  * This as a side effect indicates which DIMM we're going out on as well. Note,
1173  * the final DIMM can change due to chip-select hashing; however, we use this
1174  * DIMM for determining all of the actual address translations.
1175  */
1176 static boolean_t
1177 zen_umc_decode_find_cs(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1178 {
1179 	const zen_umc_chan_t *chan = dec->dec_umc_chan;
1180 
1181 	for (uint_t dimmno = 0; dimmno < ZEN_UMC_MAX_DIMMS; dimmno++) {
1182 		const umc_dimm_t *dimm = &chan->chan_dimms[dimmno];
1183 
1184 		if ((dimm->ud_flags & UMC_DIMM_F_VALID) == 0)
1185 			continue;
1186 
1187 		for (uint_t csno = 0; csno < ZEN_UMC_MAX_CS_PER_DIMM; csno++) {
1188 			const umc_cs_t *cs = &dimm->ud_cs[csno];
1189 			boolean_t is_sec = B_FALSE;
1190 
1191 			if (zen_umc_decoder_cs_matches(cs, dec->dec_norm_addr,
1192 			    &is_sec)) {
1193 				dec->dec_dimm = dimm;
1194 				dec->dec_cs = cs;
1195 				dec->dec_log_csno = dimmno * ZEN_UMC_MAX_DIMMS +
1196 				    csno;
1197 				dec->dec_cs_sec = is_sec;
1198 				return (B_TRUE);
1199 			}
1200 		}
1201 	}
1202 
1203 	dec->dec_fail = ZEN_UMC_DECODE_F_NO_CS_BASE_MATCH;
1204 	return (B_FALSE);
1205 }
1206 
1207 /*
1208  * Extract the column from the address. For once, something that is almost
1209  * straightforward.
1210  */
1211 static boolean_t
1212 zen_umc_decode_cols(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1213 {
1214 	uint32_t cols = 0;
1215 	const umc_cs_t *cs = dec->dec_cs;
1216 
1217 	for (uint_t i = 0; i < cs->ucs_ncol; i++) {
1218 		uint32_t index;
1219 
1220 		index = cs->ucs_col_bits[i];
1221 		cols |= bitx64(dec->dec_norm_addr, index, index) << i;
1222 	}
1223 
1224 	dec->dec_dimm_col = cols;
1225 	return (B_TRUE);
1226 }
1227 
1228 /*
1229  * The row is split into two different regions. There's a low and high value,
1230  * though the high value is only present in DDR4. Unlike the column, where each
1231  * bit is spelled out, each set of row bits are contiguous (low and high are
1232  * independent).
1233  */
1234 static boolean_t
1235 zen_umc_decode_rows(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1236 {
1237 	uint32_t row = 0;
1238 	uint8_t inv;
1239 	const umc_cs_t *cs = dec->dec_cs;
1240 	const uint_t total_bits = cs->ucs_nrow_lo + cs->ucs_nrow_hi;
1241 	const uint_t lo_end = cs->ucs_nrow_lo + cs->ucs_row_low_bit - 1;
1242 
1243 	row = bitx64(dec->dec_norm_addr, lo_end, cs->ucs_row_low_bit);
1244 	if (cs->ucs_nrow_hi > 0) {
1245 		const uint_t hi_end = cs->ucs_nrow_hi + cs->ucs_row_hi_bit - 1;
1246 		const uint32_t hi = bitx64(dec->dec_norm_addr, hi_end,
1247 		    cs->ucs_row_hi_bit);
1248 
1249 		row |= hi << cs->ucs_nrow_lo;
1250 	}
1251 
1252 	if (dec->dec_cs_sec) {
1253 		inv = cs->ucs_inv_msbs_sec;
1254 	} else {
1255 		inv = cs->ucs_inv_msbs;
1256 	}
1257 
1258 	/*
1259 	 * We need to potentially invert the top two bits of the row address
1260 	 * based on the low two bits of the inverted register below. Note, inv
1261 	 * only has two valid bits below. So we shift them into place to perform
1262 	 * the XOR. See the big theory statement in zen_umc.c for more on why
1263 	 * this works.
1264 	 */
1265 	inv = inv << (total_bits - 2);
1266 	row = row ^ inv;
1267 
1268 	dec->dec_dimm_row = row;
1269 	return (B_TRUE);
1270 }
1271 
1272 /*
1273  * Several of the hash schemes ask us to go through and xor all the bits that
1274  * are in an address to transform it into a single bit. This implements that for
1275  * a uint32_t. This is basically a bitwise XOR reduce.
1276  */
1277 static uint8_t
1278 zen_umc_running_xor32(const uint32_t in)
1279 {
1280 	uint8_t run = 0;
1281 
1282 	for (uint_t i = 0; i < sizeof (in) * NBBY; i++) {
1283 		run ^= bitx32(in, i, i);
1284 	}
1285 
1286 	return (run);
1287 }
1288 
1289 static uint8_t
1290 zen_umc_running_xor64(const uint64_t in)
1291 {
1292 	uint8_t run = 0;
1293 
1294 	for (uint_t i = 0; i < sizeof (in) * NBBY; i++) {
1295 		run ^= bitx64(in, i, i);
1296 	}
1297 
1298 	return (run);
1299 }
1300 
1301 /*
1302  * Our goal here is to extract the number of banks and bank groups that are
1303  * used, if any.
1304  */
1305 static boolean_t
1306 zen_umc_decode_banks(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1307 {
1308 	uint8_t bank = 0;
1309 	const umc_cs_t *cs = dec->dec_cs;
1310 	const umc_chan_hash_t *hash = &dec->dec_umc_chan->chan_hash;
1311 
1312 	/*
1313 	 * Get an initial bank address bit and then perform any hashing if
1314 	 * bank hashing is enabled. Note, the memory controller's nbanks is the
1315 	 * total number of bank and bank group bits, hence why it's used for
1316 	 * the loop counter.
1317 	 */
1318 	for (uint_t i = 0; i < cs->ucs_nbanks; i++) {
1319 		uint32_t row_hash, col_hash;
1320 		uint8_t row_xor, col_xor;
1321 		uint_t targ = cs->ucs_bank_bits[i];
1322 		uint8_t val = bitx64(dec->dec_norm_addr, targ, targ);
1323 		const umc_bank_hash_t *bank_hash = &hash->uch_bank_hashes[i];
1324 
1325 		if ((hash->uch_flags & UMC_CHAN_HASH_F_BANK) == 0 ||
1326 		    !hash->uch_bank_hashes[i].ubh_en) {
1327 			bank |= val << i;
1328 			continue;
1329 		}
1330 
1331 		/*
1332 		 * See the big theory statement for more on this. Short form,
1333 		 * bit-wise AND the row and column, then XOR shenanigans.
1334 		 */
1335 		row_hash = dec->dec_dimm_row & bank_hash->ubh_row_xor;
1336 		col_hash = dec->dec_dimm_col & bank_hash->ubh_col_xor;
1337 		row_xor = zen_umc_running_xor32(row_hash);
1338 		col_xor = zen_umc_running_xor32(col_hash);
1339 		bank |= (row_xor ^ col_xor ^ val) << i;
1340 	}
1341 
1342 	/*
1343 	 * The bank and bank group are conjoined in the register and bit
1344 	 * definitions. Once we've calculated that, extract it.
1345 	 */
1346 	dec->dec_dimm_bank_group = bitx8(bank, cs->ucs_nbank_groups - 1, 0);
1347 	dec->dec_dimm_bank = bitx8(bank, cs->ucs_nbanks, cs->ucs_nbank_groups);
1348 	return (B_TRUE);
1349 }
1350 
1351 /*
1352  * Extract the sub-channel. If not a DDR5 based device, simply set it to zero
1353  * and return. We can't forget to hash this if required.
1354  */
1355 static boolean_t
1356 zen_umc_decode_subchan(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1357 {
1358 	uint8_t subchan;
1359 	uint32_t row_hash, col_hash, bank_hash;
1360 	uint8_t row_xor, col_xor, bank_xor;
1361 	const umc_cs_t *cs = dec->dec_cs;
1362 	const umc_chan_hash_t *hash = &dec->dec_umc_chan->chan_hash;
1363 
1364 	switch (dec->dec_dimm->ud_type) {
1365 	case UMC_DIMM_T_DDR5:
1366 	case UMC_DIMM_T_LPDDR5:
1367 		break;
1368 	default:
1369 		dec->dec_dimm_subchan = 0;
1370 		return (B_TRUE);
1371 	}
1372 
1373 	subchan = bitx64(dec->dec_norm_addr, cs->ucs_subchan, cs->ucs_subchan);
1374 	if ((hash->uch_flags & UMC_CHAN_HASH_F_PC) == 0 ||
1375 	    !hash->uch_pc_hash.uph_en) {
1376 		dec->dec_dimm_subchan = subchan;
1377 		return (B_TRUE);
1378 	}
1379 
1380 	row_hash = dec->dec_dimm_row & hash->uch_pc_hash.uph_row_xor;
1381 	col_hash = dec->dec_dimm_col & hash->uch_pc_hash.uph_col_xor;
1382 	bank_hash = dec->dec_dimm_bank & hash->uch_pc_hash.uph_bank_xor;
1383 	row_xor = zen_umc_running_xor32(row_hash);
1384 	col_xor = zen_umc_running_xor32(col_hash);
1385 	bank_xor = zen_umc_running_xor32(bank_hash);
1386 
1387 	dec->dec_dimm_subchan = subchan ^ row_xor ^ col_xor ^ bank_xor;
1388 	return (B_TRUE);
1389 }
1390 
1391 /*
1392  * Note that we have normalized the RM bits between the primary and secondary
1393  * base/mask registers so that way even though the DDR5 controller always uses
1394  * the same RM selection bits, it works in a uniform way for both DDR4 and DDR5.
1395  */
1396 static boolean_t
1397 zen_umc_decode_rank_mul(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1398 {
1399 	uint8_t rm = 0;
1400 	const umc_cs_t *cs = dec->dec_cs;
1401 	const umc_chan_hash_t *hash = &dec->dec_umc_chan->chan_hash;
1402 
1403 	for (uint_t i = 0; i < cs->ucs_nrm; i++) {
1404 		uint8_t index = cs->ucs_rm_bits[i];
1405 		uint8_t bit = bitx64(dec->dec_norm_addr, index, index);
1406 
1407 		if ((hash->uch_flags & UMC_CHAN_HASH_F_RM) != 0 &&
1408 		    hash->uch_rm_hashes[i].uah_en) {
1409 			uint64_t norm_mask = dec->dec_norm_addr &
1410 			    hash->uch_rm_hashes[i].uah_addr_xor;
1411 			uint8_t norm_hash = zen_umc_running_xor64(norm_mask);
1412 			bit = bit ^ norm_hash;
1413 		}
1414 
1415 		rm |= bit << i;
1416 	}
1417 
1418 	dec->dec_dimm_rm = rm;
1419 	return (B_TRUE);
1420 }
1421 
1422 /*
1423  * Go through and determine the actual chip-select activated. This is subject to
1424  * hashing. Note, we first constructed a logical chip-select value based on
1425  * which of the four base/mask registers in the UMC we activated for the
1426  * channel. That basically seeded the two bit value we start with.
1427  */
1428 static boolean_t
1429 zen_umc_decode_chipsel(const zen_umc_t *umc, zen_umc_decoder_t *dec)
1430 {
1431 	uint8_t csno = 0;
1432 	const umc_cs_t *cs = dec->dec_cs;
1433 	const umc_chan_hash_t *hash = &dec->dec_umc_chan->chan_hash;
1434 
1435 	for (uint_t i = 0; i < ZEN_UMC_MAX_CS_BITS; i++) {
1436 		uint8_t bit = bitx8(dec->dec_log_csno, i, i);
1437 		if ((hash->uch_flags & UMC_CHAN_HASH_F_CS) != 0 &&
1438 		    hash->uch_cs_hashes[i].uah_en) {
1439 			uint64_t mask = dec->dec_norm_addr &
1440 			    hash->uch_cs_hashes[i].uah_addr_xor;
1441 			uint8_t rxor = zen_umc_running_xor64(mask);
1442 			bit = bit ^ rxor;
1443 		}
1444 		csno |= bit << i;
1445 	}
1446 
1447 	/*
1448 	 * It is not entirely clear what the circumstances are that we need to
1449 	 * apply the chip-select xor. Right now we always apply it. This only
1450 	 * exists on a few DDR5 SoCs, it seems, and we zero out other cases to
1451 	 * try and have a uniform and reasonable path. This tells us what the
1452 	 * absolute chip-select is in the channel. We record this for debugging
1453 	 * purposes and to derive the DIMM and CS.
1454 	 */
1455 	dec->dec_chan_csno = (csno ^ cs->ucs_cs_xor) & 0x3;
1456 
1457 	/*
1458 	 * Now that we actually know which chip-select we're targeting, go back
1459 	 * and actual indicate which DIMM we'll go out to and what chip-select
1460 	 * it is relative to the DIMM. This may have changed out due to CS
1461 	 * hashing. As such we have to now snapshot our final DIMM and
1462 	 * chip-select.
1463 	 */
1464 	dec->dec_dimm_no = dec->dec_chan_csno >> 1;
1465 	dec->dec_dimm_csno = dec->dec_chan_csno % 2;
1466 	return (B_TRUE);
1467 }
1468 
1469 /*
1470  * Initialize the decoder state. We do this by first zeroing it all and then
1471  * setting various result addresses to the UINTXX_MAX that is appropriate. These
1472  * work as better sentinel values than zero; however, we always zero the
1473  * structure to be defensive, cover pointers, etc.
1474  */
1475 static void
1476 zen_umc_decoder_init(zen_umc_decoder_t *dec)
1477 {
1478 	bzero(dec, sizeof (*dec));
1479 
1480 	dec->dec_pa = dec->dec_ilv_pa = UINT64_MAX;
1481 	dec->dec_df_ruleno = UINT32_MAX;
1482 	dec->dec_ilv_sock = dec->dec_ilv_die = dec->dec_ilv_chan =
1483 	    dec->dec_ilv_fabid = dec->dec_log_fabid = dec->dec_remap_comp =
1484 	    dec->dec_targ_fabid = UINT32_MAX;
1485 	dec->dec_umc_ruleno = UINT32_MAX;
1486 	dec->dec_norm_addr = UINT64_MAX;
1487 	dec->dec_dimm_col = dec->dec_dimm_row = UINT32_MAX;
1488 	dec->dec_log_csno = dec->dec_dimm_bank = dec->dec_dimm_bank_group =
1489 	    dec->dec_dimm_subchan = dec->dec_dimm_rm = dec->dec_chan_csno =
1490 	    dec->dec_dimm_no = dec->dec_dimm_csno = UINT8_MAX;
1491 }
1492 
1493 boolean_t
1494 zen_umc_decode_pa(const zen_umc_t *umc, const uint64_t pa,
1495     zen_umc_decoder_t *dec)
1496 {
1497 	zen_umc_decoder_init(dec);
1498 	dec->dec_pa = pa;
1499 
1500 	/*
1501 	 * Before we proceed through decoding, the first thing we should try to
1502 	 * do is verify that this is even something that could be DRAM.
1503 	 */
1504 	if (!zen_umc_decode_is_dram(umc, dec)) {
1505 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1506 		return (B_FALSE);
1507 	}
1508 
1509 	/*
1510 	 * The very first thing that we need to do is find a data fabric rule
1511 	 * that corresponds to this memory address. This will be used to
1512 	 * determine which set of rules for interleave and related we actually
1513 	 * should then use.
1514 	 */
1515 	if (!zen_umc_decode_find_df_rule(umc, dec)) {
1516 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1517 		return (B_FALSE);
1518 	}
1519 
1520 	/*
1521 	 * Now that we have a DF rule, we must take a more involved step of
1522 	 * mapping to a given CS, e.g. a specific UMC channel. This will tell us
1523 	 * the socket and die as well. This takes care of all the interleaving
1524 	 * and remapping and produces a target fabric ID.
1525 	 */
1526 	if (!zen_umc_decode_sysaddr_to_csid(umc, dec)) {
1527 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1528 		return (B_FALSE);
1529 	}
1530 
1531 	/*
1532 	 * With that target ID known, now actually map this to a corresponding
1533 	 * UMC.
1534 	 */
1535 	if (!zen_umc_decode_find_umc_rule(umc, dec)) {
1536 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1537 		return (B_FALSE);
1538 	}
1539 
1540 	/*
1541 	 * With the target and corresponding rules and offset information,
1542 	 * actually perform normalization.
1543 	 */
1544 	if (!zen_umc_decode_sysaddr_to_norm(umc, dec)) {
1545 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1546 		return (B_FALSE);
1547 	}
1548 
1549 	/*
1550 	 * Finally, we somehow managed to actually construct a normalized
1551 	 * address. Now we must begin the act of transforming this channel
1552 	 * address into something that makes sense to address a DIMM. To start
1553 	 * with determine which logical chip-select, which determines where we
1554 	 * source all our data to use.
1555 	 */
1556 	if (!zen_umc_decode_find_cs(umc, dec)) {
1557 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1558 		return (B_FALSE);
1559 	}
1560 
1561 	/*
1562 	 * Now that we have the logical chip-select matched that we're sourcing
1563 	 * our data from, the next this is a bit more involved: we need to
1564 	 * extract the row, column, rank/rank multiplication, bank, and bank
1565 	 * group out of all this, while taking into account all of our hashes.
1566 	 *
1567 	 * To do this, we begin by first calculating the row and column as those
1568 	 * will be needed to determine some of our other values here.
1569 	 */
1570 	if (!zen_umc_decode_rows(umc, dec)) {
1571 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1572 		return (B_FALSE);
1573 	}
1574 
1575 	if (!zen_umc_decode_cols(umc, dec)) {
1576 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1577 		return (B_FALSE);
1578 	}
1579 
1580 	/*
1581 	 * Now that we have the rows and columns we can go through and determine
1582 	 * the bank and bank group. This depends on the above.
1583 	 */
1584 	if (!zen_umc_decode_banks(umc, dec)) {
1585 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1586 		return (B_FALSE);
1587 	}
1588 
1589 	/*
1590 	 * If we have a DDR5 generation DIMM then we need to consider the
1591 	 * subchannel. This doesn't exist in DDR4 systems (the function handles
1592 	 * this reality). Because of potential hashing, this needs to come after
1593 	 * the row, column, and bank have all been determined.
1594 	 */
1595 	if (!zen_umc_decode_subchan(umc, dec)) {
1596 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1597 		return (B_FALSE);
1598 	}
1599 
1600 	/*
1601 	 * Time for the last two pieces here: the actual chip select used and
1602 	 * then figuring out which rank, taking into account rank
1603 	 * multiplication. Don't worry, these both have hashing opportunities.
1604 	 */
1605 	if (!zen_umc_decode_rank_mul(umc, dec)) {
1606 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1607 		return (B_FALSE);
1608 	}
1609 
1610 	if (!zen_umc_decode_chipsel(umc, dec)) {
1611 		ASSERT3U(dec->dec_fail, !=, ZEN_UMC_DECODE_F_NONE);
1612 		return (B_FALSE);
1613 	}
1614 
1615 	/*
1616 	 * Somehow, that's it.
1617 	 */
1618 	return (B_TRUE);
1619 }
1620