arch/arm64/boot/dts/rockchip/rk3399-firefly.dts - master | Gitverse (2024)

1

// SPDX-License-Identifier: (GPL-2.0+ OR MIT)

2

/*

3

 * Copyright (c) 2017 Fuzhou Rockchip Electronics Co., Ltd.

4

 */

5

6

/dts-v1/;

7

#include <dt-bindings/input/linux-event-codes.h>

8

#include <dt-bindings/interrupt-controller/irq.h>

9

#include <dt-bindings/pwm/pwm.h>

10

#include <dt-bindings/usb/pd.h>

11

#include "rk3399.dtsi"

12

#include "rk3399-opp.dtsi"

13

14

/ {

15

model = "Firefly-RK3399 Board";

16

compatible = "firefly,firefly-rk3399", "rockchip,rk3399";

17

18

aliases {

19

mmc0 = &sdio0;

20

mmc1 = &sdmmc;

21

mmc2 = &sdhci;

22

};

23

24

chosen {

25

stdout-path = "serial2:1500000n8";

26

};

27

28

backlight: backlight {

29

compatible = "pwm-backlight";

30

enable-gpios = <&gpio1 RK_PB5 GPIO_ACTIVE_HIGH>;

31

pwms = <&pwm0 0 25000 0>;

32

brightness-levels = <

33

 0 1 2 3 4 5 6 7

34

 8 9 10 11 12 13 14 15

35

 16 17 18 19 20 21 22 23

36

 24 25 26 27 28 29 30 31

37

 32 33 34 35 36 37 38 39

38

 40 41 42 43 44 45 46 47

39

 48 49 50 51 52 53 54 55

40

 56 57 58 59 60 61 62 63

41

 64 65 66 67 68 69 70 71

42

 72 73 74 75 76 77 78 79

43

 80 81 82 83 84 85 86 87

44

 88 89 90 91 92 93 94 95

45

 96 97 98 99 100 101 102 103

46

104 105 106 107 108 109 110 111

47

112 113 114 115 116 117 118 119

48

120 121 122 123 124 125 126 127

49

128 129 130 131 132 133 134 135

50

136 137 138 139 140 141 142 143

51

144 145 146 147 148 149 150 151

52

152 153 154 155 156 157 158 159

53

160 161 162 163 164 165 166 167

54

168 169 170 171 172 173 174 175

55

176 177 178 179 180 181 182 183

56

184 185 186 187 188 189 190 191

57

192 193 194 195 196 197 198 199

58

200 201 202 203 204 205 206 207

59

208 209 210 211 212 213 214 215

60

216 217 218 219 220 221 222 223

61

224 225 226 227 228 229 230 231

62

232 233 234 235 236 237 238 239

63

240 241 242 243 244 245 246 247

64

248 249 250 251 252 253 254 255>;

65

default-brightness-level = <200>;

66

};

67

68

clkin_gmac: external-gmac-clock {

69

compatible = "fixed-clock";

70

clock-frequency = <125000000>;

71

clock-output-names = "clkin_gmac";

72

#clock-cells = <0>;

73

};

74

75

dc_12v: dc-12v {

76

compatible = "regulator-fixed";

77

regulator-name = "dc_12v";

78

regulator-always-on;

79

regulator-boot-on;

80

regulator-min-microvolt = <12000000>;

81

regulator-max-microvolt = <12000000>;

82

};

83

84

gpio-keys {

85

compatible = "gpio-keys";

86

autorepeat;

87

pinctrl-names = "default";

88

pinctrl-0 = <&pwrbtn>;

89

90

key-power {

91

debounce-interval = <100>;

92

gpios = <&gpio0 RK_PA5 GPIO_ACTIVE_LOW>;

93

label = "GPIO Key Power";

94

linux,code = <KEY_POWER>;

95

wakeup-source;

96

};

97

};

98

99

ir-receiver {

100

compatible = "gpio-ir-receiver";

101

gpios = <&gpio0 RK_PA6 GPIO_ACTIVE_LOW>;

102

pinctrl-0 = <&ir_int>;

103

pinctrl-names = "default";

104

};

105

106

leds {

107

compatible = "gpio-leds";

108

pinctrl-names = "default";

109

pinctrl-0 = <&work_led_pin>, <&diy_led_pin>;

110

111

work_led: led-0 {

112

label = "work";

113

default-state = "on";

114

gpios = <&gpio2 RK_PD3 GPIO_ACTIVE_HIGH>;

115

};

116

117

diy_led: led-1 {

118

label = "diy";

119

default-state = "off";

120

gpios = <&gpio0 RK_PB5 GPIO_ACTIVE_HIGH>;

121

};

122

};

123

124

rt5640-sound {

125

compatible = "simple-audio-card";

126

simple-audio-card,name = "rockchip,rt5640-codec";

127

simple-audio-card,format = "i2s";

128

simple-audio-card,mclk-fs = <256>;

129

simple-audio-card,widgets =

130

"Microphone", "Mic Jack",

131

"Headphone", "Headphone Jack";

132

simple-audio-card,routing =

133

"Mic Jack", "MICBIAS1",

134

"IN1P", "Mic Jack",

135

"Headphone Jack", "HPOL",

136

"Headphone Jack", "HPOR";

137

138

simple-audio-card,cpu {

139

sound-dai = <&i2s1>;

140

};

141

142

simple-audio-card,codec {

143

sound-dai = <&rt5640>;

144

};

145

};

146

147

sdio_pwrseq: sdio-pwrseq {

148

compatible = "mmc-pwrseq-simple";

149

clocks = <&rk808 1>;

150

clock-names = "ext_clock";

151

pinctrl-names = "default";

152

pinctrl-0 = <&wifi_enable_h>;

153

154

/*

155

 * On the module itself this is one of these (depending

156

 * on the actual card populated):

157

 * - SDIO_RESET_L_WL_REG_ON

158

 * - PDN (power down when low)

159

 */

160

reset-gpios = <&gpio0 RK_PB2 GPIO_ACTIVE_LOW>;

161

};

162

163

sound-dit {

164

compatible = "audio-graph-card";

165

label = "SPDIF";

166

dais = <&spdif_p0>;

167

};

168

169

spdif-dit {

170

compatible = "linux,spdif-dit";

171

#sound-dai-cells = <0>;

172

173

port {

174

dit_p0_0: endpoint {

175

remote-endpoint = <&spdif_p0_0>;

176

};

177

};

178

};

179

180

/* switched by pmic_sleep */

181

vcc1v8_s3: vcca1v8_s3: vcc1v8-s3 {

182

compatible = "regulator-fixed";

183

regulator-name = "vcc1v8_s3";

184

regulator-always-on;

185

regulator-boot-on;

186

regulator-min-microvolt = <1800000>;

187

regulator-max-microvolt = <1800000>;

188

vin-supply = <&vcc_1v8>;

189

};

190

191

vcc3v3_pcie: vcc3v3-pcie-regulator {

192

compatible = "regulator-fixed";

193

enable-active-high;

194

gpio = <&gpio1 RK_PC1 GPIO_ACTIVE_HIGH>;

195

pinctrl-names = "default";

196

pinctrl-0 = <&pcie_pwr_en>;

197

regulator-name = "vcc3v3_pcie";

198

regulator-always-on;

199

regulator-boot-on;

200

vin-supply = <&dc_12v>;

201

};

202

203

vcc3v3_sys: vcc3v3-sys {

204

compatible = "regulator-fixed";

205

regulator-name = "vcc3v3_sys";

206

regulator-always-on;

207

regulator-boot-on;

208

regulator-min-microvolt = <3300000>;

209

regulator-max-microvolt = <3300000>;

210

vin-supply = <&vcc_sys>;

211

};

212

213

/* Actually 3 regulators (host0, 1, 2) controlled by the same gpio */

214

vcc5v0_host: vcc5v0-host-regulator {

215

compatible = "regulator-fixed";

216

enable-active-high;

217

gpio = <&gpio1 RK_PA0 GPIO_ACTIVE_HIGH>;

218

pinctrl-names = "default";

219

pinctrl-0 = <&vcc5v0_host_en>;

220

regulator-name = "vcc5v0_host";

221

regulator-always-on;

222

vin-supply = <&vcc_sys>;

223

};

224

225

vcc5v0_typec: vcc5v0-typec-regulator {

226

compatible = "regulator-fixed";

227

enable-active-high;

228

gpio = <&gpio1 RK_PA3 GPIO_ACTIVE_HIGH>;

229

pinctrl-names = "default";

230

pinctrl-0 = <&vcc5v0_typec_en>;

231

regulator-name = "vcc5v0_typec";

232

regulator-always-on;

233

vin-supply = <&vcc_sys>;

234

};

235

237

compatible = "regulator-fixed";

238

regulator-name = "vcc_sys";

239

regulator-always-on;

240

regulator-boot-on;

241

regulator-min-microvolt = <5000000>;

242

regulator-max-microvolt = <5000000>;

243

vin-supply = <&dc_12v>;

244

};

