

# Progetto di modulo DDR5 UDIMM 2R×8 (PC5-5600)

Un modulo DDR5 UDIMM a doppio rango (2R×8, non-ECC) utilizza 288 pin conformi agli standard JEDEC (tensione VDD/VDDQ = 1,1 V nominale <sup>1</sup>) e fornisce due **sub-canali indipendenti a 32 bit** (canale A e B, totale 64 bit dati) <sup>2</sup>. Ciascun rango contiene 8 chip di DRAM x8, per un totale di 16 chip su moduli 32 GB (es. 16×16 Gb = 256 Gb = 32 GB <sup>3</sup>). Di seguito i componenti e le caratteristiche principali:

## 1. Organizzazione e componenti del modulo

- **Chip DRAM DDR5:** 8 dispositivi per rango, organizzazione x8. Ad esempio, un modulo 32 GB 2Rx8 può impiegare **16 chip DDR5-16 Gb x8** (die A o M di Hynix, Micron, Samsung, ecc.) <sup>3</sup>. Ogni chip include un resistore di calibrazione ZQ esterno da  $\sim 240\Omega$  <sup>4</sup>. Le tensioni di alimentazione principali sono  $VDD=VDDQ\approx 1,1\text{ V}$  e  $VPP\approx 1,8\text{ V}$ , generate dal PMIC a bordo <sup>1</sup> <sup>5</sup>.
- **PMIC (Power Management IC):** su DDR5 il regolatore di potenza è on-board. JEDEC definisce lo **std. PMIC5100**, un IC di fabbricazione Renesas (es. **P8911**), in package FCQFN 3x4 mm <sup>6</sup>. Il PMIC riceve  $VIN\_BULK = 5\text{ V}$  dal connettore e genera  $VDD$ ,  $VDDQ$  (1.1 V),  $VPP$  ( $\approx 1.8\text{ V}$ ) e due LDO integrati (1.8 V e 1.0 V) per alimentare, ad esempio, l'SPD hub <sup>1</sup> <sup>7</sup>. Il PMIC gestisce la sequenza di power-up/down, offre monitoraggio via bus laterale (I<sub>3</sub>C/I<sup>2</sup>C) e segnala il "power good" (PWR\_GOOD) a host <sup>6</sup> <sup>8</sup>.
- **SPD Hub (EEPROM con hub I<sub>3</sub>C):** i moduli DDR5 includono un "hub SPD" con EEPROM da 1024 byte (16×64 B) conforme a JEDEC JESD400-5 <sup>9</sup>. Esempio: **Renesas SPD5118** (hub SPD5) opera a 1.8 V con uscita LDO 1.0 V e supporta bus I<sub>3</sub>C (compatibile I<sup>2</sup>C) fino a 12.5 MHz <sup>9</sup> <sup>10</sup>. L'SPD memorizza dati JEDEC standard (primi 640 B) e dati utente, oltre a includere un sensore di temperatura integrato opzionale <sup>9</sup>.
- **Capacitori e terminazioni:** ogni DRAM ha condensatori di decoupling sulle alimentazioni (tipicamente  $0.1\mu\text{F} + 0.01\mu\text{F}$  accanto ai pin VDD/VDDQ di ciascun chip) e condensatori bulk ( $\sim 10\mu\text{F}$ ) vicino al PMIC e al connettore. Il bus di indirizzi/comando/clock è routato in topologia *fly-by*, con terminazione passiva (VTT) al fondo del bus <sup>11</sup>. I segnali di address/comando e di clock presentano terminazioni resistive dedicate all'estremità del percorso, per ridurre riflessioni. Su HSA/HSCL/HSDA (I<sub>3</sub>C) e PWR\_GOOD servono pull-up sulle linee dati e PWR\_GOOD (open-drain) come specificato <sup>12</sup> <sup>13</sup>. Il pin PWR\_EN permette di abilitare il PMIC via hardware (tipicamente tirato su a 3.3 V o 5 V) <sup>14</sup>.

**Tabella 1 – Componenti principali di un DDR5 UDIMM**

