1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0 2*4882a593Smuzhiyun/* 3*4882a593Smuzhiyun * Device Tree Source for K2G Netcp driver 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2018 Texas Instruments Incorporated - http://www.ti.com/ 6*4882a593Smuzhiyun */ 7*4882a593Smuzhiyun 8*4882a593Smuzhiyunqmss: qmss@4020000 { 9*4882a593Smuzhiyun compatible = "ti,66ak2g-navss-qm"; 10*4882a593Smuzhiyun dma-coherent; 11*4882a593Smuzhiyun #address-cells = <1>; 12*4882a593Smuzhiyun #size-cells = <1>; 13*4882a593Smuzhiyun power-domains = <&k2g_pds 0x0018>; 14*4882a593Smuzhiyun clocks = <&k2g_clks 0x0018 0>; 15*4882a593Smuzhiyun clock-names = "nss_vclk"; 16*4882a593Smuzhiyun ranges; 17*4882a593Smuzhiyun queue-range = <0 0x80>; 18*4882a593Smuzhiyun linkram0 = <0x4020000 0x7ff>; 19*4882a593Smuzhiyun status = "disabled"; 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun qmgrs { 22*4882a593Smuzhiyun #address-cells = <1>; 23*4882a593Smuzhiyun #size-cells = <1>; 24*4882a593Smuzhiyun ranges; 25*4882a593Smuzhiyun qmgr0 { 26*4882a593Smuzhiyun managed-queues = <0 0x80>; 27*4882a593Smuzhiyun reg = <0x4100000 0x800>, 28*4882a593Smuzhiyun <0x4040000 0x100>, 29*4882a593Smuzhiyun <0x4080000 0x800>, 30*4882a593Smuzhiyun <0x40c0000 0x800>; 31*4882a593Smuzhiyun reg-names = "peek", "config", 32*4882a593Smuzhiyun "region", "push"; 33*4882a593Smuzhiyun }; 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun }; 36*4882a593Smuzhiyun queue-pools { 37*4882a593Smuzhiyun qpend { 38*4882a593Smuzhiyun qpend-0 { 39*4882a593Smuzhiyun qrange = <77 8>; 40*4882a593Smuzhiyun interrupts =<0 308 0xf04 0 309 0xf04 0 310 0xf04 41*4882a593Smuzhiyun 0 311 0xf04 0 312 0xf04 0 313 0xf04 42*4882a593Smuzhiyun 0 314 0xf04 0 315 0xf04>; 43*4882a593Smuzhiyun qalloc-by-id; 44*4882a593Smuzhiyun }; 45*4882a593Smuzhiyun }; 46*4882a593Smuzhiyun general-purpose { 47*4882a593Smuzhiyun gp-0 { 48*4882a593Smuzhiyun qrange = <112 8>; 49*4882a593Smuzhiyun }; 50*4882a593Smuzhiyun netcp-tx { 51*4882a593Smuzhiyun qrange = <5 8>; 52*4882a593Smuzhiyun qalloc-by-id; 53*4882a593Smuzhiyun }; 54*4882a593Smuzhiyun }; 55*4882a593Smuzhiyun }; 56*4882a593Smuzhiyun 57*4882a593Smuzhiyun descriptor-regions { 58*4882a593Smuzhiyun #address-cells = <1>; 59*4882a593Smuzhiyun #size-cells = <1>; 60*4882a593Smuzhiyun ranges; 61*4882a593Smuzhiyun region-12 { 62*4882a593Smuzhiyun id = <12>; 63*4882a593Smuzhiyun region-spec = <1023 128>; /* num_desc desc_size */ 64*4882a593Smuzhiyun link-index = <0x400>; 65*4882a593Smuzhiyun }; 66*4882a593Smuzhiyun }; 67*4882a593Smuzhiyun}; /* qmss */ 68*4882a593Smuzhiyun 69*4882a593Smuzhiyunknav_dmas: knav_dmas@0 { 70*4882a593Smuzhiyun compatible = "ti,keystone-navigator-dma"; 71*4882a593Smuzhiyun #address-cells = <1>; 72*4882a593Smuzhiyun #size-cells = <1>; 73*4882a593Smuzhiyun status = "disabled"; 74*4882a593Smuzhiyun power-domains = <&k2g_pds 0x0018>; 75*4882a593Smuzhiyun clocks = <&k2g_clks 0x0018 0>; 76*4882a593Smuzhiyun clock-names = "nss_vclk"; 77*4882a593Smuzhiyun ranges; 78*4882a593Smuzhiyun ti,navigator-cloud-address = <0x40c0000 0x40c0000 0x40c0000 0x40c0000>; 79*4882a593Smuzhiyun 80*4882a593Smuzhiyun dma_gbe: dma_gbe@0 { 81*4882a593Smuzhiyun reg = <0x4010000 0x100>, 82*4882a593Smuzhiyun <0x4011000 0x2a0>, /* 21 Tx channels */ 83*4882a593Smuzhiyun <0x4012000 0x400>, /* 32 Rx channels */ 84*4882a593Smuzhiyun <0x4010100 0x80>, 85*4882a593Smuzhiyun <0x4013000 0x400>; /* 32 Rx flows */ 86*4882a593Smuzhiyun reg-names = "global", "txchan", "rxchan", 87*4882a593Smuzhiyun "txsched", "rxflow"; 88*4882a593Smuzhiyun }; 89*4882a593Smuzhiyun 90*4882a593Smuzhiyun}; 91*4882a593Smuzhiyun 92*4882a593Smuzhiyunnetcp: netcp@4000000 { 93*4882a593Smuzhiyun reg = <0x2620110 0x8>; 94*4882a593Smuzhiyun reg-names = "efuse"; 95*4882a593Smuzhiyun compatible = "ti,netcp-1.0"; 96*4882a593Smuzhiyun #address-cells = <1>; 97*4882a593Smuzhiyun #size-cells = <1>; 98*4882a593Smuzhiyun status = "disabled"; 99*4882a593Smuzhiyun power-domains = <&k2g_pds 0x0018>; 100*4882a593Smuzhiyun clocks = <&k2g_clks 0x0018 3>, <&k2g_clks 0x0018 8>; 101*4882a593Smuzhiyun clock-names = "ethss_clk", "cpts"; 102*4882a593Smuzhiyun 103*4882a593Smuzhiyun /* NetCP address range */ 104*4882a593Smuzhiyun ranges = <0 0x4000000 0x1000000>; 105*4882a593Smuzhiyun 106*4882a593Smuzhiyun dma-coherent; 107*4882a593Smuzhiyun 108*4882a593Smuzhiyun ti,navigator-dmas = <&dma_gbe 0>, <&dma_gbe 5>; 109*4882a593Smuzhiyun ti,navigator-dma-names = "netrx0", "nettx"; 110*4882a593Smuzhiyun 111*4882a593Smuzhiyun netcp-devices { 112*4882a593Smuzhiyun #address-cells = <1>; 113*4882a593Smuzhiyun #size-cells = <1>; 114*4882a593Smuzhiyun ranges; 115*4882a593Smuzhiyun gbe: gbe@200000 { 116*4882a593Smuzhiyun label = "netcp-gbe"; 117*4882a593Smuzhiyun compatible = "ti,netcp-gbe-2"; 118*4882a593Smuzhiyun reg = <0x200000 0x20>, <0x220000 0x20000>; 119*4882a593Smuzhiyun enable-ale; 120*4882a593Smuzhiyun tx-queue = <5>; 121*4882a593Smuzhiyun tx-channel = "nettx"; 122*4882a593Smuzhiyun cpts-rftclk-sel = <0>; 123*4882a593Smuzhiyun cpts-ext-ts-inputs = <8>; 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun interfaces { 126*4882a593Smuzhiyun gbe0: interface-0 { 127*4882a593Smuzhiyun slave-port = <0>; 128*4882a593Smuzhiyun link-interface = <5>; 129*4882a593Smuzhiyun }; 130*4882a593Smuzhiyun }; 131*4882a593Smuzhiyun }; 132*4882a593Smuzhiyun }; 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun netcp-interfaces { 135*4882a593Smuzhiyun interface-0 { 136*4882a593Smuzhiyun rx-channel = "netrx0"; 137*4882a593Smuzhiyun rx-pool = <512 12>; 138*4882a593Smuzhiyun tx-pool = <511 12>; 139*4882a593Smuzhiyun rx-queue-depth = <128 128 0 0>; 140*4882a593Smuzhiyun rx-buffer-size = <1518 4096 0 0>; 141*4882a593Smuzhiyun rx-queue = <77>; 142*4882a593Smuzhiyun tx-completion-queue = <78>; 143*4882a593Smuzhiyun efuse-mac = <1>; 144*4882a593Smuzhiyun netcp-gbe = <&gbe0>; 145*4882a593Smuzhiyun }; 146*4882a593Smuzhiyun }; 147*4882a593Smuzhiyun}; 148