245

246

vdd_log: vdd-log {

247

compatible = "pwm-regulator";

248

pwms = <&pwm2 0 25000 1>;

249

pwm-supply = <&vcc_sys>;

250

regulator-name = "vdd_log";

251

regulator-always-on;

252

regulator-boot-on;

253

regulator-min-microvolt = <430000>;

254

regulator-max-microvolt = <1400000>;

255

};

256

};

257

258

&cpu_l0 {

259

cpu-supply = <&vdd_cpu_l>;

260

};

261

262

&cpu_l1 {

263

cpu-supply = <&vdd_cpu_l>;

264

};

265

266

&cpu_l2 {

267

cpu-supply = <&vdd_cpu_l>;

268

};

269

270

&cpu_l3 {

271

cpu-supply = <&vdd_cpu_l>;

272

};

273

274

&cpu_b0 {

275

cpu-supply = <&vdd_cpu_b>;

276

};

277

278

&cpu_b1 {

279

cpu-supply = <&vdd_cpu_b>;

280

};

281

282

&emmc_phy {

283

status = "okay";

284

};

285

286

&gmac {

287

assigned-clocks = <&cru SCLK_RMII_SRC>;

288

assigned-clock-parents = <&clkin_gmac>;

289

clock_in_out = "input";

290

phy-supply = <&vcc_lan>;

291

phy-mode = "rgmii";

292

pinctrl-names = "default";

293

pinctrl-0 = <&rgmii_pins>;

294

snps,reset-gpio = <&gpio3 RK_PB7 GPIO_ACTIVE_LOW>;

295

snps,reset-active-low;

296

snps,reset-delays-us = <0 10000 50000>;

297

tx_delay = <0x28>;

298

rx_delay = <0x11>;

299

status = "okay";

300

};

