};
 
                pcie0: pci@20000000 {
-                       compatible = "qcom,pcie-ipq8074";
+                       compatible = "qcom,pcie-ipq8074-gen3";
                        reg = <0x20000000 0xf1d>,
                              <0x20000f20 0xa8>,
-                             <0x00080000 0x2000>,
+                             <0x20001000 0x1000>,
+                             <0x00080000 0x4000>,
                              <0x20100000 0x1000>;
-                       reg-names = "dbi", "elbi", "parf", "config";
+                       reg-names = "dbi", "elbi", "atu", "parf", "config";
                        device_type = "pci";
                        linux,pci-domain = <0>;
                        bus-range = <0x00 0xff>;
                        num-lanes = <1>;
+                       max-link-speed = <3>;
                        #address-cells = <3>;
                        #size-cells = <2>;
 
                        phy-names = "pciephy";
 
                        ranges = <0x81000000 0 0x20200000 0x20200000
-                                 0 0x100000   /* downstream I/O */
-                                 0x82000000 0 0x20300000 0x20300000
-                                 0 0xd00000>; /* non-prefetchable memory */
+                                 0 0x10000>, /* downstream I/O */
+                                <0x82000000 0 0x20220000 0x20220000
+                                 0 0xfde0000>; /* non-prefetchable memory */
 
                        interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
                        interrupt-names = "msi";
                        clocks = <&gcc GCC_SYS_NOC_PCIE0_AXI_CLK>,
                                 <&gcc GCC_PCIE0_AXI_M_CLK>,
                                 <&gcc GCC_PCIE0_AXI_S_CLK>,
-                                <&gcc GCC_PCIE0_AHB_CLK>,
-                                <&gcc GCC_PCIE0_AUX_CLK>;
-
+                                <&gcc GCC_PCIE0_AXI_S_BRIDGE_CLK>,
+                                <&gcc GCC_PCIE0_RCHNG_CLK>;
                        clock-names = "iface",
                                      "axi_m",
                                      "axi_s",
-                                     "ahb",
-                                     "aux";
+                                     "axi_bridge",
+                                     "rchng";
+
                        resets = <&gcc GCC_PCIE0_PIPE_ARES>,
                                 <&gcc GCC_PCIE0_SLEEP_ARES>,
                                 <&gcc GCC_PCIE0_CORE_STICKY_ARES>,
                                 <&gcc GCC_PCIE0_AXI_MASTER_ARES>,
                                 <&gcc GCC_PCIE0_AXI_SLAVE_ARES>,
                                 <&gcc GCC_PCIE0_AHB_ARES>,
-                                <&gcc GCC_PCIE0_AXI_MASTER_STICKY_ARES>;
+                                <&gcc GCC_PCIE0_AXI_MASTER_STICKY_ARES>,
+                                <&gcc GCC_PCIE0_AXI_SLAVE_STICKY_ARES>;
                        reset-names = "pipe",
                                      "sleep",
                                      "sticky",
                                      "axi_m",
                                      "axi_s",
                                      "ahb",
-                                     "axi_m_sticky";
+                                     "axi_m_sticky",
+                                     "axi_s_sticky";
                        status = "disabled";
                };
        };