54 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0+
 | |
| /* Microchip Sparx5 Switch driver
 | |
|  *
 | |
|  * Copyright (c) 2023 Microchip Technology Inc. and its subsidiaries.
 | |
|  */
 | |
| 
 | |
| #include "sparx5_main_regs.h"
 | |
| #include "sparx5_main.h"
 | |
| 
 | |
| static int sparx5_policer_service_conf_set(struct sparx5 *sparx5,
 | |
| 					   struct sparx5_policer *pol)
 | |
| {
 | |
| 	u32 idx, pup_tokens, max_pup_tokens, burst, thres;
 | |
| 	struct sparx5_sdlb_group *g;
 | |
| 	u64 rate;
 | |
| 
 | |
| 	g = &sdlb_groups[pol->group];
 | |
| 	idx = pol->idx;
 | |
| 
 | |
| 	rate = pol->rate * 1000;
 | |
| 	burst = pol->burst;
 | |
| 
 | |
| 	pup_tokens = sparx5_sdlb_pup_token_get(sparx5, g->pup_interval, rate);
 | |
| 	max_pup_tokens =
 | |
| 		sparx5_sdlb_pup_token_get(sparx5, g->pup_interval, g->max_rate);
 | |
| 
 | |
| 	thres = DIV_ROUND_UP(burst, g->min_burst);
 | |
| 
 | |
| 	spx5_wr(ANA_AC_SDLB_PUP_TOKENS_PUP_TOKENS_SET(pup_tokens), sparx5,
 | |
| 		ANA_AC_SDLB_PUP_TOKENS(idx, 0));
 | |
| 
 | |
| 	spx5_rmw(ANA_AC_SDLB_INH_CTRL_PUP_TOKENS_MAX_SET(max_pup_tokens),
 | |
| 		 ANA_AC_SDLB_INH_CTRL_PUP_TOKENS_MAX, sparx5,
 | |
| 		 ANA_AC_SDLB_INH_CTRL(idx, 0));
 | |
| 
 | |
| 	spx5_rmw(ANA_AC_SDLB_THRES_THRES_SET(thres), ANA_AC_SDLB_THRES_THRES,
 | |
| 		 sparx5, ANA_AC_SDLB_THRES(idx, 0));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int sparx5_policer_conf_set(struct sparx5 *sparx5, struct sparx5_policer *pol)
 | |
| {
 | |
| 	/* More policer types will be added later */
 | |
| 	switch (pol->type) {
 | |
| 	case SPX5_POL_SERVICE:
 | |
| 		return sparx5_policer_service_conf_set(sparx5, pol);
 | |
| 	default:
 | |
| 		break;
 | |
| 	}
 | |
| 
 | |
| 	return 0;
 | |
| }
 |