301

302

&gpu {

303

mali-supply = <&vdd_gpu>;

304

status = "okay";

305

};

306

307

&hdmi {

308

ddc-i2c-bus = <&i2c3>;

309

pinctrl-names = "default";

310

pinctrl-0 = <&hdmi_cec>;

311

status = "okay";

312

};

313

314

&i2c0 {

315

clock-frequency = <400000>;

316

i2c-scl-rising-time-ns = <168>;

317

i2c-scl-falling-time-ns = <4>;

318

status = "okay";

319

320

rk808: pmic@1b {

321

compatible = "rockchip,rk808";

322

reg = <0x1b>;

323

interrupt-parent = <&gpio1>;

324

interrupts = <21 IRQ_TYPE_LEVEL_LOW>;

325

#clock-cells = <1>;

326

clock-output-names = "xin32k", "rk808-clkout2";

327

pinctrl-names = "default";

328

pinctrl-0 = <&pmic_int_l>;

329

rockchip,system-power-controller;

330

wakeup-source;

331

332

vcc1-supply = <&vcc_sys>;

333

vcc2-supply = <&vcc_sys>;

334

vcc3-supply = <&vcc_sys>;

335

vcc4-supply = <&vcc_sys>;

336

vcc6-supply = <&vcc_sys>;

337

vcc7-supply = <&vcc_sys>;

338

vcc8-supply = <&vcc3v3_sys>;

339

vcc9-supply = <&vcc_sys>;

340

vcc10-supply = <&vcc_sys>;

341

vcc11-supply = <&vcc_sys>;

342

vcc12-supply = <&vcc3v3_sys>;

343

vddio-supply = <&vcc1v8_pmu>;

344

345

regulators {

346

vdd_center: DCDC_REG1 {

347

regulator-name = "vdd_center";

348

regulator-always-on;

349

regulator-boot-on;

350

regulator-min-microvolt = <750000>;

351

regulator-max-microvolt = <1350000>;

352

regulator-ramp-delay = <6001>;

353

regulator-state-mem {

354

regulator-off-in-suspend;

355

};

356

};

357

358

vdd_cpu_l: DCDC_REG2 {

359

regulator-name = "vdd_cpu_l";

360

regulator-always-on;

361

regulator-boot-on;

362

regulator-min-microvolt = <750000>;

363

regulator-max-microvolt = <1350000>;

364

regulator-ramp-delay = <6001>;

365

regulator-state-mem {

366

regulator-off-in-suspend;

367

};

368

};

369

370

vcc_ddr: DCDC_REG3 {

371

regulator-name = "vcc_ddr";

372

regulator-always-on;

373

regulator-boot-on;

374

regulator-state-mem {

375

regulator-on-in-suspend;

376

};

377

};

378

379

vcc_1v8: DCDC_REG4 {

380

regulator-name = "vcc_1v8";

381

regulator-always-on;

382

regulator-boot-on;

383

regulator-min-microvolt = <1800000>;

384

regulator-max-microvolt = <1800000>;

385

regulator-state-mem {

386

regulator-on-in-suspend;

387

regulator-suspend-microvolt = <1800000>;

388

};

389

};

390

391

vcc1v8_dvp: LDO_REG1 {

392

regulator-name = "vcc1v8_dvp";

393

regulator-always-on;

394

regulator-boot-on;

395

regulator-min-microvolt = <1800000>;

396

regulator-max-microvolt = <1800000>;

397

regulator-state-mem {

398

regulator-off-in-suspend;

399

};

400

};

401

402

vcc2v8_dvp: LDO_REG2 {

403

regulator-name = "vcc2v8_dvp";

404

regulator-always-on;

405

regulator-boot-on;

406

regulator-min-microvolt = <2800000>;

407

regulator-max-microvolt = <2800000>;

408

regulator-state-mem {

409

regulator-off-in-suspend;

410

};

411

};

412

413

vcc1v8_pmu: LDO_REG3 {

414

regulator-name = "vcc1v8_pmu";

415

regulator-always-on;

416

regulator-boot-on;

417

regulator-min-microvolt = <1800000>;

418

regulator-max-microvolt = <1800000>;

419

regulator-state-mem {

420

regulator-on-in-suspend;

421

regulator-suspend-microvolt = <1800000>;

422

};

423

};

424

425

vcc_sdio: LDO_REG4 {

426

regulator-name = "vcc_sdio";

427

regulator-always-on;

428

regulator-boot-on;

429

regulator-min-microvolt = <1800000>;

430

regulator-max-microvolt = <3000000>;

431

regulator-state-mem {

432

regulator-on-in-suspend;

433

regulator-suspend-microvolt = <3000000>;

434

};

435

};

436

437

vcca3v0_codec: LDO_REG5 {

438

regulator-name = "vcca3v0_codec";

439

regulator-always-on;

440

regulator-boot-on;

441

regulator-min-microvolt = <3000000>;

442

regulator-max-microvolt = <3000000>;

443

regulator-state-mem {

444

regulator-off-in-suspend;

445

};

446

};

447

448

vcc_1v5: LDO_REG6 {

449

regulator-name = "vcc_1v5";

450

regulator-always-on;

451

regulator-boot-on;

452

regulator-min-microvolt = <1500000>;

453

regulator-max-microvolt = <1500000>;

454

regulator-state-mem {

455

regulator-on-in-suspend;

456

regulator-suspend-microvolt = <1500000>;

457

};

458

};

459

460

vcca1v8_codec: LDO_REG7 {

461

regulator-name = "vcca1v8_codec";

462

regulator-always-on;

463

regulator-boot-on;

464

regulator-min-microvolt = <1800000>;

465

regulator-max-microvolt = <1800000>;

466

regulator-state-mem {

467

regulator-off-in-suspend;

468

};

469

};

470

471

vcc_3v0: LDO_REG8 {

472

regulator-name = "vcc_3v0";

473

regulator-always-on;

474

regulator-boot-on;

475

regulator-min-microvolt = <3000000>;

476

regulator-max-microvolt = <3000000>;

477

regulator-state-mem {

478

regulator-on-in-suspend;

479

regulator-suspend-microvolt = <3000000>;

480

};

481

};

482

483

vcc3v3_s3: vcc_lan: SWITCH_REG1 {

484

regulator-name = "vcc3v3_s3";

485

regulator-always-on;

486

regulator-boot-on;

487

regulator-state-mem {

488

regulator-off-in-suspend;

489

};

490

};

491

492

vcc3v3_s0: SWITCH_REG2 {

493

regulator-name = "vcc3v3_s0";

494

regulator-always-on;

495

regulator-boot-on;

496

regulator-state-mem {

497

regulator-off-in-suspend;

498

};

499

};

500

};

501

};

502

503

vdd_cpu_b: regulator@40 {

504

compatible = "silergy,syr827";

505

reg = <0x40>;

506

fcs,suspend-voltage-selector = <0>;

507

regulator-name = "vdd_cpu_b";

508

regulator-min-microvolt = <712500>;

509

regulator-max-microvolt = <1500000>;

510

regulator-ramp-delay = <1000>;

511

regulator-always-on;

512

regulator-boot-on;

513

vin-supply = <&vcc_sys>;

514

515

regulator-state-mem {

516

regulator-off-in-suspend;

517

};

518

};

519

520

vdd_gpu: regulator@41 {

521

compatible = "silergy,syr828";

522

reg = <0x41>;

523

fcs,suspend-voltage-selector = <1>;

524

regulator-name = "vdd_gpu";

525

regulator-min-microvolt = <712500>;

526

regulator-max-microvolt = <1500000>;

527

regulator-ramp-delay = <1000>;

528

regulator-always-on;

529

regulator-boot-on;

530

vin-supply = <&vcc_sys>;

531

532

regulator-state-mem {

533

regulator-off-in-suspend;

534

};

535

};

536

};

