18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * Applied Micro X-Gene SoC Ethernet v2 Driver
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (c) 2017, Applied Micro Circuits Corporation
68c2ecf20Sopenharmony_ci * Author(s): Iyappan Subramanian <isubramanian@apm.com>
78c2ecf20Sopenharmony_ci *	      Keyur Chudgar <kchudgar@apm.com>
88c2ecf20Sopenharmony_ci */
98c2ecf20Sopenharmony_ci
108c2ecf20Sopenharmony_ci#include "main.h"
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_civoid xge_wr_csr(struct xge_pdata *pdata, u32 offset, u32 val)
138c2ecf20Sopenharmony_ci{
148c2ecf20Sopenharmony_ci	void __iomem *addr = pdata->resources.base_addr + offset;
158c2ecf20Sopenharmony_ci
168c2ecf20Sopenharmony_ci	iowrite32(val, addr);
178c2ecf20Sopenharmony_ci}
188c2ecf20Sopenharmony_ci
198c2ecf20Sopenharmony_ciu32 xge_rd_csr(struct xge_pdata *pdata, u32 offset)
208c2ecf20Sopenharmony_ci{
218c2ecf20Sopenharmony_ci	void __iomem *addr = pdata->resources.base_addr + offset;
228c2ecf20Sopenharmony_ci
238c2ecf20Sopenharmony_ci	return ioread32(addr);
248c2ecf20Sopenharmony_ci}
258c2ecf20Sopenharmony_ci
268c2ecf20Sopenharmony_ciint xge_port_reset(struct net_device *ndev)
278c2ecf20Sopenharmony_ci{
288c2ecf20Sopenharmony_ci	struct xge_pdata *pdata = netdev_priv(ndev);
298c2ecf20Sopenharmony_ci	struct device *dev = &pdata->pdev->dev;
308c2ecf20Sopenharmony_ci	u32 data, wait = 10;
318c2ecf20Sopenharmony_ci
328c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, ENET_CLKEN, 0x3);
338c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, ENET_SRST, 0xf);
348c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, ENET_SRST, 0);
358c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, CFG_MEM_RAM_SHUTDOWN, 1);
368c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, CFG_MEM_RAM_SHUTDOWN, 0);
378c2ecf20Sopenharmony_ci
388c2ecf20Sopenharmony_ci	do {
398c2ecf20Sopenharmony_ci		usleep_range(100, 110);
408c2ecf20Sopenharmony_ci		data = xge_rd_csr(pdata, BLOCK_MEM_RDY);
418c2ecf20Sopenharmony_ci	} while (data != MEM_RDY && wait--);
428c2ecf20Sopenharmony_ci
438c2ecf20Sopenharmony_ci	if (data != MEM_RDY) {
448c2ecf20Sopenharmony_ci		dev_err(dev, "ECC init failed: %x\n", data);
458c2ecf20Sopenharmony_ci		return -ETIMEDOUT;
468c2ecf20Sopenharmony_ci	}
478c2ecf20Sopenharmony_ci
488c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, ENET_SHIM, DEVM_ARAUX_COH | DEVM_AWAUX_COH);
498c2ecf20Sopenharmony_ci
508c2ecf20Sopenharmony_ci	return 0;
518c2ecf20Sopenharmony_ci}
528c2ecf20Sopenharmony_ci
538c2ecf20Sopenharmony_cistatic void xge_traffic_resume(struct net_device *ndev)
548c2ecf20Sopenharmony_ci{
558c2ecf20Sopenharmony_ci	struct xge_pdata *pdata = netdev_priv(ndev);
568c2ecf20Sopenharmony_ci
578c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, CFG_FORCE_LINK_STATUS_EN, 1);
588c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, FORCE_LINK_STATUS, 1);
598c2ecf20Sopenharmony_ci
608c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, CFG_LINK_AGGR_RESUME, 1);
618c2ecf20Sopenharmony_ci	xge_wr_csr(pdata, RX_DV_GATE_REG, 1);
628c2ecf20Sopenharmony_ci}
638c2ecf20Sopenharmony_ci
648c2ecf20Sopenharmony_civoid xge_port_init(struct net_device *ndev)
658c2ecf20Sopenharmony_ci{
668c2ecf20Sopenharmony_ci	struct xge_pdata *pdata = netdev_priv(ndev);
678c2ecf20Sopenharmony_ci
688c2ecf20Sopenharmony_ci	pdata->phy_speed = SPEED_1000;
698c2ecf20Sopenharmony_ci	xge_mac_init(pdata);
708c2ecf20Sopenharmony_ci	xge_traffic_resume(ndev);
718c2ecf20Sopenharmony_ci}
72