mirror of
				https://github.com/Ysurac/openmptcprouter.git
				synced 2025-03-09 15:40:20 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			91 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From f3565e6c2276411275e707a5442d3f69cc111273 Mon Sep 17 00:00:00 2001
 | |
| Message-Id: <f3565e6c2276411275e707a5442d3f69cc111273.1678718888.git.lorenzo@kernel.org>
 | |
| From: Lorenzo Bianconi <lorenzo@kernel.org>
 | |
| Date: Sun, 12 Mar 2023 18:51:47 +0100
 | |
| Subject: [PATCH net-next 1/3] net: ethernet: mtk_wed: move ilm a dedicated dts
 | |
|  node
 | |
| 
 | |
| Since the ilm memory region is not part of the RAM SoC, move ilm in a
 | |
| deidicated syscon node.
 | |
| This patch helps to keep backward-compatibility with older version of
 | |
| uboot codebase where we have a limit of 8 reserved-memory dts child
 | |
| nodes.
 | |
| Keep backward-compatibility with older dts version where ilm was defined
 | |
| as reserved-memory child node.
 | |
| 
 | |
| Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
 | |
| ---
 | |
|  drivers/net/ethernet/mediatek/mtk_wed_mcu.c | 55 ++++++++++++++++++---
 | |
|  1 file changed, 49 insertions(+), 6 deletions(-)
 | |
| 
 | |
| --- a/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
 | |
| +++ b/drivers/net/ethernet/mediatek/mtk_wed_mcu.c
 | |
| @@ -300,6 +300,52 @@ next:
 | |
|  }
 | |
|  
 | |
|  static int
 | |
| +mtk_wed_mcu_load_memory_regions(struct mtk_wed_wo *wo,
 | |
| +				struct mtk_wed_wo_memory_region *region)
 | |
| +{
 | |
| +	struct device_node *np;
 | |
| +	int ret;
 | |
| +
 | |
| +	/* firmware EMI memory region */
 | |
| +	ret = mtk_wed_get_reserved_memory_region(wo,
 | |
| +			®ion[MTK_WED_WO_REGION_EMI]);
 | |
| +	if (ret)
 | |
| +		return ret;
 | |
| +
 | |
| +	/* firmware DATA memory region */
 | |
| +	ret = mtk_wed_get_reserved_memory_region(wo,
 | |
| +			®ion[MTK_WED_WO_REGION_DATA]);
 | |
| +	if (ret)
 | |
| +		return ret;
 | |
| +
 | |
| +	np = of_parse_phandle(wo->hw->node, "mediatek,wo-ilm", 0);
 | |
| +	if (np) {
 | |
| +		struct mtk_wed_wo_memory_region *ilm_region;
 | |
| +		struct resource res;
 | |
| +
 | |
| +		ret = of_address_to_resource(np, 0, &res);
 | |
| +		of_node_put(np);
 | |
| +
 | |
| +		if (ret < 0)
 | |
| +			return ret;
 | |
| +
 | |
| +		ilm_region = ®ion[MTK_WED_WO_REGION_ILM];
 | |
| +		ilm_region->phy_addr = res.start;
 | |
| +		ilm_region->size = resource_size(&res);
 | |
| +		ilm_region->addr = devm_ioremap(wo->hw->dev, res.start,
 | |
| +						resource_size(&res));
 | |
| +
 | |
| +		return IS_ERR(ilm_region->addr) ? PTR_ERR(ilm_region->addr) : 0;
 | |
| +	}
 | |
| +
 | |
| +	/* For backward compatibility, we need to check if ILM
 | |
| +	 * node is defined through reserved memory property.
 | |
| +	 */
 | |
| +	return mtk_wed_get_reserved_memory_region(wo,
 | |
| +			®ion[MTK_WED_WO_REGION_ILM]);
 | |
| +}
 | |
| +
 | |
| +static int
 | |
|  mtk_wed_mcu_load_firmware(struct mtk_wed_wo *wo)
 | |
|  {
 | |
|  	static struct mtk_wed_wo_memory_region mem_region[] = {
 | |
| @@ -320,12 +366,9 @@ mtk_wed_mcu_load_firmware(struct mtk_wed
 | |
|  	u32 val, boot_cr;
 | |
|  	int ret, i;
 | |
|  
 | |
| -	/* load firmware region metadata */
 | |
| -	for (i = 0; i < ARRAY_SIZE(mem_region); i++) {
 | |
| -		ret = mtk_wed_get_reserved_memory_region(wo, &mem_region[i]);
 | |
| -		if (ret)
 | |
| -			return ret;
 | |
| -	}
 | |
| +	ret = mtk_wed_mcu_load_memory_regions(wo, mem_region);
 | |
| +	if (ret)
 | |
| +		return ret;
 | |
|  
 | |
|  	wo->boot_regmap = syscon_regmap_lookup_by_phandle(wo->hw->node,
 | |
|  							  "mediatek,wo-cpuboot");
 |