537

538

&i2c1 {

539

i2c-scl-rising-time-ns = <300>;

540

i2c-scl-falling-time-ns = <15>;

541

status = "okay";

542

543

rt5640: rt5640@1c {

544

compatible = "realtek,rt5640";

545

reg = <0x1c>;

546

clocks = <&cru SCLK_I2S_8CH_OUT>;

547

clock-names = "mclk";

548

realtek,in1-differential;

549

#sound-dai-cells = <0>;

550

pinctrl-names = "default";

551

pinctrl-0 = <&rt5640_hpcon>;

552

};

553

};

554

555

&i2c3 {

556

i2c-scl-rising-time-ns = <450>;

557

i2c-scl-falling-time-ns = <15>;

558

status = "okay";

559

};

560

561

&i2c4 {

562

i2c-scl-rising-time-ns = <600>;

563

i2c-scl-falling-time-ns = <20>;

564

status = "okay";

565

566

fusb0: typec-portc@22 {

567

compatible = "fcs,fusb302";

568

reg = <0x22>;

569

interrupt-parent = <&gpio1>;

570

interrupts = <RK_PA2 IRQ_TYPE_LEVEL_LOW>;

571

pinctrl-names = "default";

572

pinctrl-0 = <&fusb0_int>;

573

vbus-supply = <&vcc5v0_typec>;

574

status = "okay";

575

576

connector {

577

compatible = "usb-c-connector";

578

data-role = "host";

579

label = "USB-C";

580

op-sink-microwatt = <1000000>;

581

power-role = "dual";

582

sink-pdos =

583

<PDO_FIXED(5000, 2500, PDO_FIXED_USB_COMM)>;

584

source-pdos =

585

<PDO_FIXED(5000, 1400, PDO_FIXED_USB_COMM)>;

586

try-power-role = "sink";

587

588

ports {

589

#address-cells = <1>;

590

#size-cells = <0>;

591

592

port@0 {

593

reg = <0>;

594

595

usbc_hs: endpoint {

596

remote-endpoint =

597

<&u2phy0_typec_hs>;

598

};

599

};

600

601

port@1 {

602

reg = <1>;

603

604

usbc_ss: endpoint {

605

remote-endpoint =

606

<&tcphy0_typec_ss>;

607

};

608

};

609

};

610

};

611

};

612

613

accelerometer@68 {

614

compatible = "invensense,mpu6500";

615

reg = <0x68>;

616

interrupt-parent = <&gpio1>;

617

interrupts = <RK_PC6 IRQ_TYPE_EDGE_RISING>;

618

};

619

};

