1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (C) 2025-2026, NVIDIA CORPORATION. All rights reserved. 4 */ 5 6 #include <dt-bindings/memory/nvidia,tegra264.h> 7 8 #include <linux/interconnect.h> 9 #include <linux/of_device.h> 10 #include <linux/tegra-icc.h> 11 12 #include <soc/tegra/bpmp.h> 13 #include <soc/tegra/mc.h> 14 15 #include "mc.h" 16 #include "tegra264-bwmgr.h" 17 18 /* 19 * MC Client entries are sorted in the increasing order of the 20 * override and security register offsets. 21 */ 22 static const struct tegra_mc_client tegra264_mc_clients[] = { 23 { 24 .id = TEGRA264_MEMORY_CLIENT_PTCR, 25 .name = "ptcr", 26 }, { 27 .id = TEGRA264_MEMORY_CLIENT_HOST1XR, 28 .name = "host1xr", 29 }, { 30 .id = TEGRA264_MEMORY_CLIENT_MPCORER, 31 .name = "mpcorer", 32 }, { 33 .id = TEGRA264_MEMORY_CLIENT_PSCR, 34 .name = "pscr", 35 }, { 36 .id = TEGRA264_MEMORY_CLIENT_PSCW, 37 .name = "pscw", 38 }, { 39 .id = TEGRA264_MEMORY_CLIENT_ISP0R, 40 .name = "isp0r", 41 }, { 42 .id = TEGRA264_MEMORY_CLIENT_MPCOREW, 43 .name = "mpcorew", 44 }, { 45 .id = TEGRA264_MEMORY_CLIENT_ISP0W, 46 .name = "isp0w", 47 }, { 48 .id = TEGRA264_MEMORY_CLIENT_ISP1W, 49 .name = "isp1w", 50 }, { 51 .id = TEGRA264_MEMORY_CLIENT_ISPFALCONR, 52 .name = "ispfalconr", 53 }, { 54 .id = TEGRA264_MEMORY_CLIENT_ISPFALCONW, 55 .name = "ispfalconw", 56 }, { 57 .id = TEGRA264_MEMORY_CLIENT_MGBE2R, 58 .name = "mgbe2r", 59 }, { 60 .id = TEGRA264_MEMORY_CLIENT_OFAR2MC, 61 .name = "ofar2mc", 62 }, { 63 .id = TEGRA264_MEMORY_CLIENT_OFAW2MC, 64 .name = "ofaw2mc", 65 }, { 66 .id = TEGRA264_MEMORY_CLIENT_MGBE2W, 67 .name = "mgbe2w", 68 }, { 69 .id = TEGRA264_MEMORY_CLIENT_MGBE3R, 70 .name = "mgbe3r", 71 }, { 72 .id = TEGRA264_MEMORY_CLIENT_MGBE3W, 73 .name = "mgbe3w", 74 }, { 75 .id = TEGRA264_MEMORY_CLIENT_SEU1RD, 76 .name = "seu1rd", 77 }, { 78 .id = TEGRA264_MEMORY_CLIENT_SEU1WR, 79 .name = "seu1wr", 80 }, { 81 .id = TEGRA264_MEMORY_CLIENT_VICR, 82 .name = "vicr", 83 .bpmp_id = TEGRA264_BWMGR_VIC, 84 .type = TEGRA_ICC_NISO, 85 }, { 86 .id = TEGRA264_MEMORY_CLIENT_VICW, 87 .name = "vicw", 88 .bpmp_id = TEGRA264_BWMGR_VIC, 89 .type = TEGRA_ICC_NISO, 90 }, { 91 .id = TEGRA264_MEMORY_CLIENT_VIW, 92 .name = "viw", 93 }, { 94 .id = TEGRA264_MEMORY_CLIENT_XSPI0R, 95 .name = "xspi0r", 96 }, { 97 .id = TEGRA264_MEMORY_CLIENT_XSPI0W, 98 .name = "xspi0w", 99 }, { 100 .id = TEGRA264_MEMORY_CLIENT_APER, 101 .name = "aper", 102 .bpmp_id = TEGRA264_BWMGR_APE, 103 .type = TEGRA_ICC_ISO_AUDIO, 104 }, { 105 .id = TEGRA264_MEMORY_CLIENT_APEW, 106 .name = "apew", 107 .bpmp_id = TEGRA264_BWMGR_APE, 108 .type = TEGRA_ICC_ISO_AUDIO, 109 }, { 110 .id = TEGRA264_MEMORY_CLIENT_SER, 111 .name = "ser", 112 }, { 113 .id = TEGRA264_MEMORY_CLIENT_SEW, 114 .name = "sew", 115 }, { 116 .id = TEGRA264_MEMORY_CLIENT_AXIAPR, 117 .name = "axiapr", 118 }, { 119 .id = TEGRA264_MEMORY_CLIENT_AXIAPW, 120 .name = "axiapw", 121 }, { 122 .id = TEGRA264_MEMORY_CLIENT_ETRR, 123 .name = "etrr", 124 }, { 125 .id = TEGRA264_MEMORY_CLIENT_ETRW, 126 .name = "etrw", 127 }, { 128 .id = TEGRA264_MEMORY_CLIENT_TSECR, 129 .name = "tsecr", 130 }, { 131 .id = TEGRA264_MEMORY_CLIENT_TSECW, 132 .name = "tsecw", 133 }, { 134 .id = TEGRA264_MEMORY_CLIENT_BPMPR, 135 .name = "bpmpr", 136 }, { 137 .id = TEGRA264_MEMORY_CLIENT_BPMPW, 138 .name = "bpmpw", 139 }, { 140 .id = TEGRA264_MEMORY_CLIENT_AONR, 141 .name = "aonr", 142 }, { 143 .id = TEGRA264_MEMORY_CLIENT_AONW, 144 .name = "aonw", 145 }, { 146 .id = TEGRA264_MEMORY_CLIENT_GPCDMAR, 147 .name = "gpcdmar", 148 }, { 149 .id = TEGRA264_MEMORY_CLIENT_GPCDMAW, 150 .name = "gpcdmaw", 151 }, { 152 .id = TEGRA264_MEMORY_CLIENT_APEDMAR, 153 .name = "apedmar", 154 .bpmp_id = TEGRA264_BWMGR_APEDMA, 155 .type = TEGRA_ICC_ISO_AUDIO, 156 }, { 157 .id = TEGRA264_MEMORY_CLIENT_APEDMAW, 158 .name = "apedmaw", 159 .bpmp_id = TEGRA264_BWMGR_APEDMA, 160 .type = TEGRA_ICC_ISO_AUDIO, 161 }, { 162 .id = TEGRA264_MEMORY_CLIENT_MIU0R, 163 .name = "miu0r", 164 }, { 165 .id = TEGRA264_MEMORY_CLIENT_MIU0W, 166 .name = "miu0w", 167 }, { 168 .id = TEGRA264_MEMORY_CLIENT_MIU1R, 169 .name = "miu1r", 170 }, { 171 .id = TEGRA264_MEMORY_CLIENT_MIU1W, 172 .name = "miu1w", 173 }, { 174 .id = TEGRA264_MEMORY_CLIENT_MIU2R, 175 .name = "miu2r", 176 }, { 177 .id = TEGRA264_MEMORY_CLIENT_MIU2W, 178 .name = "miu2w", 179 }, { 180 .id = TEGRA264_MEMORY_CLIENT_MIU3R, 181 .name = "miu3r", 182 }, { 183 .id = TEGRA264_MEMORY_CLIENT_MIU3W, 184 .name = "miu3w", 185 }, { 186 .id = TEGRA264_MEMORY_CLIENT_MIU4R, 187 .name = "miu4r", 188 }, { 189 .id = TEGRA264_MEMORY_CLIENT_MIU4W, 190 .name = "miu4w", 191 }, { 192 .id = TEGRA264_MEMORY_CLIENT_VIFALCONR, 193 .name = "vifalconr", 194 .bpmp_id = TEGRA264_BWMGR_VIFAL, 195 .type = TEGRA_ICC_ISO_VIFAL, 196 }, { 197 .id = TEGRA264_MEMORY_CLIENT_VIFALCONW, 198 .name = "vifalconw", 199 .bpmp_id = TEGRA264_BWMGR_VIFAL, 200 .type = TEGRA_ICC_ISO_VIFAL, 201 }, { 202 .id = TEGRA264_MEMORY_CLIENT_RCER, 203 .name = "rcer", 204 .bpmp_id = TEGRA264_BWMGR_RCE, 205 .type = TEGRA_ICC_NISO, 206 }, { 207 .id = TEGRA264_MEMORY_CLIENT_RCEW, 208 .name = "rcew", 209 .bpmp_id = TEGRA264_BWMGR_RCE, 210 .type = TEGRA_ICC_NISO, 211 }, { 212 .id = TEGRA264_MEMORY_CLIENT_NVENC1SRD2MC, 213 .name = "nvenc1srd2mc", 214 }, { 215 .id = TEGRA264_MEMORY_CLIENT_NVENC1SWR2MC, 216 .name = "nvenc1swr2mc", 217 }, { 218 .id = TEGRA264_MEMORY_CLIENT_PCIE0W, 219 .name = "pcie0w", 220 .bpmp_id = TEGRA264_BWMGR_PCIE_0, 221 .type = TEGRA_ICC_NISO, 222 }, { 223 .id = TEGRA264_MEMORY_CLIENT_PCIE1R, 224 .name = "pcie1r", 225 .bpmp_id = TEGRA264_BWMGR_PCIE_1, 226 .type = TEGRA_ICC_NISO, 227 }, { 228 .id = TEGRA264_MEMORY_CLIENT_PCIE1W, 229 .name = "pcie1w", 230 .bpmp_id = TEGRA264_BWMGR_PCIE_1, 231 .type = TEGRA_ICC_NISO, 232 }, { 233 .id = TEGRA264_MEMORY_CLIENT_PCIE2AR, 234 .name = "pcie2ar", 235 .bpmp_id = TEGRA264_BWMGR_PCIE_2, 236 .type = TEGRA_ICC_NISO, 237 }, { 238 .id = TEGRA264_MEMORY_CLIENT_PCIE2AW, 239 .name = "pcie2aw", 240 .bpmp_id = TEGRA264_BWMGR_PCIE_2, 241 .type = TEGRA_ICC_NISO, 242 }, { 243 .id = TEGRA264_MEMORY_CLIENT_PCIE3R, 244 .name = "pcie3r", 245 .bpmp_id = TEGRA264_BWMGR_PCIE_3, 246 .type = TEGRA_ICC_NISO, 247 }, { 248 .id = TEGRA264_MEMORY_CLIENT_PCIE3W, 249 .name = "pcie3w", 250 .bpmp_id = TEGRA264_BWMGR_PCIE_3, 251 .type = TEGRA_ICC_NISO, 252 }, { 253 .id = TEGRA264_MEMORY_CLIENT_PCIE4R, 254 .name = "pcie4r", 255 .bpmp_id = TEGRA264_BWMGR_PCIE_4, 256 .type = TEGRA_ICC_NISO, 257 }, { 258 .id = TEGRA264_MEMORY_CLIENT_PCIE4W, 259 .name = "pcie4w", 260 .bpmp_id = TEGRA264_BWMGR_PCIE_4, 261 .type = TEGRA_ICC_NISO, 262 }, { 263 .id = TEGRA264_MEMORY_CLIENT_PCIE5R, 264 .name = "pcie5r", 265 .bpmp_id = TEGRA264_BWMGR_PCIE_5, 266 .type = TEGRA_ICC_NISO, 267 }, { 268 .id = TEGRA264_MEMORY_CLIENT_PCIE5W, 269 .name = "pcie5w", 270 .bpmp_id = TEGRA264_BWMGR_PCIE_5, 271 .type = TEGRA_ICC_NISO, 272 }, { 273 .id = TEGRA264_MEMORY_CLIENT_GPUR02MC, 274 .name = "gpur02mc", 275 .bpmp_id = TEGRA264_BWMGR_GPU, 276 .type = TEGRA_ICC_NISO, 277 }, { 278 .id = TEGRA264_MEMORY_CLIENT_GPUW02MC, 279 .name = "gpuw02mc", 280 .bpmp_id = TEGRA264_BWMGR_GPU, 281 .type = TEGRA_ICC_NISO, 282 }, { 283 .id = TEGRA264_MEMORY_CLIENT_NVDECSRD2MC, 284 .name = "nvdecsrd2mc", 285 .bpmp_id = TEGRA264_BWMGR_NVDEC, 286 .type = TEGRA_ICC_NISO, 287 }, { 288 .id = TEGRA264_MEMORY_CLIENT_NVDECSWR2MC, 289 .name = "nvdecswr2mc", 290 .bpmp_id = TEGRA264_BWMGR_NVDEC, 291 .type = TEGRA_ICC_NISO, 292 }, { 293 .id = TEGRA264_MEMORY_CLIENT_MIU5R, 294 .name = "miu5r", 295 }, { 296 .id = TEGRA264_MEMORY_CLIENT_MIU5W, 297 .name = "miu5w", 298 }, { 299 .id = TEGRA264_MEMORY_CLIENT_MIU6W, 300 .name = "miu6w", 301 }, { 302 .id = TEGRA264_MEMORY_CLIENT_RISTR, 303 .name = "ristr", 304 }, { 305 .id = TEGRA264_MEMORY_CLIENT_RISTW, 306 .name = "ristw", 307 }, { 308 .id = TEGRA264_MEMORY_CLIENT_OESPR, 309 .name = "oespr", 310 }, { 311 .id = TEGRA264_MEMORY_CLIENT_OESPW, 312 .name = "oespw", 313 }, { 314 .id = TEGRA264_MEMORY_CLIENT_MIU7W, 315 .name = "miu7w", 316 }, { 317 .id = TEGRA264_MEMORY_CLIENT_MIU8R, 318 .name = "miu8r", 319 }, { 320 .id = TEGRA264_MEMORY_CLIENT_MIU8W, 321 .name = "miu8w", 322 }, { 323 .id = TEGRA264_MEMORY_CLIENT_MIU9R, 324 .name = "miu9r", 325 }, { 326 .id = TEGRA264_MEMORY_CLIENT_MIU9W, 327 .name = "miu9w", 328 }, { 329 .id = TEGRA264_MEMORY_CLIENT_PMA0AWR, 330 .name = "pma0awr", 331 }, { 332 .id = TEGRA264_MEMORY_CLIENT_NVJPG1SRD2MC, 333 .name = "nvjpg1srd2mc", 334 }, { 335 .id = TEGRA264_MEMORY_CLIENT_NVJPG1SWR2MC, 336 .name = "nvjpg1swr2mc", 337 }, { 338 .id = TEGRA264_MEMORY_CLIENT_SMMU0CTWR, 339 .name = "smmu0ctwr", 340 }, { 341 .id = TEGRA264_MEMORY_CLIENT_SMMU0CMDQVR, 342 .name = "smmu0cmdqvr", 343 }, { 344 .id = TEGRA264_MEMORY_CLIENT_SMMU0CMDQVW, 345 .name = "smmu0cmdqvw", 346 }, { 347 .id = TEGRA264_MEMORY_CLIENT_SMMU0EVNTQW, 348 .name = "smmu0evntqw", 349 }, { 350 .id = TEGRA264_MEMORY_CLIENT_SMMU1PTWR, 351 .name = "smmu1ptwr", 352 }, { 353 .id = TEGRA264_MEMORY_CLIENT_SMMU1CTWR, 354 .name = "smmu1ctwr", 355 }, { 356 .id = TEGRA264_MEMORY_CLIENT_SMMU1CMDQVR, 357 .name = "smmu1cmdqvr", 358 }, { 359 .id = TEGRA264_MEMORY_CLIENT_SMMU1CMDQVW, 360 .name = "smmu1cmdqvw", 361 }, { 362 .id = TEGRA264_MEMORY_CLIENT_SMMU1EVNTQW, 363 .name = "smmu1evntqw", 364 }, { 365 .id = TEGRA264_MEMORY_CLIENT_SMMU2PTWR, 366 .name = "smmu2ptwr", 367 }, { 368 .id = TEGRA264_MEMORY_CLIENT_SMMU2CTWR, 369 .name = "smmu2ctwr", 370 }, { 371 .id = TEGRA264_MEMORY_CLIENT_SMMU2CMDQVR, 372 .name = "smmu2cmdqvr", 373 }, { 374 .id = TEGRA264_MEMORY_CLIENT_SMMU2CMDQVW, 375 .name = "smmu2cmdqvw", 376 }, { 377 .id = TEGRA264_MEMORY_CLIENT_SMMU2EVNTQW, 378 .name = "smmu2evntqw", 379 }, { 380 .id = TEGRA264_MEMORY_CLIENT_SMMU0CMDQR, 381 .name = "smmu0cmdqr", 382 }, { 383 .id = TEGRA264_MEMORY_CLIENT_SMMU1CMDQR, 384 .name = "smmu1cmdqr", 385 }, { 386 .id = TEGRA264_MEMORY_CLIENT_SMMU2CMDQR, 387 .name = "smmu2cmdqr", 388 }, { 389 .id = TEGRA264_MEMORY_CLIENT_APE1R, 390 .name = "ape1r", 391 }, { 392 .id = TEGRA264_MEMORY_CLIENT_APE1W, 393 .name = "ape1w", 394 }, { 395 .id = TEGRA264_MEMORY_CLIENT_UFSR, 396 .name = "ufsr", 397 }, { 398 .id = TEGRA264_MEMORY_CLIENT_UFSW, 399 .name = "ufsw", 400 }, { 401 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEVR, 402 .name = "xusb_devr", 403 }, { 404 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEVW, 405 .name = "xusb_devw", 406 }, { 407 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV1R, 408 .name = "xusb_dev1r", 409 }, { 410 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV2W, 411 .name = "xusb_dev2w", 412 }, { 413 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV3R, 414 .name = "xusb_dev3r", 415 }, { 416 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV3W, 417 .name = "xusb_dev3w", 418 }, { 419 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV4R, 420 .name = "xusb_dev4r", 421 }, { 422 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV4W, 423 .name = "xusb_dev4w", 424 }, { 425 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV5R, 426 .name = "xusb_dev5r", 427 }, { 428 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV5W, 429 .name = "xusb_dev5w", 430 }, { 431 .id = TEGRA264_MEMORY_CLIENT_DCER, 432 .name = "dcer", 433 }, { 434 .id = TEGRA264_MEMORY_CLIENT_DCEW, 435 .name = "dcew", 436 }, { 437 .id = TEGRA264_MEMORY_CLIENT_HDAR, 438 .name = "hdar", 439 .bpmp_id = TEGRA264_BWMGR_HDA, 440 .type = TEGRA_ICC_ISO_AUDIO, 441 }, { 442 .id = TEGRA264_MEMORY_CLIENT_HDAW, 443 .name = "hdaw", 444 .bpmp_id = TEGRA264_BWMGR_HDA, 445 .type = TEGRA_ICC_ISO_AUDIO, 446 }, { 447 .id = TEGRA264_MEMORY_CLIENT_DISPNISOR, 448 .name = "dispnisor", 449 }, { 450 .id = TEGRA264_MEMORY_CLIENT_DISPNISOW, 451 .name = "dispnisow", 452 }, { 453 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV1W, 454 .name = "xusb_dev1w", 455 }, { 456 .id = TEGRA264_MEMORY_CLIENT_XUSB_DEV2R, 457 .name = "xusb_dev2r", 458 }, { 459 .id = TEGRA264_MEMORY_CLIENT_DISPR, 460 .name = "dispr", 461 .bpmp_id = TEGRA264_BWMGR_DISPLAY, 462 .type = TEGRA_ICC_ISO_DISPLAY, 463 }, { 464 .id = TEGRA264_MEMORY_CLIENT_MSSSEQR, 465 .name = "mssseqr", 466 }, { 467 .id = TEGRA264_MEMORY_CLIENT_MSSSEQW, 468 .name = "mssseqw", 469 }, { 470 .id = TEGRA264_MEMORY_CLIENT_SMMU3PTWR, 471 .name = "smmu3ptwr", 472 }, { 473 .id = TEGRA264_MEMORY_CLIENT_SMMU3CTWR, 474 .name = "smmu3ctwr", 475 }, { 476 .id = TEGRA264_MEMORY_CLIENT_SMMU3CMDQVR, 477 .name = "smmu3cmdqvr", 478 }, { 479 .id = TEGRA264_MEMORY_CLIENT_SMMU3CMDQVW, 480 .name = "smmu3cmdqvw", 481 }, { 482 .id = TEGRA264_MEMORY_CLIENT_SMMU3EVNTQW, 483 .name = "smmu3evntqw", 484 }, { 485 .id = TEGRA264_MEMORY_CLIENT_SMMU3CMDQR, 486 .name = "smmu3cmdqr", 487 }, { 488 .id = TEGRA264_MEMORY_CLIENT_SMMU4PTWR, 489 .name = "smmu4ptwr", 490 }, { 491 .id = TEGRA264_MEMORY_CLIENT_SMMU4CTWR, 492 .name = "smmu4ctwr", 493 }, { 494 .id = TEGRA264_MEMORY_CLIENT_SMMU4CMDQVR, 495 .name = "smmu4cmdqvr", 496 }, { 497 .id = TEGRA264_MEMORY_CLIENT_SMMU4CMDQVW, 498 .name = "smmu4cmdqvw", 499 }, { 500 .id = TEGRA264_MEMORY_CLIENT_SMMU4EVNTQW, 501 .name = "smmu4evntqw", 502 }, { 503 .id = TEGRA264_MEMORY_CLIENT_SMMU4CMDQR, 504 .name = "smmu4cmdqr", 505 }, { 506 .id = TEGRA264_MEMORY_CLIENT_MGBE0R, 507 .name = "mgbe0r", 508 .bpmp_id = TEGRA264_BWMGR_EQOS, 509 .type = TEGRA_ICC_NISO, 510 }, { 511 .id = TEGRA264_MEMORY_CLIENT_MGBE0W, 512 .name = "mgbe0w", 513 .bpmp_id = TEGRA264_BWMGR_EQOS, 514 .type = TEGRA_ICC_NISO, 515 }, { 516 .id = TEGRA264_MEMORY_CLIENT_MGBE1R, 517 .name = "mgbe1r", 518 .bpmp_id = TEGRA264_BWMGR_EQOS, 519 .type = TEGRA_ICC_NISO, 520 }, { 521 .id = TEGRA264_MEMORY_CLIENT_MGBE1W, 522 .name = "mgbe1w", 523 .bpmp_id = TEGRA264_BWMGR_EQOS, 524 .type = TEGRA_ICC_NISO, 525 }, { 526 .id = TEGRA264_MEMORY_CLIENT_VI1W, 527 .name = "vi1w", 528 }, { 529 .id = TEGRA264_MEMORY_CLIENT_VIFALCON1R, 530 .name = "vifalcon1r", 531 }, { 532 .id = TEGRA264_MEMORY_CLIENT_VIFALCON1W, 533 .name = "vifalcon1w", 534 }, { 535 .id = TEGRA264_MEMORY_CLIENT_ISPFALCON1R, 536 .name = "ispfalcon1r", 537 }, { 538 .id = TEGRA264_MEMORY_CLIENT_ISPFALCON1W, 539 .name = "ispfalcon1w", 540 }, { 541 .id = TEGRA264_MEMORY_CLIENT_RCE1R, 542 .name = "rce1r", 543 }, { 544 .id = TEGRA264_MEMORY_CLIENT_RCE1W, 545 .name = "rce1w", 546 }, { 547 .id = TEGRA264_MEMORY_CLIENT_SEU2R, 548 .name = "seu2r", 549 }, { 550 .id = TEGRA264_MEMORY_CLIENT_SEU2W, 551 .name = "seu2w", 552 }, { 553 .id = TEGRA264_MEMORY_CLIENT_SEU3R, 554 .name = "seu3r", 555 }, { 556 .id = TEGRA264_MEMORY_CLIENT_SEU3W, 557 .name = "seu3w", 558 }, { 559 .id = TEGRA264_MEMORY_CLIENT_PVA0R, 560 .name = "pva0r", 561 }, { 562 .id = TEGRA264_MEMORY_CLIENT_PVA0W, 563 .name = "pva0w", 564 }, { 565 .id = TEGRA264_MEMORY_CLIENT_PVA1R, 566 .name = "pva1r", 567 }, { 568 .id = TEGRA264_MEMORY_CLIENT_PVA1W, 569 .name = "pva1w", 570 }, { 571 .id = TEGRA264_MEMORY_CLIENT_PVA2R, 572 .name = "pva2r", 573 }, { 574 .id = TEGRA264_MEMORY_CLIENT_PVA2W, 575 .name = "pva2w", 576 }, { 577 .id = TEGRA264_MEMORY_CLIENT_ISP3W, 578 .name = "isp3w", 579 }, { 580 .id = TEGRA264_MEMORY_CLIENT_ISP2R, 581 .name = "isp2r", 582 }, { 583 .id = TEGRA264_MEMORY_CLIENT_ISP2W, 584 .name = "isp2w", 585 }, { 586 .id = TEGRA264_MEMORY_CLIENT_EQOSR, 587 .name = "eqosr", 588 }, { 589 .id = TEGRA264_MEMORY_CLIENT_EQOSW, 590 .name = "eqosw", 591 }, { 592 .id = TEGRA264_MEMORY_CLIENT_FSI0R, 593 .name = "fsi0r", 594 }, { 595 .id = TEGRA264_MEMORY_CLIENT_FSI0W, 596 .name = "fsi0w", 597 }, { 598 .id = TEGRA264_MEMORY_CLIENT_FSI1R, 599 .name = "fsi1r", 600 }, { 601 .id = TEGRA264_MEMORY_CLIENT_FSI1W, 602 .name = "fsi1w", 603 }, { 604 .id = TEGRA264_MEMORY_CLIENT_SDMMC0R, 605 .name = "sdmmc0r", 606 .bpmp_id = TEGRA264_BWMGR_SDMMC_1, 607 .type = TEGRA_ICC_NISO, 608 }, { 609 .id = TEGRA264_MEMORY_CLIENT_SDMMC0W, 610 .name = "sdmmc0w", 611 .bpmp_id = TEGRA264_BWMGR_SDMMC_1, 612 .type = TEGRA_ICC_NISO, 613 }, { 614 .id = TEGRA264_MEMORY_CLIENT_SBR, 615 .name = "sbr", 616 }, { 617 .id = TEGRA264_MEMORY_CLIENT_SBW, 618 .name = "sbw", 619 }, { 620 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU0R, 621 .name = "hss_miu0r", 622 }, { 623 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU0W, 624 .name = "hss_miu0w", 625 }, { 626 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU1R, 627 .name = "hss_miu1r", 628 }, { 629 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU1W, 630 .name = "hss_miu1w", 631 }, { 632 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU2R, 633 .name = "hss_miu2r", 634 }, { 635 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU2W, 636 .name = "hss_miu2w", 637 }, { 638 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU3R, 639 .name = "hss_miu3r", 640 }, { 641 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU3W, 642 .name = "hss_miu3w", 643 }, { 644 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU4R, 645 .name = "hss_miu4r", 646 }, { 647 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU4W, 648 .name = "hss_miu4w", 649 }, { 650 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU5R, 651 .name = "hss_miu5r", 652 }, { 653 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU5W, 654 .name = "hss_miu5w", 655 }, { 656 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU6R, 657 .name = "hss_miu6r", 658 }, { 659 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU6W, 660 .name = "hss_miu6w", 661 }, { 662 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU7R, 663 .name = "hss_miu7r", 664 }, { 665 .id = TEGRA264_MEMORY_CLIENT_HSS_MIU7W, 666 .name = "hss_miu7w", 667 }, { 668 .id = TEGRA264_MEMORY_CLIENT_GMMUR2MC, 669 .name = "gmmur2mc", 670 }, { 671 .id = TEGRA264_MEMORY_CLIENT_UCFELAR, 672 .name = "ucfelar", 673 }, { 674 .id = TEGRA264_MEMORY_CLIENT_UCFELAW, 675 .name = "ucfelaw", 676 }, { 677 .id = TEGRA264_MEMORY_CLIENT_SLCR, 678 .name = "slcr", 679 }, { 680 .id = TEGRA264_MEMORY_CLIENT_SLCW, 681 .name = "slcw", 682 }, { 683 .id = TEGRA264_MEMORY_CLIENT_REMOTER, 684 .name = "remoter", 685 }, { 686 .id = TEGRA264_MEMORY_CLIENT_REMOTEW, 687 .name = "remotew", 688 }, 689 }; 690 691 static const char *const tegra264_hub_error_names[32] = { 692 [0] = "coalescer error", 693 [1] = "SMMU BYPASS ALLOW error", 694 [2] = "Illegal tbugrp_id error", 695 [3] = "Malformed MSI request error", 696 [4] = "Read response with poison bit error", 697 [5] = "Restricted access violation error", 698 [6] = "Reserved PA error", 699 }; 700 701 static const char *const tegra264_mc_error_names[4] = { 702 [1] = "EMEM decode error", 703 [2] = "TrustZone violation", 704 [3] = "Carveout violation", 705 }; 706 707 static const char *const tegra264_rt_error_names[16] = { 708 [1] = "DECERR_PARTIAL_POPULATED", 709 [2] = "DECERR_SMMU_BYPASS", 710 [3] = "DECERR_INVALID_MMIO", 711 [4] = "DECERR_INVALID_GIC_MSI", 712 [5] = "DECERR_ATOMIC_SYSRAM", 713 [9] = "DECERR_REMOTE_REQ_PRE_BOOT", 714 [10] = "DECERR_ISO_OVER_C2C", 715 [11] = "DECERR_UNSUPPORTED_SBS_OPCODE", 716 [12] = "DECERR_SBS_REQ_OVER_SISO_LL", 717 }; 718 719 /* 720 * MC instance aperture mapping for hubc registers 721 */ 722 static const int mc_hubc_aperture_number[5] = { 723 7, 8, 9, 10, 11 724 }; 725 726 /* 727 * tegra264_mc_icc_set() - Pass MC client info to the BPMP-FW 728 * @src: ICC node for Memory Controller's (MC) Client 729 * @dst: ICC node for Memory Controller (MC) 730 * 731 * Passing the current request info from the MC to the BPMP-FW where 732 * LA and PTSA registers are accessed and the final EMC freq is set 733 * based on client_id, type, latency and bandwidth. 734 * icc_set_bw() makes set_bw calls for both MC and EMC providers in 735 * sequence. Both the calls are protected by 'mutex_lock(&icc_lock)'. 736 * So, the data passed won't be updated by concurrent set calls from 737 * other clients. 738 */ 739 static int tegra264_mc_icc_set(struct icc_node *src, struct icc_node *dst) 740 { 741 struct tegra_mc *mc = icc_provider_to_tegra_mc(dst->provider); 742 struct mrq_bwmgr_int_request bwmgr_req = { 0 }; 743 struct mrq_bwmgr_int_response bwmgr_resp = { 0 }; 744 const struct tegra_mc_client *pclient = src->data; 745 struct tegra_bpmp_message msg; 746 int ret; 747 748 /* 749 * Same Src and Dst node will happen during boot from icc_node_add(). 750 * This can be used to pre-initialize and set bandwidth for all clients 751 * before their drivers are loaded. We are skipping this case as for us, 752 * the pre-initialization already happened in Bootloader(MB2) and BPMP-FW. 753 */ 754 if (src->id == dst->id) 755 return 0; 756 757 if (!mc->bwmgr_mrq_supported) 758 return 0; 759 760 if (!mc->bpmp) { 761 dev_err(mc->dev, "BPMP reference NULL\n"); 762 return -ENOENT; 763 } 764 765 /* Skip forwarding bw requests to BPMP from clients without bpmp_id/type. */ 766 if (pclient->type == TEGRA_ICC_NONE || !pclient->bpmp_id) 767 return 0; 768 769 if (pclient->type == TEGRA_ICC_NISO) 770 bwmgr_req.bwmgr_calc_set_req.niso_bw = src->avg_bw; 771 else 772 bwmgr_req.bwmgr_calc_set_req.iso_bw = src->avg_bw; 773 774 bwmgr_req.bwmgr_calc_set_req.client_id = pclient->bpmp_id; 775 776 bwmgr_req.cmd = CMD_BWMGR_INT_CALC_AND_SET; 777 bwmgr_req.bwmgr_calc_set_req.mc_floor = src->peak_bw; 778 bwmgr_req.bwmgr_calc_set_req.floor_unit = BWMGR_INT_UNIT_KBPS; 779 780 memset(&msg, 0, sizeof(msg)); 781 msg.mrq = MRQ_BWMGR_INT; 782 msg.tx.data = &bwmgr_req; 783 msg.tx.size = sizeof(bwmgr_req); 784 msg.rx.data = &bwmgr_resp; 785 msg.rx.size = sizeof(bwmgr_resp); 786 787 ret = tegra_bpmp_transfer(mc->bpmp, &msg); 788 if (ret < 0) { 789 dev_err(mc->dev, "BPMP transfer failed: %d\n", ret); 790 goto error; 791 } 792 if (msg.rx.ret < 0) { 793 pr_err("failed to set bandwidth for %u: %d\n", 794 bwmgr_req.bwmgr_calc_set_req.client_id, msg.rx.ret); 795 ret = -EINVAL; 796 } 797 798 error: 799 return ret; 800 } 801 802 static int tegra264_mc_icc_get_init_bw(struct icc_node *node, u32 *avg, u32 *peak) 803 { 804 *avg = 0; 805 *peak = 0; 806 807 return 0; 808 } 809 810 static void mcf_log_fault(struct tegra_mc *mc, u32 channel, unsigned long mcf_ch_intstatus) 811 { 812 unsigned int bit; 813 814 for_each_set_bit(bit, &mcf_ch_intstatus, 32) { 815 const char *client = "unknown", *desc = "NA"; 816 u32 status_reg, status1_reg = 0, addr_reg, addr_hi_reg = 0, err_type_mask = 0; 817 u32 value, client_id, i, addr_hi_shift = 0, addr_hi_mask = 0, status1; 818 u32 mc_rw_bit = MC_ERR_STATUS_RW, mc_sec_bit = MC_ERR_STATUS_SECURITY; 819 phys_addr_t addr = 0; 820 u8 type; 821 822 switch (BIT(bit)) { 823 case MC_INT_DECERR_EMEM: 824 case MC_INT_SECURITY_VIOLATION: 825 status_reg = mc->soc->regs->err_status; 826 addr_reg = mc->soc->regs->err_add; 827 addr_hi_reg = mc->soc->regs->err_add_hi; 828 err_type_mask = mc->soc->mc_err_status_type_mask; 829 break; 830 831 case MC_INT_DECERR_VPR: 832 status_reg = mc->soc->regs->err_vpr_status; 833 addr_reg = mc->soc->regs->err_vpr_add; 834 addr_hi_shift = MC_ERR_STATUS_ADR_HI_SHIFT; 835 addr_hi_mask = mc->soc->mc_addr_hi_mask; 836 break; 837 838 case MC_INT_SECERR_SEC: 839 status_reg = mc->soc->regs->err_sec_status; 840 addr_reg = mc->soc->regs->err_sec_add; 841 addr_hi_shift = MC_ERR_STATUS_ADR_HI_SHIFT; 842 addr_hi_mask = mc->soc->mc_addr_hi_mask; 843 break; 844 845 case MC_INT_DECERR_MTS: 846 status_reg = mc->soc->regs->err_mts_status; 847 addr_reg = mc->soc->regs->err_mts_add; 848 addr_hi_shift = MC_ERR_STATUS_ADR_HI_SHIFT; 849 addr_hi_mask = mc->soc->mc_addr_hi_mask; 850 break; 851 852 case MC_INT_DECERR_GENERALIZED_CARVEOUT: 853 status_reg = mc->soc->regs->err_gen_co_status; 854 status1_reg = MC_ERR_GENERALIZED_CARVEOUT_STATUS_1_0; 855 addr_reg = mc->soc->regs->err_gen_co_add; 856 addr_hi_shift = MC_ERR_STATUS_GSC_ADR_HI_SHIFT; 857 addr_hi_mask = MC_ERR_STATUS_GSC_ADR_HI_MASK; 858 break; 859 860 case MC_INT_DECERR_ROUTE_SANITY: 861 case MC_INT_DECERR_ROUTE_SANITY_GIC_MSI: 862 status_reg = mc->soc->regs->err_route_status; 863 addr_reg = mc->soc->regs->err_route_add; 864 addr_hi_shift = MC_ERR_STATUS_RT_ADR_HI_SHIFT; 865 addr_hi_mask = mc->soc->mc_addr_hi_mask; 866 mc_sec_bit = MC_ERR_ROUTE_SANITY_SEC; 867 mc_rw_bit = MC_ERR_ROUTE_SANITY_RW; 868 err_type_mask = MC_ERR_STATUS_RT_TYPE_MASK; 869 break; 870 871 default: 872 dev_err_ratelimited(mc->dev, "Incorrect MC interrupt mask\n"); 873 return; 874 } 875 876 value = mc_ch_readl(mc, channel, status_reg); 877 if (addr_hi_reg) { 878 addr = mc_ch_readl(mc, channel, addr_hi_reg); 879 } else { 880 if (!status1_reg) { 881 addr = ((value >> addr_hi_shift) & addr_hi_mask); 882 } else { 883 status1 = mc_ch_readl(mc, channel, status1_reg); 884 addr = ((status1 >> addr_hi_shift) & addr_hi_mask); 885 } 886 } 887 888 addr <<= 32; 889 addr |= mc_ch_readl(mc, channel, addr_reg); 890 891 client_id = value & mc->soc->client_id_mask; 892 for (i = 0; i < mc->soc->num_clients; i++) { 893 if (mc->soc->clients[i].id == client_id) { 894 client = mc->soc->clients[i].name; 895 break; 896 } 897 } 898 899 if (err_type_mask == MC_ERR_STATUS_RT_TYPE_MASK) { 900 type = (value & err_type_mask) >> 901 MC_ERR_STATUS_RT_TYPE_SHIFT; 902 desc = tegra264_rt_error_names[type]; 903 } else if (err_type_mask) { 904 type = (value & err_type_mask) >> 905 MC_ERR_STATUS_TYPE_SHIFT; 906 desc = tegra264_mc_error_names[type]; 907 } 908 909 dev_err_ratelimited(mc->dev, "%s: %s %s @%pa: %s (%s)\n", 910 client, value & mc_sec_bit ? "secure" : "non-secure", 911 value & mc_rw_bit ? "write" : "read", &addr, 912 tegra_mc_status_names[bit] ?: "unknown", desc); 913 if (status1_reg) 914 dev_err_ratelimited(mc->dev, "gsc_apr_id=%u gsc_co_apr_id=%u\n", 915 ((status1 >> ERR_GENERALIZED_APERTURE_ID_SHIFT) 916 & ERR_GENERALIZED_APERTURE_ID_MASK), 917 ((status1 >> ERR_GENERALIZED_CARVEOUT_APERTURE_ID_SHIFT) 918 & ERR_GENERALIZED_CARVEOUT_APERTURE_ID_MASK)); 919 } 920 921 /* clear interrupts */ 922 mc_ch_writel(mc, channel, mcf_ch_intstatus, MCF_INTSTATUS_0); 923 } 924 925 static irqreturn_t handle_mcf_irq(int irq, void *data) 926 { 927 struct tegra_mc *mc = data; 928 unsigned long common_intstat, intstatus; 929 u32 slice; 930 931 /* Read MCF_COMMON_INTSTATUS0_0_0 from MCB block */ 932 common_intstat = mc_ch_readl(mc, MC_BROADCAST_CHANNEL, MCF_COMMON_INTSTATUS0_0_0); 933 if (common_intstat == 0) { 934 dev_warn(mc->dev, "No interrupt in MCF\n"); 935 return IRQ_NONE; 936 } 937 938 for_each_set_bit(slice, &common_intstat, 32) { 939 /* Find out the slice number on which interrupt occurred */ 940 if (slice > 4) { 941 dev_err(mc->dev, "Slice index out of bounds: %u\n", slice); 942 return IRQ_NONE; 943 } 944 945 intstatus = mc_ch_readl(mc, slice, MCF_INTSTATUS_0); 946 if (intstatus != 0) 947 mcf_log_fault(mc, slice, intstatus); 948 } 949 950 return IRQ_HANDLED; 951 } 952 953 static void hub_log_fault(struct tegra_mc *mc, u32 hub, unsigned long hub_intstat) 954 { 955 unsigned int bit; 956 957 for_each_set_bit(bit, &hub_intstat, 32) { 958 const char *client = "unknown"; 959 u32 client_id, status_reg, value, i; 960 phys_addr_t addr = 0; 961 962 switch (BIT(bit)) { 963 case MSS_HUB_COALESCER_ERR_INTMASK: 964 status_reg = MSS_HUB_COALESCE_ERR_STATUS_0; 965 addr = mc_ch_readl(mc, hub, MSS_HUB_COALESCE_ERR_ADR_HI_0); 966 addr <<= 32; 967 addr |= mc_ch_readl(mc, hub, MSS_HUB_COALESCE_ERR_ADR_0); 968 break; 969 970 case MSS_HUB_SMMU_BYPASS_ALLOW_ERR_INTMASK: 971 status_reg = MSS_HUB_SMMU_BYPASS_ALLOW_ERR_STATUS_0; 972 break; 973 974 case MSS_HUB_ILLEGAL_TBUGRP_ID_INTMASK: 975 status_reg = MSS_HUB_ILLEGAL_TBUGRP_ID_ERR_STATUS_0; 976 break; 977 978 case MSS_HUB_MSI_ERR_INTMASK: 979 status_reg = MSS_HUB_MSI_ERR_STATUS_0; 980 break; 981 982 case MSS_HUB_POISON_RSP_INTMASK: 983 status_reg = MSS_HUB_POISON_RSP_STATUS_0; 984 break; 985 986 case MSS_HUB_RESTRICTED_ACCESS_ERR_INTMASK: 987 status_reg = MSS_HUB_RESTRICTED_ACCESS_ERR_STATUS_0; 988 break; 989 990 case MSS_HUB_RESERVED_PA_ERR_INTMASK: 991 status_reg = MSS_HUB_RESERVED_PA_ERR_STATUS_0; 992 break; 993 994 default: 995 dev_err_ratelimited(mc->dev, "Incorrect HUB interrupt mask\n"); 996 return; 997 } 998 999 value = mc_ch_readl(mc, hub, status_reg); 1000 1001 client_id = value & mc->soc->client_id_mask; 1002 for (i = 0; i < mc->soc->num_clients; i++) { 1003 if (mc->soc->clients[i].id == client_id) { 1004 client = mc->soc->clients[i].name; 1005 break; 1006 } 1007 } 1008 1009 dev_err_ratelimited(mc->dev, "%s: @%pa: %s status: 0x%x\n", 1010 client, &addr, tegra264_hub_error_names[bit] ?: "unknown", 1011 value); 1012 } 1013 1014 /* clear interrupts */ 1015 mc_ch_writel(mc, hub, hub_intstat, MSS_HUB_INTRSTATUS_0); 1016 } 1017 1018 static irqreturn_t handle_hub_irq(int irq, void *data, int mc_hubc_aperture_number) 1019 { 1020 struct tegra_mc *mc = data; 1021 u32 global_intstat; 1022 unsigned long hub_interrupt, intstat, hub; 1023 1024 /* Read MSS_HUB_GLOBAL_INTSTATUS_0 from mc_hubc_aperture_number block */ 1025 global_intstat = mc_ch_readl(mc, mc_hubc_aperture_number, MSS_HUB_GLOBAL_INTSTATUS_0); 1026 if (global_intstat == 0) { 1027 dev_warn(mc->dev, "No interrupt in HUB/HUBC\n"); 1028 return IRQ_NONE; 1029 } 1030 1031 /* Handle interrupt from hubc */ 1032 if (global_intstat & MSS_HUBC_INTR) { 1033 /* Read MSS_HUB_HUBC_INTSTATUS_0 from block mc_hubc_aperture_number */ 1034 intstat = mc_ch_readl(mc, mc_hubc_aperture_number, MSS_HUB_HUBC_INTSTATUS_0); 1035 if (intstat != 0) { 1036 dev_err_ratelimited(mc->dev, "Scrubber operation status: 0x%lx\n", 1037 intstat); 1038 /* Clear hubc interrupt */ 1039 mc_ch_writel(mc, mc_hubc_aperture_number, intstat, 1040 MSS_HUB_HUBC_INTSTATUS_0); 1041 } 1042 } 1043 1044 hub_interrupt = (global_intstat & MSS_HUB_GLOBAL_MASK) >> MSS_HUB_GLOBAL_SHIFT; 1045 /* Handle interrupt from hub */ 1046 for_each_set_bit(hub, &hub_interrupt, 32) { 1047 /* Read MSS_HUB_INTRSTATUS_0 from block MCi */ 1048 intstat = mc_ch_readl(mc, hub, MSS_HUB_INTRSTATUS_0); 1049 if (intstat != 0) 1050 hub_log_fault(mc, hub, intstat); 1051 } 1052 1053 /* Clear global interrupt status register */ 1054 mc_ch_writel(mc, mc_hubc_aperture_number, global_intstat, MSS_HUB_GLOBAL_INTSTATUS_0); 1055 return IRQ_HANDLED; 1056 } 1057 1058 static irqreturn_t handle_disp_hub_irq(int irq, void *data) 1059 { 1060 return handle_hub_irq(irq, data, mc_hubc_aperture_number[0]); 1061 } 1062 1063 static irqreturn_t handle_system_hub_irq(int irq, void *data) 1064 { 1065 return handle_hub_irq(irq, data, mc_hubc_aperture_number[1]); 1066 } 1067 1068 static irqreturn_t handle_vision_hub_irq(int irq, void *data) 1069 { 1070 return handle_hub_irq(irq, data, mc_hubc_aperture_number[2]); 1071 } 1072 1073 static irqreturn_t handle_uphy_hub_irq(int irq, void *data) 1074 { 1075 return handle_hub_irq(irq, data, mc_hubc_aperture_number[3]); 1076 } 1077 1078 static irqreturn_t handle_top_hub_irq(int irq, void *data) 1079 { 1080 return handle_hub_irq(irq, data, mc_hubc_aperture_number[4]); 1081 } 1082 1083 static irqreturn_t handle_generic_irq(struct tegra_mc *mc, unsigned long intstat_reg) 1084 { 1085 u32 intstat, i; 1086 1087 /* Iterate over all MC blocks to read INTSTATUS */ 1088 for (i = 0; i < mc->num_channels; i++) { 1089 intstat = mc_ch_readl(mc, i, intstat_reg); 1090 if (intstat) { 1091 dev_err_ratelimited(mc->dev, "channel: %i status: 0x%x\n", i, intstat); 1092 /* Clear interrupt */ 1093 mc_ch_writel(mc, i, intstat, intstat_reg); 1094 } 1095 } 1096 1097 return IRQ_HANDLED; 1098 } 1099 1100 static irqreturn_t handle_sbs_irq(int irq, void *data) 1101 { 1102 return handle_generic_irq((struct tegra_mc *)data, MSS_SBS_INTSTATUS_0); 1103 } 1104 1105 static irqreturn_t handle_channel_irq(int irq, void *data) 1106 { 1107 return handle_generic_irq((struct tegra_mc *)data, MC_CH_INTSTATUS_0); 1108 } 1109 1110 static const irq_handler_t tegra264_mc_irq_handlers[8] = { 1111 handle_mcf_irq, handle_disp_hub_irq, handle_vision_hub_irq, 1112 handle_system_hub_irq, handle_uphy_hub_irq, handle_top_hub_irq, 1113 handle_sbs_irq, handle_channel_irq 1114 }; 1115 1116 static const struct tegra_mc_icc_ops tegra264_mc_icc_ops = { 1117 .xlate = tegra_mc_icc_xlate, 1118 .aggregate = icc_std_aggregate, 1119 .get_bw = tegra264_mc_icc_get_init_bw, 1120 .set = tegra264_mc_icc_set, 1121 }; 1122 1123 static const struct tegra_mc_regs tegra264_mc_regs = { 1124 .cfg_channel_enable = 0x8870, 1125 .err_status = 0xbc00, 1126 .err_add = 0xbc04, 1127 .err_add_hi = 0xbc08, 1128 .err_vpr_status = 0xbc20, 1129 .err_vpr_add = 0xbc24, 1130 .err_sec_status = 0xbc3c, 1131 .err_sec_add = 0xbc40, 1132 .err_mts_status = 0xbc5c, 1133 .err_mts_add = 0xbc60, 1134 .err_gen_co_status = 0xbc78, 1135 .err_gen_co_add = 0xbc7c, 1136 .err_route_status = 0xbc64, 1137 .err_route_add = 0xbc68, 1138 }; 1139 1140 static const struct tegra_mc_intmask tegra264_mc_intmasks[] = { 1141 { 1142 .reg = MCF_INTMASK_0, 1143 .mask = MC_INT_DECERR_ROUTE_SANITY_GIC_MSI | MC_INT_DECERR_ROUTE_SANITY | 1144 MC_INT_DECERR_GENERALIZED_CARVEOUT | MC_INT_DECERR_MTS | 1145 MC_INT_SECERR_SEC | MC_INT_DECERR_VPR | MC_INT_SECURITY_VIOLATION | 1146 MC_INT_DECERR_EMEM, 1147 }, 1148 { 1149 .reg = MCF_INTPRIORITY_0, 1150 .mask = MC_INT_DECERR_ROUTE_SANITY_GIC_MSI | MC_INT_DECERR_ROUTE_SANITY | 1151 MC_INT_DECERR_GENERALIZED_CARVEOUT | MC_INT_DECERR_MTS | 1152 MC_INT_SECERR_SEC | MC_INT_DECERR_VPR | MC_INT_SECURITY_VIOLATION | 1153 MC_INT_DECERR_EMEM, 1154 }, 1155 { 1156 .reg = MSS_HUB_INTRMASK_0, 1157 .mask = MSS_HUB_COALESCER_ERR_INTMASK | MSS_HUB_SMMU_BYPASS_ALLOW_ERR_INTMASK | 1158 MSS_HUB_ILLEGAL_TBUGRP_ID_INTMASK | MSS_HUB_MSI_ERR_INTMASK | 1159 MSS_HUB_POISON_RSP_INTMASK | MSS_HUB_RESTRICTED_ACCESS_ERR_INTMASK | 1160 MSS_HUB_RESERVED_PA_ERR_INTMASK, 1161 }, 1162 { 1163 .reg = MSS_HUB_INTRPRIORITY_0, 1164 .mask = MSS_HUB_COALESCER_ERR_INTMASK | MSS_HUB_SMMU_BYPASS_ALLOW_ERR_INTMASK | 1165 MSS_HUB_ILLEGAL_TBUGRP_ID_INTMASK | MSS_HUB_MSI_ERR_INTMASK | 1166 MSS_HUB_POISON_RSP_INTMASK | MSS_HUB_RESTRICTED_ACCESS_ERR_INTMASK | 1167 MSS_HUB_RESERVED_PA_ERR_INTMASK, 1168 }, 1169 { 1170 .reg = MSS_HUB_HUBC_INTMASK_0, 1171 .mask = MSS_HUB_HUBC_SCRUB_DONE_INTMASK, 1172 }, 1173 { 1174 .reg = MSS_HUB_HUBC_INTPRIORITY_0, 1175 .mask = MSS_HUB_HUBC_SCRUB_DONE_INTMASK, 1176 }, 1177 { 1178 .reg = MSS_SBS_INTMASK_0, 1179 .mask = MSS_SBS_FILL_FIFO_ISO_OVERFLOW_INTMASK | 1180 MSS_SBS_FILL_FIFO_SISO_OVERFLOW_INTMASK | 1181 MSS_SBS_FILL_FIFO_NISO_OVERFLOW_INTMASK, 1182 }, 1183 { 1184 .reg = MC_CH_INTMASK_0, 1185 .mask = WCAM_ERR_INTMASK, 1186 } 1187 }; 1188 1189 const struct tegra_mc_soc tegra264_mc_soc = { 1190 .num_clients = ARRAY_SIZE(tegra264_mc_clients), 1191 .clients = tegra264_mc_clients, 1192 .num_address_bits = 40, 1193 .num_channels = 16, 1194 .client_id_mask = 0x1ff, 1195 .intmasks = tegra264_mc_intmasks, 1196 .num_intmasks = ARRAY_SIZE(tegra264_mc_intmasks), 1197 .has_addr_hi_reg = true, 1198 .ops = &tegra186_mc_ops, 1199 .icc_ops = &tegra264_mc_icc_ops, 1200 .ch_intmask = 0x0000ff00, 1201 .global_intstatus_channel_shift = 8, 1202 /* 1203 * Additionally, there are lite carveouts but those are not currently 1204 * supported. 1205 */ 1206 .num_carveouts = 32, 1207 .mc_addr_hi_mask = 0xff, 1208 .mc_err_status_type_mask = (0x3 << 28), 1209 .regs = &tegra264_mc_regs, 1210 .handle_irq = tegra264_mc_irq_handlers, 1211 .num_interrupts = ARRAY_SIZE(tegra264_mc_irq_handlers), 1212 }; 1213