1 /* 2 * QEMU PowerPC 4xx embedded processors SDRAM controller emulation 3 * 4 * DDR SDRAM controller: 5 * Copyright (c) 2007 Jocelyn Mayer 6 * 7 * Permission is hereby granted, free of charge, to any person obtaining a copy 8 * of this software and associated documentation files (the "Software"), to deal 9 * in the Software without restriction, including without limitation the rights 10 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 11 * copies of the Software, and to permit persons to whom the Software is 12 * furnished to do so, subject to the following conditions: 13 * 14 * The above copyright notice and this permission notice shall be included in 15 * all copies or substantial portions of the Software. 16 * 17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 18 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 20 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 21 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 22 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 23 * THE SOFTWARE. 24 * 25 * DDR2 SDRAM controller: 26 * Copyright (c) 2012 François Revol 27 * Copyright (c) 2016-2019 BALATON Zoltan 28 * 29 * This work is licensed under the GNU GPL license version 2 or later. 30 */ 31 32 #include "qemu/osdep.h" 33 #include "qemu/units.h" 34 #include "qapi/error.h" 35 #include "qemu/log.h" 36 #include "qemu/error-report.h" 37 #include "exec/address-spaces.h" /* get_system_memory() */ 38 #include "hw/irq.h" 39 #include "hw/qdev-properties.h" 40 #include "hw/ppc/ppc4xx.h" 41 #include "trace.h" 42 43 /*****************************************************************************/ 44 /* Shared functions */ 45 46 /* 47 * Split RAM between SDRAM banks. 48 * 49 * sdram_bank_sizes[] must be in descending order, that is sizes[i] > sizes[i+1] 50 * and must be 0-terminated. 51 * 52 * The 4xx SDRAM controller supports a small number of banks, and each bank 53 * must be one of a small set of sizes. The number of banks and the supported 54 * sizes varies by SoC. 55 */ 56 static bool ppc4xx_sdram_banks(MemoryRegion *ram, int nr_banks, 57 Ppc4xxSdramBank ram_banks[], 58 const ram_addr_t sdram_bank_sizes[], 59 Error **errp) 60 { 61 ERRP_GUARD(); 62 ram_addr_t size_left = memory_region_size(ram); 63 ram_addr_t base = 0; 64 ram_addr_t bank_size; 65 int i; 66 int j; 67 68 for (i = 0; i < nr_banks; i++) { 69 for (j = 0; sdram_bank_sizes[j] != 0; j++) { 70 bank_size = sdram_bank_sizes[j]; 71 if (bank_size <= size_left) { 72 char name[32]; 73 74 ram_banks[i].base = base; 75 ram_banks[i].size = bank_size; 76 base += bank_size; 77 size_left -= bank_size; 78 snprintf(name, sizeof(name), "ppc4xx.sdram%d", i); 79 memory_region_init_alias(&ram_banks[i].ram, NULL, name, ram, 80 ram_banks[i].base, ram_banks[i].size); 81 break; 82 } 83 } 84 if (!size_left) { 85 /* No need to use the remaining banks. */ 86 break; 87 } 88 } 89 90 if (size_left) { 91 ram_addr_t used_size = memory_region_size(ram) - size_left; 92 GString *s = g_string_new(NULL); 93 94 for (i = 0; sdram_bank_sizes[i]; i++) { 95 g_string_append_printf(s, "%" PRIi64 "%s", 96 sdram_bank_sizes[i] / MiB, 97 sdram_bank_sizes[i + 1] ? ", " : ""); 98 } 99 error_setg(errp, "Invalid SDRAM banks"); 100 error_append_hint(errp, "at most %d bank%s of %s MiB each supported\n", 101 nr_banks, nr_banks == 1 ? "" : "s", s->str); 102 error_append_hint(errp, "Possible valid RAM size: %" PRIi64 " MiB\n", 103 used_size ? used_size / MiB : sdram_bank_sizes[i - 1] / MiB); 104 105 g_string_free(s, true); 106 return false; 107 } 108 return true; 109 } 110 111 static void sdram_bank_map(Ppc4xxSdramBank *bank) 112 { 113 trace_ppc4xx_sdram_map(bank->base, bank->size); 114 memory_region_init(&bank->container, NULL, "sdram-container", bank->size); 115 memory_region_add_subregion(&bank->container, 0, &bank->ram); 116 memory_region_add_subregion(get_system_memory(), bank->base, 117 &bank->container); 118 } 119 120 static void sdram_bank_unmap(Ppc4xxSdramBank *bank) 121 { 122 trace_ppc4xx_sdram_unmap(bank->base, bank->size); 123 memory_region_del_subregion(get_system_memory(), &bank->container); 124 memory_region_del_subregion(&bank->container, &bank->ram); 125 object_unparent(OBJECT(&bank->container)); 126 } 127 128 static void sdram_bank_set_bcr(Ppc4xxSdramBank *bank, uint32_t bcr, 129 hwaddr base, hwaddr size, int enabled) 130 { 131 if (memory_region_is_mapped(&bank->container)) { 132 sdram_bank_unmap(bank); 133 } 134 bank->bcr = bcr; 135 bank->base = base; 136 bank->size = size; 137 if (enabled && (bcr & 1)) { 138 sdram_bank_map(bank); 139 } 140 } 141 142 enum { 143 SDRAM0_CFGADDR = 0x010, 144 SDRAM0_CFGDATA = 0x011, 145 }; 146 147 /*****************************************************************************/ 148 /* DDR SDRAM controller */ 149 #define SDRAM_DDR_BCR_MASK 0xFFDEE001 150 151 static uint32_t sdram_ddr_bcr(hwaddr ram_base, hwaddr ram_size) 152 { 153 uint32_t bcr; 154 155 switch (ram_size) { 156 case 4 * MiB: 157 bcr = 0; 158 break; 159 case 8 * MiB: 160 bcr = 0x20000; 161 break; 162 case 16 * MiB: 163 bcr = 0x40000; 164 break; 165 case 32 * MiB: 166 bcr = 0x60000; 167 break; 168 case 64 * MiB: 169 bcr = 0x80000; 170 break; 171 case 128 * MiB: 172 bcr = 0xA0000; 173 break; 174 case 256 * MiB: 175 bcr = 0xC0000; 176 break; 177 default: 178 qemu_log_mask(LOG_GUEST_ERROR, 179 "%s: invalid RAM size 0x%" HWADDR_PRIx "\n", __func__, 180 ram_size); 181 return 0; 182 } 183 bcr |= ram_base & 0xFF800000; 184 bcr |= 1; 185 186 return bcr; 187 } 188 189 static inline hwaddr sdram_ddr_base(uint32_t bcr) 190 { 191 return bcr & 0xFF800000; 192 } 193 194 static hwaddr sdram_ddr_size(uint32_t bcr) 195 { 196 int sh = (bcr >> 17) & 0x7; 197 198 if (sh == 7) { 199 return -1; 200 } 201 202 return (4 * MiB) << sh; 203 } 204 205 static uint32_t sdram_ddr_dcr_read(void *opaque, int dcrn) 206 { 207 Ppc4xxSdramDdrState *s = opaque; 208 uint32_t ret; 209 210 switch (dcrn) { 211 case SDRAM0_CFGADDR: 212 ret = s->addr; 213 break; 214 case SDRAM0_CFGDATA: 215 switch (s->addr) { 216 case 0x00: /* SDRAM_BESR0 */ 217 ret = s->besr0; 218 break; 219 case 0x08: /* SDRAM_BESR1 */ 220 ret = s->besr1; 221 break; 222 case 0x10: /* SDRAM_BEAR */ 223 ret = s->bear; 224 break; 225 case 0x20: /* SDRAM_CFG */ 226 ret = s->cfg; 227 break; 228 case 0x24: /* SDRAM_STATUS */ 229 ret = s->status; 230 break; 231 case 0x30: /* SDRAM_RTR */ 232 ret = s->rtr; 233 break; 234 case 0x34: /* SDRAM_PMIT */ 235 ret = s->pmit; 236 break; 237 case 0x40: /* SDRAM_B0CR */ 238 ret = s->bank[0].bcr; 239 break; 240 case 0x44: /* SDRAM_B1CR */ 241 ret = s->bank[1].bcr; 242 break; 243 case 0x48: /* SDRAM_B2CR */ 244 ret = s->bank[2].bcr; 245 break; 246 case 0x4C: /* SDRAM_B3CR */ 247 ret = s->bank[3].bcr; 248 break; 249 case 0x80: /* SDRAM_TR */ 250 ret = -1; /* ? */ 251 break; 252 case 0x94: /* SDRAM_ECCCFG */ 253 ret = s->ecccfg; 254 break; 255 case 0x98: /* SDRAM_ECCESR */ 256 ret = s->eccesr; 257 break; 258 default: /* Error */ 259 ret = -1; 260 break; 261 } 262 break; 263 default: 264 /* Avoid gcc warning */ 265 ret = 0; 266 break; 267 } 268 269 return ret; 270 } 271 272 static void sdram_ddr_dcr_write(void *opaque, int dcrn, uint32_t val) 273 { 274 Ppc4xxSdramDdrState *s = opaque; 275 int i; 276 277 switch (dcrn) { 278 case SDRAM0_CFGADDR: 279 s->addr = val; 280 break; 281 case SDRAM0_CFGDATA: 282 switch (s->addr) { 283 case 0x00: /* SDRAM_BESR0 */ 284 s->besr0 &= ~val; 285 break; 286 case 0x08: /* SDRAM_BESR1 */ 287 s->besr1 &= ~val; 288 break; 289 case 0x10: /* SDRAM_BEAR */ 290 s->bear = val; 291 break; 292 case 0x20: /* SDRAM_CFG */ 293 val &= 0xFFE00000; 294 if (!(s->cfg & 0x80000000) && (val & 0x80000000)) { 295 trace_ppc4xx_sdram_enable("enable"); 296 /* validate all RAM mappings */ 297 for (i = 0; i < s->nbanks; i++) { 298 if (s->bank[i].size) { 299 sdram_bank_set_bcr(&s->bank[i], s->bank[i].bcr, 300 s->bank[i].base, s->bank[i].size, 301 1); 302 } 303 } 304 s->status &= ~0x80000000; 305 } else if ((s->cfg & 0x80000000) && !(val & 0x80000000)) { 306 trace_ppc4xx_sdram_enable("disable"); 307 /* invalidate all RAM mappings */ 308 for (i = 0; i < s->nbanks; i++) { 309 if (s->bank[i].size) { 310 sdram_bank_set_bcr(&s->bank[i], s->bank[i].bcr, 311 s->bank[i].base, s->bank[i].size, 312 0); 313 } 314 } 315 s->status |= 0x80000000; 316 } 317 if (!(s->cfg & 0x40000000) && (val & 0x40000000)) { 318 s->status |= 0x40000000; 319 } else if ((s->cfg & 0x40000000) && !(val & 0x40000000)) { 320 s->status &= ~0x40000000; 321 } 322 s->cfg = val; 323 break; 324 case 0x24: /* SDRAM_STATUS */ 325 /* Read-only register */ 326 break; 327 case 0x30: /* SDRAM_RTR */ 328 s->rtr = val & 0x3FF80000; 329 break; 330 case 0x34: /* SDRAM_PMIT */ 331 s->pmit = (val & 0xF8000000) | 0x07C00000; 332 break; 333 case 0x40: /* SDRAM_B0CR */ 334 case 0x44: /* SDRAM_B1CR */ 335 case 0x48: /* SDRAM_B2CR */ 336 case 0x4C: /* SDRAM_B3CR */ 337 i = (s->addr - 0x40) / 4; 338 val &= SDRAM_DDR_BCR_MASK; 339 if (s->bank[i].size) { 340 sdram_bank_set_bcr(&s->bank[i], val, 341 sdram_ddr_base(val), sdram_ddr_size(val), 342 s->cfg & 0x80000000); 343 } 344 break; 345 case 0x80: /* SDRAM_TR */ 346 s->tr = val & 0x018FC01F; 347 break; 348 case 0x94: /* SDRAM_ECCCFG */ 349 s->ecccfg = val & 0x00F00000; 350 break; 351 case 0x98: /* SDRAM_ECCESR */ 352 val &= 0xFFF0F000; 353 if (s->eccesr == 0 && val != 0) { 354 qemu_irq_raise(s->irq); 355 } else if (s->eccesr != 0 && val == 0) { 356 qemu_irq_lower(s->irq); 357 } 358 s->eccesr = val; 359 break; 360 default: /* Error */ 361 break; 362 } 363 break; 364 } 365 } 366 367 static void ppc4xx_sdram_ddr_reset(DeviceState *dev) 368 { 369 Ppc4xxSdramDdrState *s = PPC4xx_SDRAM_DDR(dev); 370 371 s->addr = 0; 372 s->bear = 0; 373 s->besr0 = 0; /* No error */ 374 s->besr1 = 0; /* No error */ 375 s->cfg = 0; 376 s->ecccfg = 0; /* No ECC */ 377 s->eccesr = 0; /* No error */ 378 s->pmit = 0x07C00000; 379 s->rtr = 0x05F00000; 380 s->tr = 0x00854009; 381 /* We pre-initialize RAM banks */ 382 s->status = 0; 383 s->cfg = 0x00800000; 384 } 385 386 static void ppc4xx_sdram_ddr_realize(DeviceState *dev, Error **errp) 387 { 388 Ppc4xxSdramDdrState *s = PPC4xx_SDRAM_DDR(dev); 389 Ppc4xxDcrDeviceState *dcr = PPC4xx_DCR_DEVICE(dev); 390 const ram_addr_t valid_bank_sizes[] = { 391 256 * MiB, 128 * MiB, 64 * MiB, 32 * MiB, 16 * MiB, 8 * MiB, 4 * MiB, 0 392 }; 393 int i; 394 395 if (s->nbanks < 1 || s->nbanks > 4) { 396 error_setg(errp, "Invalid number of RAM banks"); 397 return; 398 } 399 if (!s->dram_mr) { 400 error_setg(errp, "Missing dram memory region"); 401 return; 402 } 403 if (!ppc4xx_sdram_banks(s->dram_mr, s->nbanks, s->bank, 404 valid_bank_sizes, errp)) { 405 return; 406 } 407 for (i = 0; i < s->nbanks; i++) { 408 if (s->bank[i].size) { 409 s->bank[i].bcr = sdram_ddr_bcr(s->bank[i].base, s->bank[i].size); 410 sdram_bank_set_bcr(&s->bank[i], s->bank[i].bcr, 411 s->bank[i].base, s->bank[i].size, 0); 412 } else { 413 sdram_bank_set_bcr(&s->bank[i], 0, 0, 0, 0); 414 } 415 trace_ppc4xx_sdram_init(sdram_ddr_base(s->bank[i].bcr), 416 sdram_ddr_size(s->bank[i].bcr), 417 s->bank[i].bcr); 418 } 419 420 sysbus_init_irq(SYS_BUS_DEVICE(dev), &s->irq); 421 422 ppc4xx_dcr_register(dcr, SDRAM0_CFGADDR, 423 s, &sdram_ddr_dcr_read, &sdram_ddr_dcr_write); 424 ppc4xx_dcr_register(dcr, SDRAM0_CFGDATA, 425 s, &sdram_ddr_dcr_read, &sdram_ddr_dcr_write); 426 } 427 428 static const Property ppc4xx_sdram_ddr_props[] = { 429 DEFINE_PROP_LINK("dram", Ppc4xxSdramDdrState, dram_mr, TYPE_MEMORY_REGION, 430 MemoryRegion *), 431 DEFINE_PROP_UINT32("nbanks", Ppc4xxSdramDdrState, nbanks, 4), 432 }; 433 434 static void ppc4xx_sdram_ddr_class_init(ObjectClass *oc, void *data) 435 { 436 DeviceClass *dc = DEVICE_CLASS(oc); 437 438 dc->realize = ppc4xx_sdram_ddr_realize; 439 device_class_set_legacy_reset(dc, ppc4xx_sdram_ddr_reset); 440 /* Reason: only works as function of a ppc4xx SoC */ 441 dc->user_creatable = false; 442 device_class_set_props(dc, ppc4xx_sdram_ddr_props); 443 } 444 445 void ppc4xx_sdram_ddr_enable(Ppc4xxSdramDdrState *s) 446 { 447 sdram_ddr_dcr_write(s, SDRAM0_CFGADDR, 0x20); 448 sdram_ddr_dcr_write(s, SDRAM0_CFGDATA, 0x80000000); 449 } 450 451 /*****************************************************************************/ 452 /* DDR2 SDRAM controller */ 453 #define SDRAM_DDR2_BCR_MASK 0xffe0ffc1 454 455 enum { 456 SDRAM_R0BAS = 0x40, 457 SDRAM_R1BAS, 458 SDRAM_R2BAS, 459 SDRAM_R3BAS, 460 SDRAM_CONF1HB = 0x45, 461 SDRAM_PLBADDULL = 0x4a, 462 SDRAM_CONF1LL = 0x4b, 463 SDRAM_CONFPATHB = 0x4f, 464 SDRAM_PLBADDUHB = 0x50, 465 }; 466 467 static uint32_t sdram_ddr2_bcr(hwaddr ram_base, hwaddr ram_size) 468 { 469 uint32_t bcr; 470 471 switch (ram_size) { 472 case 8 * MiB: 473 bcr = 0xffc0; 474 break; 475 case 16 * MiB: 476 bcr = 0xff80; 477 break; 478 case 32 * MiB: 479 bcr = 0xff00; 480 break; 481 case 64 * MiB: 482 bcr = 0xfe00; 483 break; 484 case 128 * MiB: 485 bcr = 0xfc00; 486 break; 487 case 256 * MiB: 488 bcr = 0xf800; 489 break; 490 case 512 * MiB: 491 bcr = 0xf000; 492 break; 493 case 1 * GiB: 494 bcr = 0xe000; 495 break; 496 case 2 * GiB: 497 bcr = 0xc000; 498 break; 499 case 4 * GiB: 500 bcr = 0x8000; 501 break; 502 default: 503 error_report("invalid RAM size " HWADDR_FMT_plx, ram_size); 504 return 0; 505 } 506 bcr |= ram_base >> 2 & 0xffe00000; 507 bcr |= 1; 508 509 return bcr; 510 } 511 512 static inline hwaddr sdram_ddr2_base(uint32_t bcr) 513 { 514 return (bcr & 0xffe00000) << 2; 515 } 516 517 static hwaddr sdram_ddr2_size(uint32_t bcr) 518 { 519 int sh; 520 521 sh = 1024 - ((bcr >> 6) & 0x3ff); 522 return 8 * MiB * sh; 523 } 524 525 static uint32_t sdram_ddr2_dcr_read(void *opaque, int dcrn) 526 { 527 Ppc4xxSdramDdr2State *s = opaque; 528 uint32_t ret = 0; 529 530 switch (dcrn) { 531 case SDRAM_R0BAS: 532 case SDRAM_R1BAS: 533 case SDRAM_R2BAS: 534 case SDRAM_R3BAS: 535 if (s->bank[dcrn - SDRAM_R0BAS].size) { 536 ret = sdram_ddr2_bcr(s->bank[dcrn - SDRAM_R0BAS].base, 537 s->bank[dcrn - SDRAM_R0BAS].size); 538 } 539 break; 540 case SDRAM_CONF1HB: 541 case SDRAM_CONF1LL: 542 case SDRAM_CONFPATHB: 543 case SDRAM_PLBADDULL: 544 case SDRAM_PLBADDUHB: 545 break; 546 case SDRAM0_CFGADDR: 547 ret = s->addr; 548 break; 549 case SDRAM0_CFGDATA: 550 switch (s->addr) { 551 case 0x14: /* SDRAM_MCSTAT (405EX) */ 552 case 0x1F: 553 ret = 0x80000000; 554 break; 555 case 0x21: /* SDRAM_MCOPT2 */ 556 ret = s->mcopt2; 557 break; 558 case 0x40: /* SDRAM_MB0CF */ 559 ret = 0x00008001; 560 break; 561 case 0x7A: /* SDRAM_DLCR */ 562 ret = 0x02000000; 563 break; 564 case 0xE1: /* SDR0_DDR0 */ 565 ret = SDR0_DDR0_DDRM_ENCODE(1) | SDR0_DDR0_DDRM_DDR1; 566 break; 567 default: 568 break; 569 } 570 break; 571 default: 572 break; 573 } 574 575 return ret; 576 } 577 578 #define SDRAM_DDR2_MCOPT2_DCEN BIT(27) 579 580 static void sdram_ddr2_dcr_write(void *opaque, int dcrn, uint32_t val) 581 { 582 Ppc4xxSdramDdr2State *s = opaque; 583 int i; 584 585 switch (dcrn) { 586 case SDRAM_R0BAS: 587 case SDRAM_R1BAS: 588 case SDRAM_R2BAS: 589 case SDRAM_R3BAS: 590 case SDRAM_CONF1HB: 591 case SDRAM_CONF1LL: 592 case SDRAM_CONFPATHB: 593 case SDRAM_PLBADDULL: 594 case SDRAM_PLBADDUHB: 595 break; 596 case SDRAM0_CFGADDR: 597 s->addr = val; 598 break; 599 case SDRAM0_CFGDATA: 600 switch (s->addr) { 601 case 0x00: /* B0CR */ 602 break; 603 case 0x21: /* SDRAM_MCOPT2 */ 604 if (!(s->mcopt2 & SDRAM_DDR2_MCOPT2_DCEN) && 605 (val & SDRAM_DDR2_MCOPT2_DCEN)) { 606 trace_ppc4xx_sdram_enable("enable"); 607 /* validate all RAM mappings */ 608 for (i = 0; i < s->nbanks; i++) { 609 if (s->bank[i].size) { 610 sdram_bank_set_bcr(&s->bank[i], s->bank[i].bcr, 611 s->bank[i].base, s->bank[i].size, 612 1); 613 } 614 } 615 s->mcopt2 |= SDRAM_DDR2_MCOPT2_DCEN; 616 } else if ((s->mcopt2 & SDRAM_DDR2_MCOPT2_DCEN) && 617 !(val & SDRAM_DDR2_MCOPT2_DCEN)) { 618 trace_ppc4xx_sdram_enable("disable"); 619 /* invalidate all RAM mappings */ 620 for (i = 0; i < s->nbanks; i++) { 621 if (s->bank[i].size) { 622 sdram_bank_set_bcr(&s->bank[i], s->bank[i].bcr, 623 s->bank[i].base, s->bank[i].size, 624 0); 625 } 626 } 627 s->mcopt2 &= ~SDRAM_DDR2_MCOPT2_DCEN; 628 } 629 break; 630 default: 631 break; 632 } 633 break; 634 default: 635 break; 636 } 637 } 638 639 static void ppc4xx_sdram_ddr2_reset(DeviceState *dev) 640 { 641 Ppc4xxSdramDdr2State *s = PPC4xx_SDRAM_DDR2(dev); 642 643 s->addr = 0; 644 s->mcopt2 = 0; 645 } 646 647 static void ppc4xx_sdram_ddr2_realize(DeviceState *dev, Error **errp) 648 { 649 Ppc4xxSdramDdr2State *s = PPC4xx_SDRAM_DDR2(dev); 650 Ppc4xxDcrDeviceState *dcr = PPC4xx_DCR_DEVICE(dev); 651 /* 652 * SoC also has 4 GiB but that causes problem with 32 bit 653 * builds (4*GiB overflows the 32 bit ram_addr_t). 654 */ 655 const ram_addr_t valid_bank_sizes[] = { 656 2 * GiB, 1 * GiB, 512 * MiB, 256 * MiB, 128 * MiB, 657 64 * MiB, 32 * MiB, 16 * MiB, 8 * MiB, 0 658 }; 659 int i; 660 661 if (s->nbanks < 1 || s->nbanks > 4) { 662 error_setg(errp, "Invalid number of RAM banks"); 663 return; 664 } 665 if (!s->dram_mr) { 666 error_setg(errp, "Missing dram memory region"); 667 return; 668 } 669 if (!ppc4xx_sdram_banks(s->dram_mr, s->nbanks, s->bank, 670 valid_bank_sizes, errp)) { 671 return; 672 } 673 for (i = 0; i < s->nbanks; i++) { 674 if (s->bank[i].size) { 675 s->bank[i].bcr = sdram_ddr2_bcr(s->bank[i].base, s->bank[i].size); 676 s->bank[i].bcr &= SDRAM_DDR2_BCR_MASK; 677 sdram_bank_set_bcr(&s->bank[i], s->bank[i].bcr, 678 s->bank[i].base, s->bank[i].size, 0); 679 } else { 680 sdram_bank_set_bcr(&s->bank[i], 0, 0, 0, 0); 681 } 682 trace_ppc4xx_sdram_init(sdram_ddr2_base(s->bank[i].bcr), 683 sdram_ddr2_size(s->bank[i].bcr), 684 s->bank[i].bcr); 685 } 686 687 ppc4xx_dcr_register(dcr, SDRAM0_CFGADDR, 688 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 689 ppc4xx_dcr_register(dcr, SDRAM0_CFGDATA, 690 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 691 692 ppc4xx_dcr_register(dcr, SDRAM_R0BAS, 693 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 694 ppc4xx_dcr_register(dcr, SDRAM_R1BAS, 695 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 696 ppc4xx_dcr_register(dcr, SDRAM_R2BAS, 697 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 698 ppc4xx_dcr_register(dcr, SDRAM_R3BAS, 699 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 700 ppc4xx_dcr_register(dcr, SDRAM_CONF1HB, 701 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 702 ppc4xx_dcr_register(dcr, SDRAM_PLBADDULL, 703 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 704 ppc4xx_dcr_register(dcr, SDRAM_CONF1LL, 705 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 706 ppc4xx_dcr_register(dcr, SDRAM_CONFPATHB, 707 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 708 ppc4xx_dcr_register(dcr, SDRAM_PLBADDUHB, 709 s, &sdram_ddr2_dcr_read, &sdram_ddr2_dcr_write); 710 } 711 712 static const Property ppc4xx_sdram_ddr2_props[] = { 713 DEFINE_PROP_LINK("dram", Ppc4xxSdramDdr2State, dram_mr, TYPE_MEMORY_REGION, 714 MemoryRegion *), 715 DEFINE_PROP_UINT32("nbanks", Ppc4xxSdramDdr2State, nbanks, 4), 716 }; 717 718 static void ppc4xx_sdram_ddr2_class_init(ObjectClass *oc, void *data) 719 { 720 DeviceClass *dc = DEVICE_CLASS(oc); 721 722 dc->realize = ppc4xx_sdram_ddr2_realize; 723 device_class_set_legacy_reset(dc, ppc4xx_sdram_ddr2_reset); 724 /* Reason: only works as function of a ppc4xx SoC */ 725 dc->user_creatable = false; 726 device_class_set_props(dc, ppc4xx_sdram_ddr2_props); 727 } 728 729 void ppc4xx_sdram_ddr2_enable(Ppc4xxSdramDdr2State *s) 730 { 731 sdram_ddr2_dcr_write(s, SDRAM0_CFGADDR, 0x21); 732 sdram_ddr2_dcr_write(s, SDRAM0_CFGDATA, 0x08000000); 733 } 734 735 static const TypeInfo ppc4xx_sdram_types[] = { 736 { 737 .name = TYPE_PPC4xx_SDRAM_DDR, 738 .parent = TYPE_PPC4xx_DCR_DEVICE, 739 .instance_size = sizeof(Ppc4xxSdramDdrState), 740 .class_init = ppc4xx_sdram_ddr_class_init, 741 }, { 742 .name = TYPE_PPC4xx_SDRAM_DDR2, 743 .parent = TYPE_PPC4xx_DCR_DEVICE, 744 .instance_size = sizeof(Ppc4xxSdramDdr2State), 745 .class_init = ppc4xx_sdram_ddr2_class_init, 746 } 747 }; 748 749 DEFINE_TYPES(ppc4xx_sdram_types) 750