620

621

&i2s0 {

622

rockchip,playback-channels = <8>;

623

rockchip,capture-channels = <8>;

624

status = "okay";

625

};

626

627

&i2s1 {

628

rockchip,playback-channels = <2>;

629

rockchip,capture-channels = <2>;

630

status = "okay";

631

};

632

633

&i2s2 {

634

status = "okay";

635

};

636

637

&io_domains {

638

status = "okay";

639

640

bt656-supply = <&vcc1v8_dvp>;

641

audio-supply = <&vcca1v8_codec>;

642

sdmmc-supply = <&vcc_sdio>;

643

gpio1830-supply = <&vcc_3v0>;

644

};

645

646

&pcie_phy {

647

status = "okay";

648

};

649

650

&pcie0 {

651

ep-gpios = <&gpio4 RK_PD1 GPIO_ACTIVE_HIGH>;

652

num-lanes = <4>;

653

pinctrl-names = "default";

654

pinctrl-0 = <&pcie_clkreqn_cpm>;

655

status = "okay";

656

};

657

658

&pmu_io_domains {

659

pmu1830-supply = <&vcc_3v0>;

660

status = "okay";

661

};

662

663

&pinctrl {

664

buttons {

665

pwrbtn: pwrbtn {

666

rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>;

667

};

668

};

669

670

fusb302x {

671

fusb0_int: fusb0-int {

672

rockchip,pins = <1 RK_PA2 RK_FUNC_GPIO &pcfg_pull_up>;

673

};

674

};

675

676

ir {

677

ir_int: ir-int {

678

rockchip,pins = <0 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;

679

};

680

};

681

682

lcd-panel {

683

lcd_panel_reset: lcd-panel-reset {

684

rockchip,pins = <4 RK_PD6 RK_FUNC_GPIO &pcfg_pull_up>;

685

};

686

};

687

688

leds {

689

work_led_pin: work-led-pin {

690

rockchip,pins = <2 RK_PD3 RK_FUNC_GPIO &pcfg_pull_none>;

691

};

692

693

diy_led_pin: diy-led-pin {

694

rockchip,pins = <0 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>;

695

};

696

};

697

698

pcie {

699

pcie_pwr_en: pcie-pwr-en {

700

rockchip,pins = <1 RK_PC1 RK_FUNC_GPIO &pcfg_pull_none>;

701

};

702

703

pcie_3g_drv: pcie-3g-drv {

704

rockchip,pins = <0 RK_PA2 RK_FUNC_GPIO &pcfg_pull_up>;

705

};

706

};

707

708

pmic {

709

pmic_int_l: pmic-int-l {

710

rockchip,pins = <1 RK_PC5 RK_FUNC_GPIO &pcfg_pull_up>;

711

};

712

713

vsel1_pin: vsel1-pin {

714

rockchip,pins = <1 RK_PC2 RK_FUNC_GPIO &pcfg_pull_down>;

715

};

716

717

vsel2_pin: vsel2-pin {

718

rockchip,pins = <1 RK_PB6 RK_FUNC_GPIO &pcfg_pull_down>;

719

};

720

};

721

722

rt5640 {

723

rt5640_hpcon: rt5640-hpcon {

724

rockchip,pins = <4 RK_PC5 RK_FUNC_GPIO &pcfg_pull_none>;

725

};

726

};

727

728

sdio-pwrseq {

729

wifi_enable_h: wifi-enable-h {

730

rockchip,pins = <0 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>;

731

};

732

};

733

734

usb-typec {

735

vcc5v0_typec_en: vcc5v0_typec_en {

736

rockchip,pins = <1 RK_PA3 RK_FUNC_GPIO &pcfg_pull_up>;

737

};

738

};

739

740

usb2 {

741

vcc5v0_host_en: vcc5v0-host-en {

742

rockchip,pins = <1 RK_PA0 RK_FUNC_GPIO &pcfg_pull_none>;

743

};

744

};

745

746

wifi {

747

wifi_host_wake_l: wifi-host-wake-l {

748

rockchip,pins = <0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>;

749

};

750

};

751

};