| Componente        | Esempio (parte)                 | Funzione                                                                                                                                                                            |
|-------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chip DRAM DDR5 x8 | Hynix<br>H5CG48MEBDX<br>(16 Gb) | Celle di memoria, 8 chip per rango (2R×8 = 16 chip) <sup>3</sup> . Alimentazione $VDD/VDDQ=1.1\text{ V}$ , $VPP=1.8\text{ V}$ . $ZQ=240\Omega/\pm 1\%$ per ogni chip <sup>4</sup> . |

| Componente                              | Esempio (parte)                   | Funzione                                                                                                                                                                                                                                         |
|-----------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PMIC (DC-DC/<br>LDO)                    | Renesas P8911<br>(JEDEC PMIC5100) | Converte 5 V VIN_BULK in VDD, VDDQ, VPP, LDO 1.8V/1.0V. Gestione power sequencing, monitoraggio via I3C, 10W output <a href="#">6</a> <a href="#">7</a> .                                                                                        |
| Hub SPD /<br>EEPROM                     | Renesas SPD5118                   | EEPROM 1 kB I3C (o I <sup>2</sup> C) con 16×64B, SPD standard e sensore T integrato <a href="#">9</a> <a href="#">10</a> . Isola il bus modulo interno dall'host.                                                                                |
| Resistenze di<br>calibrazione (ZQ)      | -                                 | 240 Ω/±1% ciascuna, per impostare I/O impedance dei DRAM <a href="#">4</a> .                                                                                                                                                                     |
| Condensatori<br>decoupling bulk e<br>HF | -                                 | Esempio: 2×10 µF (bulk) su VIN_BULK; 0.1/0.01 µF vicino a VDD, VDDQ di ogni DRAM e al PMIC; decoupling LDO (1.8V,1.0V).                                                                                                                          |
| Terminazioni/<br>terminatori            | -                                 | Resistenze di terminazione VTT sui segnali CA/clock in topologia fly-by (capacitive-divider interne o array di terminatori) <a href="#">11</a> . Resistenze pull-up su PWR_GOOD e bus I3C come richiesto <a href="#">13</a> <a href="#">12</a> . |

## 2. Layout del PCB (dimensioni e norme JEDEC)

