rtl_w0w1_eri(tp, 0x0d4, ERIAR_MASK_0011, 0x0c00, 0x0000, ERIAR_EXGMAC);
 }
 
-static void rtl_hw_start_8168g_1(struct rtl8169_private *tp)
+static void rtl_hw_start_8168g(struct rtl8169_private *tp)
 {
        void __iomem *ioaddr = tp->mmio_addr;
        struct pci_dev *pdev = tp->pci_dev;
        rtl_pcie_state_l2l3_enable(tp, false);
 }
 
+static void rtl_hw_start_8168g_1(struct rtl8169_private *tp)
+{
+       void __iomem *ioaddr = tp->mmio_addr;
+       static const struct ephy_info e_info_8168g_1[] = {
+               { 0x00, 0x0000, 0x0008 },
+               { 0x0c, 0x37d0, 0x0820 },
+               { 0x1e, 0x0000, 0x0001 },
+               { 0x19, 0x8000, 0x0000 }
+       };
+
+       rtl_hw_start_8168g(tp);
+
+       /* disable aspm and clock request before access ephy */
+       RTL_W8(Config2, RTL_R8(Config2) & ~ClkReqEn);
+       RTL_W8(Config5, RTL_R8(Config5) & ~ASPM_en);
+       rtl_ephy_init(tp, e_info_8168g_1, ARRAY_SIZE(e_info_8168g_1));
+}
+
 static void rtl_hw_start_8168g_2(struct rtl8169_private *tp)
 {
        void __iomem *ioaddr = tp->mmio_addr;
                { 0x1e, 0xffff, 0x20eb }
        };
 
-       rtl_hw_start_8168g_1(tp);
+       rtl_hw_start_8168g(tp);
 
        /* disable aspm and clock request before access ephy */
        RTL_W8(Config2, RTL_R8(Config2) & ~ClkReqEn);
                { 0x1e, 0x0000, 0x2000 }
        };
 
-       rtl_hw_start_8168g_1(tp);
+       rtl_hw_start_8168g(tp);
 
        /* disable aspm and clock request before access ephy */
        RTL_W8(Config2, RTL_R8(Config2) & ~ClkReqEn);