752

753

&pwm0 {

754

status = "okay";

755

};

756

757

&pwm2 {

758

status = "okay";

759

};

760

761

&saradc {

762

vref-supply = <&vcca1v8_s3>;

763

status = "okay";

764

};

765

766

&sdio0 {

767

/* WiFi & BT combo module Ampak AP6356S */

768

bus-width = <4>;

769

cap-sdio-irq;

770

cap-sd-highspeed;

771

keep-power-in-suspend;

772

mmc-pwrseq = <&sdio_pwrseq>;

773

non-removable;

774

pinctrl-names = "default";

775

pinctrl-0 = <&sdio0_bus4 &sdio0_cmd &sdio0_clk>;

776

sd-uhs-sdr104;

777

778

/* Power supply */

779

vqmmc-supply = <&vcc1v8_s3>;/* IO line */

780

vmmc-supply = <&vcc_sdio>;/* card's power */

781

782

#address-cells = <1>;

783

#size-cells = <0>;

784

status = "okay";

785

786

brcmf: wifi@1 {

787

reg = <1>;

788

compatible = "brcm,bcm4329-fmac";

789

interrupt-parent = <&gpio0>;

790

interrupts = <RK_PA3 IRQ_TYPE_LEVEL_HIGH>;

791

interrupt-names = "host-wake";

792

brcm,drive-strength = <5>;

793

pinctrl-names = "default";

794

pinctrl-0 = <&wifi_host_wake_l>;

795

};

796

};

