mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-31 14:04:26 -04:00 
			
		
		
		
	The qca8k patch series brings the numbering to 799. This patch renames 7xx patches to create space for more backports to be added. Signed-off-by: Matthew Hagan <mnhagan88@gmail.com> [rename 729->719] Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0d56e5c191b197e1d30a0a4c92628836dafced0f Mon Sep 17 00:00:00 2001
 | |
| From: Wei Yongjun <weiyongjun1@huawei.com>
 | |
| Date: Tue, 18 May 2021 11:24:13 +0000
 | |
| Subject: [PATCH] net: dsa: qca8k: fix missing unlock on error in
 | |
|  qca8k_vlan_(add|del)
 | |
| 
 | |
| Add the missing unlock before return from function qca8k_vlan_add()
 | |
| and qca8k_vlan_del() in the error handling case.
 | |
| 
 | |
| Fixes: 028f5f8ef44f ("net: dsa: qca8k: handle error with qca8k_read operation")
 | |
| Reported-by: Hulk Robot <hulkci@huawei.com>
 | |
| Signed-off-by: Wei Yongjun <weiyongjun1@huawei.com>
 | |
| Reviewed-by: Vladimir Oltean <olteanv@gmail.com>
 | |
| Signed-off-by: David S. Miller <davem@davemloft.net>
 | |
| ---
 | |
|  drivers/net/dsa/qca8k.c | 16 ++++++++++------
 | |
|  1 file changed, 10 insertions(+), 6 deletions(-)
 | |
| 
 | |
| --- a/drivers/net/dsa/qca8k.c
 | |
| +++ b/drivers/net/dsa/qca8k.c
 | |
| @@ -506,8 +506,10 @@ qca8k_vlan_add(struct qca8k_priv *priv,
 | |
|  		goto out;
 | |
|  
 | |
|  	reg = qca8k_read(priv, QCA8K_REG_VTU_FUNC0);
 | |
| -	if (reg < 0)
 | |
| -		return reg;
 | |
| +	if (reg < 0) {
 | |
| +		ret = reg;
 | |
| +		goto out;
 | |
| +	}
 | |
|  	reg |= QCA8K_VTU_FUNC0_VALID | QCA8K_VTU_FUNC0_IVL_EN;
 | |
|  	reg &= ~(QCA8K_VTU_FUNC0_EG_MODE_MASK << QCA8K_VTU_FUNC0_EG_MODE_S(port));
 | |
|  	if (untagged)
 | |
| @@ -519,7 +521,7 @@ qca8k_vlan_add(struct qca8k_priv *priv,
 | |
|  
 | |
|  	ret = qca8k_write(priv, QCA8K_REG_VTU_FUNC0, reg);
 | |
|  	if (ret)
 | |
| -		return ret;
 | |
| +		goto out;
 | |
|  	ret = qca8k_vlan_access(priv, QCA8K_VLAN_LOAD, vid);
 | |
|  
 | |
|  out:
 | |
| @@ -541,8 +543,10 @@ qca8k_vlan_del(struct qca8k_priv *priv,
 | |
|  		goto out;
 | |
|  
 | |
|  	reg = qca8k_read(priv, QCA8K_REG_VTU_FUNC0);
 | |
| -	if (reg < 0)
 | |
| -		return reg;
 | |
| +	if (reg < 0) {
 | |
| +		ret = reg;
 | |
| +		goto out;
 | |
| +	}
 | |
|  	reg &= ~(3 << QCA8K_VTU_FUNC0_EG_MODE_S(port));
 | |
|  	reg |= QCA8K_VTU_FUNC0_EG_MODE_NOT <<
 | |
|  			QCA8K_VTU_FUNC0_EG_MODE_S(port);
 | |
| @@ -564,7 +568,7 @@ qca8k_vlan_del(struct qca8k_priv *priv,
 | |
|  	} else {
 | |
|  		ret = qca8k_write(priv, QCA8K_REG_VTU_FUNC0, reg);
 | |
|  		if (ret)
 | |
| -			return ret;
 | |
| +			goto out;
 | |
|  		ret = qca8k_vlan_access(priv, QCA8K_VLAN_LOAD, vid);
 | |
|  	}
 | |
|  
 |