- Il modulo DDR5 UDIMM è **288-pin, dimensioni 133,35×31,25 mm** (tolleranze ±0,15 mm) [15](#). È conforme a JESD-260B e JEDEC DDR5 unbuffered DIMM standard. Il PCB è generalmente a 6-8 layer (tipicamente FR4, stackup controllato per impedenza), con ampio piano di massa VSS [11](#) [16](#).
- **Topologia bus:** indirizzi/controllo/clock seguono schema *fly-by*: il segnale passa da un chip all'altro e termina all'estremità con resistenza a VTT [11](#). I segnali differenziali di clock (CK0\_t/CK0\_c e CK1\_t/CK1\_c) alimentano due sub-canali (uno per ogni metà del bus dati). La coerenza temporale richiede accoppiamenti attentamente bilanciati: ogni gruppo di segnali (CK, command, address, DQS, DQ) ha regole di routing specifiche e *length matching* (ex. differenze minime tra DQ e relativo DQS) [11](#).
- **Distribuzione dei chip:** in un modulo dual-rank 2Rx8 i chip DRAM sono disposti su entrambi i lati del PCB (solitamente 8 per lato). L'addendum del datasheet (MPN-specific) definisce esattamente le posizioni ("Primary side", "Secondary side"). Per esempio, Micron mostra in addendum che in un UDIMM 16 GB SR tutti i chip sono su un solo lato [17](#), mentre moduli 2R ne utilizzano entrambi. Anche il PMIC e l'SPD hub sono tipicamente posizionati sul lato principale, vicini al connettore.
- **Regole di layout:** decoupling vicino alle pin di alimentazione (ad. es. condensatori posizionati subito accanto a VDD, VDDQ dei chip e al VIN\_BULK). Plane di massa ininterrotto sotto tutti i segnali ad alta frequenza. Controllo di impedenza per DQ/DQS (es. 45 Ω) e per CMD/CA/CK (es. 50–60 Ω) [11](#). Non esistono gerber o progetti pubblici completi disponibili: si fa riferimento agli standard JEDEC (es. JESD260 per dimensioni meccaniche, JESD79-5 per DRAM) e ai datasheet dei produttori (che forniscono linee guida di layout e addendum specifici).

### 3. Segnali e tensioni

- **Segnali dati:** 64 bit *parallel* DQ (DQ0–DQ63 divisi in *canale A* e *canale B*, ciascuno 32 bit) più eventuali bit CB (ECC) o PARITY. I rispettivi strobo (DQS\_t/DQS\_c) sono 10 coppie per canale (una per byte) <sup>18</sup>. DDR5 introduce anche segnali di *loopback* per il training: LBDQ0–LBDQ3 e LBDQS0–LBDQS3 (4 coppie) che rinviano parte dei dati al controller in lettura di livellamento bilanciamento <sup>9</sup> <sup>19</sup>.
- **Segnali di clock e address/command:** sono ripartiti su due sub-canali da 32 bit. Tipicamente CK0\_/\_CK1\_ (true/complement) per ogni canale. CA[12:0]\_A/B (indirizzo e comandi), CS0\_n/CS1\_n per rank (due chip-select per ogni sub-canale), e segnali CKE, ODT, RAS, CAS, WE, parity (PAR\_A/ PAR\_B) come in DDR4, ma raddoppiati per i due sub-canali. Il pin MIR di ciascun chip determina lo *address mirroring* (collegato a VSS o VDDQ) <sup>20</sup>.
- **Bus laterale (sideband):** DDR5 usa MIPI I3C Basic (compatibile I<sup>2</sup>C) sul bus sideband ("Host Sideband Bus", HSB). Ci sono i pin HSCL (clock) e HSDA (data) condivisi per tutti i dispositivi lato modulo, e fino a tre pin HSA, HSB, HSC usati come address fisici del device sul bus <sup>9</sup> <sup>12</sup>. Tipicamente sull'UDIMM ci sono HSCL, HSDA, HSA (3-bit address) e anche 3 pin HSB e HSC per indirizzare più dispositivi I3C. SPD hub, PMIC e sensori si vedono su questo bus. HSCL e HSDA vanno con pull-up interni/esterni tipici I2C/I3C.
- **Reset e controllo:** RESET\_n attivo basso resetta tutti i DRAM. PWR\_EN è un input che abilita le uscite del PMIC: se tenuto basso, il PMIC disabilita i regolatori (le LDO restano su) <sup>14</sup>. PWR\_GOOD è un segnale Open-Drain dal PMIC che viene tirato basso in caso di guasto tensione e rilasciato in HIGH quando VIN\_BULK 5V e le tensioni regolate sono *good* <sup>13</sup>.
- **Tensioni operative:** VIN\_BULK = 5V dal sistema <sup>1</sup>. Il PMIC converte il 5V in: **VDD/VDDQ = 1,1V** (min 1,067 – max 1,166V), e **VPP = 1,8V** (min 1,746 – max 1,908V) <sup>1</sup> <sup>21</sup>. I pin VDD, VDDQ possono tollerare fino a ~1,5V max <sup>5</sup>. Il PMIC fornisce inoltre un LDO 1,8V e uno 1,0V (usati tipicamente per alimentare l'SPD hub e altri chip a basso voltaggio) <sup>1</sup> <sup>7</sup>. Tutti i segnali I/O (DQ, CA, CK, ecc.) sono a 1.1 V <sup>1</sup>.

**Tabella 2 – Segnali chiave di un DDR5 UDIMM**

| Segnale                                           | Funzione                              | Note / Valori tipici                                                             |
|---------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------|
| CK0_t/c, CK1_t/c                                  | Clock differenziale (2 coppie)        | Due clock differentiali, uno per sub-canale.                                     |
| DQ0–DQ63                                          | Linee dati (64 bit totale)            | Parallel bus dati, due canali da 32 bit <sup>2</sup> .                           |
| DQS0–DQS9_t/c (A,B)                               | Data Strobes (20 coppie)              | Strobo differenziali associati ai byte, uno per 8 bit data.                      |
| LBDQS0–3_t/c; LBDQ0–3                             | Loopback strobes/dati (4 coppie)      | Per training dati (DDR5 only) <sup>9</sup> <sup>19</sup> .                       |
| CA[12:0]_A/B, RAS, CAS, WE, CS0/1_n_A/B, CKE, ODT | Address/Command, Chip Select, Control | Indirizzi e comandi (13+), 2 CS per sub-canale. Topologia fly-by <sup>11</sup> . |

| Segnale                  | Funzione                             | Note / Valori tipici                                                                 |
|--------------------------|--------------------------------------|--------------------------------------------------------------------------------------|
| PAR_A/B                  | Parity bit ECC (solo x72)            | Parity per canale (8 bit) se modulo ECC.                                             |
| RESET_n                  | Reset asincrono attivo basso         | Reset globale dei DRAM.                                                              |
| HSCL, HSDA, HSA (HsbA-C) | I3C Basic sideband bus               | Bus di controllo di modulo: clock, data e indirizzi hardware (3 bit) <sup>12</sup> . |
| PWR_EN                   | Abilita PMIC                         | High→PMIC on; Low→PMIC off <sup>14</sup> .                                           |
| PWR_GOOD                 | Power-good open-drain                | Segnale dal PMIC verso l'host per indicare ok power <sup>13</sup> .                  |
| VIN_BULK (5V)            | Ingresso principale 5V               | Alimenta il PMIC (5V fornito dal sistema) <sup>1</sup> .                             |
| VDD, VDDQ                | Alimentazione core e I/O DRAM (1.1V) | Uscite PMIC verso DRAM.                                                              |
| VPP                      | Tensione pump dei DRAM (~1.8V)       | Uscita PMIC. Deve essere sempre $\geq$ VDD+300mV <sup>5</sup> .                      |

## 4. Standard e riferimenti

- **JEDEC:** lo standard JESD260B (288-pin unbuffered DIMM) definisce le dimensioni meccaniche del modulo <sup>15</sup>. JESD79-5 (o successivo) descrive le specifiche elettriche delle DRAM DDR5. La sezione *PMIC* del datasheet (es. JESD301-2) dettaglia il comportamento del PMIC DDR5 <sup>6</sup>.
- **Datasheet del modulo:** i produttori (Micron, Hynix, Samsung, ecc.) pubblicano datasheet "UDIMM Core" e relativi *addendum* specifici per ciascun modulo. Ad esempio, il datasheet Micron riporta i valori elettrici, pinout completo e un diagramma blocchi del modulo <sup>22</sup> <sup>23</sup>. Gli addendum MPN-specific indicano il posizionamento dei chip e componenti (es. il layout di 1 rank o 2 rank) <sup>17</sup> <sup>15</sup>.
- **Linee guida PCB:** risorse come guide di Intel, AMD, o blog tecnici Altium/JESD (ESD/E3/E4) forniscono consigli di routing high-speed per DDR5 (matching, sequenze di instradamento, impedenza). In particolare, DDR5 richiede un preciso allineamento dei segnali DQ/DQS e un'attenta suddivisione in subconvoluzioni per indirizzi e dati.
- **File di progetto e Gerber:** non esistono gerber pubblici completi di moduli DDR5 (sono proprietà dei produttori). Alcuni esempi open-source riguardano solo schede di test/interposizione (es. un "interposer" GitHub <sup>16</sup>). Per lo sviluppo da zero si fa riferimento a blueprint standard (JESD) e a revisione dei componenti.

In sintesi, un modulo DDR5 PC5-5600 UDIMM 2R×8 integra 16 chip DRAM x8 (due ranghi), un PMIC DDR5 (JEDEC PMIC5100) per la potenza, un hub SPD I3C (per l'EEPROM 1 KB) e circuiteria passiva (resistenze di calibrazione ZQ, terminazioni, condensatori di disaccoppiamento). Il PCB segue le regole JEDEC (fly-by topology, voltaggi 5V→1.1V/1.8V, bus MIPI I3C) <sup>1</sup> <sup>6</sup>. Le specifiche dettagliate si trovano nelle norme JEDEC e nei datasheet addendum dei produttori (Micron, SK Hynix, Samsung, Renesas, ecc.) citati sopra.

**Fonti:** Specifiche JEDEC e datasheet Micron/Hynix/ADI. In particolare, *Micron DDR5 UDIMM Core* <sup>22</sup> <sup>23</sup>, *Micron UDIMM Addendum* (parametri modulo) <sup>17</sup>, *Renesas SPD5118/P8911* <sup>6</sup> <sup>10</sup> <sup>7</sup>, *ADATA DDR5 U-DIMM datasheet* (pinout, SPD) <sup>18</sup> <sup>9</sup> e informazioni JEDEC sul PMIC <sup>6</sup>. Altri dettagli di layout derivano da guide PCB DDR5 (Altium, Intel) e documentazione JEDEC.

---

<sup>1</sup> <sup>2</sup> <sup>6</sup> <sup>8</sup> <sup>9</sup> <sup>11</sup> <sup>15</sup> <sup>20</sup> <sup>22</sup> <sup>23</sup> **DDR5 SDRAM UDIMM Core**

<https://gzhls.at/blob/ldb/f/a/8/7/01a8d2e592a701b7b7658543a3bc564a3c76.pdf>

<sup>3</sup> **computing\_DDR5(M-die)based\_UDIMMs(Rev.1.0)\_0429.pdf**

<https://gzhls.at/blob/ldb/b/e/5/8/5bc212f7c92604fd3737505ee4c96014733c.pdf>

<sup>4</sup> <sup>18</sup> <sup>19</sup> **positivoempresas.com.br**

<https://www.positivoempresas.com.br/wp-content/uploads/2024/12/Mem%C3%B3ria-ADATA-16GB-DDR5-DIMM-Desktop.pdf>

<sup>5</sup> <sup>12</sup> <sup>13</sup> <sup>14</sup> <sup>21</sup> **cdn.iceshop.nl**

[https://cdn.iceshop.nl/objects/mmo\\_97484524\\_1719500576\\_4794\\_27393.pdf](https://cdn.iceshop.nl/objects/mmo_97484524_1719500576_4794_27393.pdf)

<sup>7</sup> **P8911 - DDR5 Client PMIC for UDIMMs and SODIMMs | Renesas**

[https://www.renesas.com/en/products/p8911?srsltid=AfmBOopSy9LJaxX3GyhB\\_Cd\\_wPPt2XASgau5yURgfvn4225AXoRicCZK](https://www.renesas.com/en/products/p8911?srsltid=AfmBOopSy9LJaxX3GyhB_Cd_wPPt2XASgau5yURgfvn4225AXoRicCZK)

<sup>10</sup> **SPD5118 - SPD HUB for DDR5 Memory Modules | Renesas**

[https://www.renesas.com/en/products/spd5118?srsltid=AfmBOop7JDvcpw0y3j\\_j61INVKwTfqRNK3-O5mwxjVTvrAHI\\_egb1Tlf](https://www.renesas.com/en/products/spd5118?srsltid=AfmBOop7JDvcpw0y3j_j61INVKwTfqRNK3-O5mwxjVTvrAHI_egb1Tlf)

<sup>16</sup> **GitHub - refault-artifacts/fault-injection-interposer: Hardware design files of the fault injection interposer used in REFault: A Fault Injection Platform for Rowhammer Research on DDR5 Memory.**

<https://github.com/refault-artifacts/fault-injection-interposer>

<sup>17</sup> **DDR5 SDRAM UDIMM Addendum**

[https://www.mouser.it/datasheet/2/671/mtc8c1084s1uc\\_srx8\\_udimm\\_diereva-3193802.pdf?srsltid=AfmBOoqK3SZIXgGLdvjLxwFOrvnWpznHHsijCsD8\\_BbDjFa0B30oH6Bb](https://www.mouser.it/datasheet/2/671/mtc8c1084s1uc_srx8_udimm_diereva-3193802.pdf?srsltid=AfmBOoqK3SZIXgGLdvjLxwFOrvnWpznHHsijCsD8_BbDjFa0B30oH6Bb)