797

798

&sdmmc {

799

bus-width = <4>;

800

cap-mmc-highspeed;

801

cap-sd-highspeed;

802

cd-gpios = <&gpio0 7 GPIO_ACTIVE_LOW>;

803

disable-wp;

804

max-frequency = <150000000>;

805

pinctrl-names = "default";

806

pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_bus4>;

807

status = "okay";

808

};

809

810

&sdhci {

811

bus-width = <8>;

812

mmc-hs400-1_8v;

813

mmc-hs400-enhanced-strobe;

814

non-removable;

815

status = "okay";

816

};

817

818

&spdif {

819

pinctrl-0 = <&spdif_bus_1>;

820

status = "okay";

821

822

spdif_p0: port {

823

spdif_p0_0: endpoint {

824

remote-endpoint = <&dit_p0_0>;

825

};

826

};

827

};

828

829

&tcphy0 {

830

status = "okay";

831

};

832

833

&tcphy0_usb3 {

834

port {

835

tcphy0_typec_ss: endpoint {

836

remote-endpoint = <&usbc_ss>;

837

};

838

};

839

};

840

841

&tcphy1 {

842

status = "okay";

843

};

844

845

&tsadc {

846

/* tshut mode 0:CRU 1:GPIO */

847

rockchip,hw-tshut-mode = <1>;

848

/* tshut polarity 0:LOW 1:HIGH */

849

rockchip,hw-tshut-polarity = <1>;

850

status = "okay";

851

};

852

853

&u2phy0 {

854

status = "okay";

855

856

u2phy0_otg: otg-port {

857

status = "okay";

858

};

859

860

u2phy0_host: host-port {

861

phy-supply = <&vcc5v0_host>;

862

status = "okay";

863

};

864

865

port {

866

u2phy0_typec_hs: endpoint {

867

remote-endpoint = <&usbc_hs>;

868

};

869

};

870

};

871

872

&u2phy1 {

873

status = "okay";

874

875

u2phy1_otg: otg-port {

876

status = "okay";

877

};

878

879

u2phy1_host: host-port {

880

phy-supply = <&vcc5v0_host>;

881

status = "okay";

882

};

883

};

884

885

&uart0 {

886

pinctrl-names = "default";

887

pinctrl-0 = <&uart0_xfer &uart0_cts>;

888

status = "okay";

889

};

890

891

&uart2 {

892

status = "okay";

893

};

894

895

&usb_host0_ehci {

896

status = "okay";

897

};

898

899

&usb_host0_ohci {

900

status = "okay";

901

};

902

903

&usb_host1_ehci {

904

status = "okay";

905

};

906

907

&usb_host1_ohci {

908

status = "okay";

909

};

910

911

&usbdrd3_0 {

912

status = "okay";

913

};

914

915

&usbdrd_dwc3_0 {

916

status = "okay";

917

dr_mode = "otg";

918

};

919

920

&usbdrd3_1 {

921

status = "okay";

922

};

923

924

&usbdrd_dwc3_1 {

925

status = "okay";

926

dr_mode = "host";

927

};

928

929

&vopb {

930

status = "okay";

931

};

932

933

&vopb_mmu {

934

status = "okay";

935

};

936

937

&vopl {

938

status = "okay";

939

};

940

941

&vopl_mmu {

942

status = "okay";

943

};

944

arch/arm64/boot/dts/rockchip/rk3399-firefly.dts - master | Gitverse (2024)
Top Articles
Latest Posts
Recommended Articles
Article information

Author: Stevie Stamm

Last Updated:

Views: 5942

Rating: 5 / 5 (60 voted)

Reviews: 91% of readers found this page helpful

Author information

Name: Stevie Stamm

Birthday: 1996-06-22

Address: Apt. 419 4200 Sipes Estate, East Delmerview, WY 05617

Phone: +342332224300

Job: Future Advertising Analyst

Hobby: Leather crafting, Puzzles, Leather crafting, scrapbook, Urban exploration, Cabaret, Skateboarding

Introduction: My name is Stevie Stamm, I am a colorful, sparkling, splendid, vast, open, hilarious, tender person who loves writing and wants to share my knowledge and understanding with you.