18aa9ebccSVladimir Oltean // SPDX-License-Identifier: BSD-3-Clause
2*3c9cfb52SVladimir Oltean /* Copyright 2016-2018 NXP
38aa9ebccSVladimir Oltean  * Copyright (c) 2018-2019, Vladimir Oltean <olteanv@gmail.com>
48aa9ebccSVladimir Oltean  */
58aa9ebccSVladimir Oltean #include "sja1105_static_config.h"
68aa9ebccSVladimir Oltean #include <linux/crc32.h>
78aa9ebccSVladimir Oltean #include <linux/slab.h>
88aa9ebccSVladimir Oltean #include <linux/string.h>
98aa9ebccSVladimir Oltean #include <linux/errno.h>
108aa9ebccSVladimir Oltean 
118aa9ebccSVladimir Oltean /* Convenience wrappers over the generic packing functions. These take into
128aa9ebccSVladimir Oltean  * account the SJA1105 memory layout quirks and provide some level of
138aa9ebccSVladimir Oltean  * programmer protection against incorrect API use. The errors are not expected
148aa9ebccSVladimir Oltean  * to occur durring runtime, therefore printing and swallowing them here is
158aa9ebccSVladimir Oltean  * appropriate instead of clutterring up higher-level code.
168aa9ebccSVladimir Oltean  */
sja1105_pack(void * buf,const u64 * val,int start,int end,size_t len)178aa9ebccSVladimir Oltean void sja1105_pack(void *buf, const u64 *val, int start, int end, size_t len)
188aa9ebccSVladimir Oltean {
198aa9ebccSVladimir Oltean 	int rc = packing(buf, (u64 *)val, start, end, len,
208aa9ebccSVladimir Oltean 			 PACK, QUIRK_LSW32_IS_FIRST);
218aa9ebccSVladimir Oltean 
228aa9ebccSVladimir Oltean 	if (likely(!rc))
238aa9ebccSVladimir Oltean 		return;
248aa9ebccSVladimir Oltean 
258aa9ebccSVladimir Oltean 	if (rc == -EINVAL) {
268aa9ebccSVladimir Oltean 		pr_err("Start bit (%d) expected to be larger than end (%d)\n",
278aa9ebccSVladimir Oltean 		       start, end);
288aa9ebccSVladimir Oltean 	} else if (rc == -ERANGE) {
298aa9ebccSVladimir Oltean 		if ((start - end + 1) > 64)
308aa9ebccSVladimir Oltean 			pr_err("Field %d-%d too large for 64 bits!\n",
318aa9ebccSVladimir Oltean 			       start, end);
328aa9ebccSVladimir Oltean 		else
338aa9ebccSVladimir Oltean 			pr_err("Cannot store %llx inside bits %d-%d (would truncate)\n",
348aa9ebccSVladimir Oltean 			       *val, start, end);
358aa9ebccSVladimir Oltean 	}
368aa9ebccSVladimir Oltean 	dump_stack();
378aa9ebccSVladimir Oltean }
388aa9ebccSVladimir Oltean 
sja1105_unpack(const void * buf,u64 * val,int start,int end,size_t len)398aa9ebccSVladimir Oltean void sja1105_unpack(const void *buf, u64 *val, int start, int end, size_t len)
408aa9ebccSVladimir Oltean {
418aa9ebccSVladimir Oltean 	int rc = packing((void *)buf, val, start, end, len,
428aa9ebccSVladimir Oltean 			 UNPACK, QUIRK_LSW32_IS_FIRST);
438aa9ebccSVladimir Oltean 
448aa9ebccSVladimir Oltean 	if (likely(!rc))
458aa9ebccSVladimir Oltean 		return;
468aa9ebccSVladimir Oltean 
478aa9ebccSVladimir Oltean 	if (rc == -EINVAL)
488aa9ebccSVladimir Oltean 		pr_err("Start bit (%d) expected to be larger than end (%d)\n",
498aa9ebccSVladimir Oltean 		       start, end);
508aa9ebccSVladimir Oltean 	else if (rc == -ERANGE)
518aa9ebccSVladimir Oltean 		pr_err("Field %d-%d too large for 64 bits!\n",
528aa9ebccSVladimir Oltean 		       start, end);
538aa9ebccSVladimir Oltean 	dump_stack();
548aa9ebccSVladimir Oltean }
558aa9ebccSVladimir Oltean 
sja1105_packing(void * buf,u64 * val,int start,int end,size_t len,enum packing_op op)568aa9ebccSVladimir Oltean void sja1105_packing(void *buf, u64 *val, int start, int end,
578aa9ebccSVladimir Oltean 		     size_t len, enum packing_op op)
588aa9ebccSVladimir Oltean {
598aa9ebccSVladimir Oltean 	int rc = packing(buf, val, start, end, len, op, QUIRK_LSW32_IS_FIRST);
608aa9ebccSVladimir Oltean 
618aa9ebccSVladimir Oltean 	if (likely(!rc))
628aa9ebccSVladimir Oltean 		return;
638aa9ebccSVladimir Oltean 
648aa9ebccSVladimir Oltean 	if (rc == -EINVAL) {
658aa9ebccSVladimir Oltean 		pr_err("Start bit (%d) expected to be larger than end (%d)\n",
668aa9ebccSVladimir Oltean 		       start, end);
678aa9ebccSVladimir Oltean 	} else if (rc == -ERANGE) {
688aa9ebccSVladimir Oltean 		if ((start - end + 1) > 64)
698aa9ebccSVladimir Oltean 			pr_err("Field %d-%d too large for 64 bits!\n",
708aa9ebccSVladimir Oltean 			       start, end);
718aa9ebccSVladimir Oltean 		else
728aa9ebccSVladimir Oltean 			pr_err("Cannot store %llx inside bits %d-%d (would truncate)\n",
738aa9ebccSVladimir Oltean 			       *val, start, end);
748aa9ebccSVladimir Oltean 	}
758aa9ebccSVladimir Oltean 	dump_stack();
768aa9ebccSVladimir Oltean }
778aa9ebccSVladimir Oltean 
788aa9ebccSVladimir Oltean /* Little-endian Ethernet CRC32 of data packed as big-endian u32 words */
sja1105_crc32(const void * buf,size_t len)798aa9ebccSVladimir Oltean u32 sja1105_crc32(const void *buf, size_t len)
808aa9ebccSVladimir Oltean {
818aa9ebccSVladimir Oltean 	unsigned int i;
828aa9ebccSVladimir Oltean 	u64 word;
838aa9ebccSVladimir Oltean 	u32 crc;
848aa9ebccSVladimir Oltean 
858aa9ebccSVladimir Oltean 	/* seed */
868aa9ebccSVladimir Oltean 	crc = ~0;
878aa9ebccSVladimir Oltean 	for (i = 0; i < len; i += 4) {
88fcd4ba3bSGeert Uytterhoeven 		sja1105_unpack(buf + i, &word, 31, 0, 4);
898aa9ebccSVladimir Oltean 		crc = crc32_le(crc, (u8 *)&word, 4);
908aa9ebccSVladimir Oltean 	}
918aa9ebccSVladimir Oltean 	return ~crc;
928aa9ebccSVladimir Oltean }
938aa9ebccSVladimir Oltean 
sja1105et_avb_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)9424c01949SVladimir Oltean static size_t sja1105et_avb_params_entry_packing(void *buf, void *entry_ptr,
9524c01949SVladimir Oltean 						 enum packing_op op)
9624c01949SVladimir Oltean {
9724c01949SVladimir Oltean 	const size_t size = SJA1105ET_SIZE_AVB_PARAMS_ENTRY;
9824c01949SVladimir Oltean 	struct sja1105_avb_params_entry *entry = entry_ptr;
9924c01949SVladimir Oltean 
10024c01949SVladimir Oltean 	sja1105_packing(buf, &entry->destmeta, 95, 48, size, op);
10124c01949SVladimir Oltean 	sja1105_packing(buf, &entry->srcmeta,  47,  0, size, op);
10224c01949SVladimir Oltean 	return size;
10324c01949SVladimir Oltean }
10424c01949SVladimir Oltean 
sja1105pqrs_avb_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)1050a7e984cSVladimir Oltean size_t sja1105pqrs_avb_params_entry_packing(void *buf, void *entry_ptr,
10624c01949SVladimir Oltean 					    enum packing_op op)
10724c01949SVladimir Oltean {
10824c01949SVladimir Oltean 	const size_t size = SJA1105PQRS_SIZE_AVB_PARAMS_ENTRY;
10924c01949SVladimir Oltean 	struct sja1105_avb_params_entry *entry = entry_ptr;
11024c01949SVladimir Oltean 
111747e5eb3SVladimir Oltean 	sja1105_packing(buf, &entry->cas_master, 126, 126, size, op);
11224c01949SVladimir Oltean 	sja1105_packing(buf, &entry->destmeta,   125,  78, size, op);
11324c01949SVladimir Oltean 	sja1105_packing(buf, &entry->srcmeta,     77,  30, size, op);
11424c01949SVladimir Oltean 	return size;
11524c01949SVladimir Oltean }
11624c01949SVladimir Oltean 
sja1105et_general_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)1178aa9ebccSVladimir Oltean static size_t sja1105et_general_params_entry_packing(void *buf, void *entry_ptr,
1188aa9ebccSVladimir Oltean 						     enum packing_op op)
1198aa9ebccSVladimir Oltean {
1208aa9ebccSVladimir Oltean 	const size_t size = SJA1105ET_SIZE_GENERAL_PARAMS_ENTRY;
1218aa9ebccSVladimir Oltean 	struct sja1105_general_params_entry *entry = entry_ptr;
1228aa9ebccSVladimir Oltean 
1238aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vllupformat, 319, 319, size, op);
1248aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mirr_ptacu,  318, 318, size, op);
1258aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->switchid,    317, 315, size, op);
1268aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->hostprio,    314, 312, size, op);
1278aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_fltres1, 311, 264, size, op);
1288aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_fltres0, 263, 216, size, op);
1298aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_flt1,    215, 168, size, op);
1308aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_flt0,    167, 120, size, op);
1318aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->incl_srcpt1, 119, 119, size, op);
1328aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->incl_srcpt0, 118, 118, size, op);
1338aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->send_meta1,  117, 117, size, op);
1348aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->send_meta0,  116, 116, size, op);
1358aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->casc_port,   115, 113, size, op);
1368aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->host_port,   112, 110, size, op);
1378aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mirr_port,   109, 107, size, op);
1388aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlmarker,    106,  75, size, op);
1398aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlmask,       74,  43, size, op);
1408aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->tpid,         42,  27, size, op);
1418aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ignore2stf,   26,  26, size, op);
1428aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->tpid2,        25,  10, size, op);
1438aa9ebccSVladimir Oltean 	return size;
1448aa9ebccSVladimir Oltean }
1458aa9ebccSVladimir Oltean 
14654fa49eeSVladimir Oltean /* TPID and TPID2 are intentionally reversed so that semantic
14754fa49eeSVladimir Oltean  * compatibility with E/T is kept.
14854fa49eeSVladimir Oltean  */
sja1105pqrs_general_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)14999b981f4SVladimir Oltean size_t sja1105pqrs_general_params_entry_packing(void *buf, void *entry_ptr,
1508aa9ebccSVladimir Oltean 						enum packing_op op)
1518aa9ebccSVladimir Oltean {
1528aa9ebccSVladimir Oltean 	const size_t size = SJA1105PQRS_SIZE_GENERAL_PARAMS_ENTRY;
1538aa9ebccSVladimir Oltean 	struct sja1105_general_params_entry *entry = entry_ptr;
1548aa9ebccSVladimir Oltean 
1558aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vllupformat, 351, 351, size, op);
1568aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mirr_ptacu,  350, 350, size, op);
1578aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->switchid,    349, 347, size, op);
1588aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->hostprio,    346, 344, size, op);
1598aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_fltres1, 343, 296, size, op);
1608aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_fltres0, 295, 248, size, op);
1618aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_flt1,    247, 200, size, op);
1628aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mac_flt0,    199, 152, size, op);
1638aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->incl_srcpt1, 151, 151, size, op);
1648aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->incl_srcpt0, 150, 150, size, op);
1658aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->send_meta1,  149, 149, size, op);
1668aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->send_meta0,  148, 148, size, op);
1678aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->casc_port,   147, 145, size, op);
1688aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->host_port,   144, 142, size, op);
1698aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->mirr_port,   141, 139, size, op);
1708aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlmarker,    138, 107, size, op);
1718aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlmask,      106,  75, size, op);
17254fa49eeSVladimir Oltean 	sja1105_packing(buf, &entry->tpid2,        74,  59, size, op);
1738aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ignore2stf,   58,  58, size, op);
17454fa49eeSVladimir Oltean 	sja1105_packing(buf, &entry->tpid,         57,  42, size, op);
1758aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->queue_ts,     41,  41, size, op);
1768aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->egrmirrvid,   40,  29, size, op);
1778aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->egrmirrpcp,   28,  26, size, op);
1788aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->egrmirrdei,   25,  25, size, op);
1798aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->replay_port,  24,  22, size, op);
1808aa9ebccSVladimir Oltean 	return size;
1818aa9ebccSVladimir Oltean }
1828aa9ebccSVladimir Oltean 
sja1110_general_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)1833e77e59bSVladimir Oltean size_t sja1110_general_params_entry_packing(void *buf, void *entry_ptr,
1843e77e59bSVladimir Oltean 					    enum packing_op op)
1853e77e59bSVladimir Oltean {
1863e77e59bSVladimir Oltean 	struct sja1105_general_params_entry *entry = entry_ptr;
1873e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_GENERAL_PARAMS_ENTRY;
1883e77e59bSVladimir Oltean 
1893e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vllupformat,  447, 447, size, op);
1903e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mirr_ptacu,   446, 446, size, op);
1913e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->switchid,     445, 442, size, op);
1923e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->hostprio,     441, 439, size, op);
1933e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mac_fltres1,  438, 391, size, op);
1943e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mac_fltres0,  390, 343, size, op);
1953e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mac_flt1,     342, 295, size, op);
1963e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mac_flt0,     294, 247, size, op);
1973e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->incl_srcpt1,  246, 246, size, op);
1983e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->incl_srcpt0,  245, 245, size, op);
1993e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->send_meta1,   244, 244, size, op);
2003e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->send_meta0,   243, 243, size, op);
2013e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->casc_port,    242, 232, size, op);
2023e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->host_port,    231, 228, size, op);
2033e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mirr_port,    227, 224, size, op);
2043e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlmarker,     223, 192, size, op);
2053e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlmask,       191, 160, size, op);
2063e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->tpid2,        159, 144, size, op);
2073e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->ignore2stf,   143, 143, size, op);
2083e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->tpid,         142, 127, size, op);
2093e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->queue_ts,     126, 126, size, op);
2103e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->egrmirrvid,   125, 114, size, op);
2113e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->egrmirrpcp,   113, 111, size, op);
2123e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->egrmirrdei,   110, 110, size, op);
2133e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->replay_port,  109, 106, size, op);
214ceec8bc0SVladimir Oltean 	sja1105_packing(buf, &entry->tdmaconfigidx, 70,  67, size, op);
2154913b8ebSVladimir Oltean 	sja1105_packing(buf, &entry->header_type,   64,  49, size, op);
2163e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->tte_en,        16,  16, size, op);
2173e77e59bSVladimir Oltean 	return size;
2183e77e59bSVladimir Oltean }
2193e77e59bSVladimir Oltean 
2208aa9ebccSVladimir Oltean static size_t
sja1105_l2_forwarding_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)2218aa9ebccSVladimir Oltean sja1105_l2_forwarding_params_entry_packing(void *buf, void *entry_ptr,
2228aa9ebccSVladimir Oltean 					   enum packing_op op)
2238aa9ebccSVladimir Oltean {
2248aa9ebccSVladimir Oltean 	const size_t size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY;
2258aa9ebccSVladimir Oltean 	struct sja1105_l2_forwarding_params_entry *entry = entry_ptr;
2268aa9ebccSVladimir Oltean 	int offset, i;
2278aa9ebccSVladimir Oltean 
2288aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->max_dynp, 95, 93, size, op);
2298aa9ebccSVladimir Oltean 	for (i = 0, offset = 13; i < 8; i++, offset += 10)
2308aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->part_spc[i],
2318aa9ebccSVladimir Oltean 				offset + 9, offset + 0, size, op);
2328aa9ebccSVladimir Oltean 	return size;
2338aa9ebccSVladimir Oltean }
2348aa9ebccSVladimir Oltean 
sja1110_l2_forwarding_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)2353e77e59bSVladimir Oltean size_t sja1110_l2_forwarding_params_entry_packing(void *buf, void *entry_ptr,
2363e77e59bSVladimir Oltean 						  enum packing_op op)
2373e77e59bSVladimir Oltean {
2383e77e59bSVladimir Oltean 	struct sja1105_l2_forwarding_params_entry *entry = entry_ptr;
2393e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY;
2403e77e59bSVladimir Oltean 	int offset, i;
2413e77e59bSVladimir Oltean 
2423e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->max_dynp, 95, 93, size, op);
2433e77e59bSVladimir Oltean 	for (i = 0, offset = 5; i < 8; i++, offset += 11)
2443e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->part_spc[i],
2453e77e59bSVladimir Oltean 				offset + 10, offset + 0, size, op);
2463e77e59bSVladimir Oltean 	return size;
2473e77e59bSVladimir Oltean }
2483e77e59bSVladimir Oltean 
sja1105_l2_forwarding_entry_packing(void * buf,void * entry_ptr,enum packing_op op)2498aa9ebccSVladimir Oltean size_t sja1105_l2_forwarding_entry_packing(void *buf, void *entry_ptr,
2508aa9ebccSVladimir Oltean 					   enum packing_op op)
2518aa9ebccSVladimir Oltean {
2528aa9ebccSVladimir Oltean 	const size_t size = SJA1105_SIZE_L2_FORWARDING_ENTRY;
2538aa9ebccSVladimir Oltean 	struct sja1105_l2_forwarding_entry *entry = entry_ptr;
2548aa9ebccSVladimir Oltean 	int offset, i;
2558aa9ebccSVladimir Oltean 
2568aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->bc_domain,  63, 59, size, op);
2578aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->reach_port, 58, 54, size, op);
2588aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->fl_domain,  53, 49, size, op);
2598aa9ebccSVladimir Oltean 	for (i = 0, offset = 25; i < 8; i++, offset += 3)
2608aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->vlan_pmap[i],
2618aa9ebccSVladimir Oltean 				offset + 2, offset + 0, size, op);
2628aa9ebccSVladimir Oltean 	return size;
2638aa9ebccSVladimir Oltean }
2648aa9ebccSVladimir Oltean 
sja1110_l2_forwarding_entry_packing(void * buf,void * entry_ptr,enum packing_op op)2653e77e59bSVladimir Oltean size_t sja1110_l2_forwarding_entry_packing(void *buf, void *entry_ptr,
2663e77e59bSVladimir Oltean 					   enum packing_op op)
2673e77e59bSVladimir Oltean {
2683e77e59bSVladimir Oltean 	struct sja1105_l2_forwarding_entry *entry = entry_ptr;
2693e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_L2_FORWARDING_ENTRY;
2703e77e59bSVladimir Oltean 	int offset, i;
2713e77e59bSVladimir Oltean 
2723e77e59bSVladimir Oltean 	if (entry->type_egrpcp2outputq) {
2733e77e59bSVladimir Oltean 		for (i = 0, offset = 31; i < SJA1110_NUM_PORTS;
2743e77e59bSVladimir Oltean 		     i++, offset += 3) {
2753e77e59bSVladimir Oltean 			sja1105_packing(buf, &entry->vlan_pmap[i],
2763e77e59bSVladimir Oltean 					offset + 2, offset + 0, size, op);
2773e77e59bSVladimir Oltean 		}
2783e77e59bSVladimir Oltean 	} else {
2793e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->bc_domain,  63, 53, size, op);
2803e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->reach_port, 52, 42, size, op);
2813e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->fl_domain,  41, 31, size, op);
2823e77e59bSVladimir Oltean 	}
2833e77e59bSVladimir Oltean 	return size;
2843e77e59bSVladimir Oltean }
2853e77e59bSVladimir Oltean 
2868aa9ebccSVladimir Oltean static size_t
sja1105et_l2_lookup_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)2878aa9ebccSVladimir Oltean sja1105et_l2_lookup_params_entry_packing(void *buf, void *entry_ptr,
2888aa9ebccSVladimir Oltean 					 enum packing_op op)
2898aa9ebccSVladimir Oltean {
2908aa9ebccSVladimir Oltean 	const size_t size = SJA1105ET_SIZE_L2_LOOKUP_PARAMS_ENTRY;
2918aa9ebccSVladimir Oltean 	struct sja1105_l2_lookup_params_entry *entry = entry_ptr;
2928aa9ebccSVladimir Oltean 
2938aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->maxage,         31, 17, size, op);
2948aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->dyn_tbsz,       16, 14, size, op);
2958aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->poly,           13,  6, size, op);
2968aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->shared_learn,    5,  5, size, op);
2978aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->no_enf_hostprt,  4,  4, size, op);
2988aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->no_mgmt_learn,   3,  3, size, op);
2998aa9ebccSVladimir Oltean 	return size;
3008aa9ebccSVladimir Oltean }
3018aa9ebccSVladimir Oltean 
sja1105pqrs_l2_lookup_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)30299b981f4SVladimir Oltean size_t sja1105pqrs_l2_lookup_params_entry_packing(void *buf, void *entry_ptr,
3038aa9ebccSVladimir Oltean 						  enum packing_op op)
3048aa9ebccSVladimir Oltean {
3058aa9ebccSVladimir Oltean 	const size_t size = SJA1105PQRS_SIZE_L2_LOOKUP_PARAMS_ENTRY;
3068aa9ebccSVladimir Oltean 	struct sja1105_l2_lookup_params_entry *entry = entry_ptr;
3076c56e167SVladimir Oltean 	int offset, i;
3088aa9ebccSVladimir Oltean 
3096c56e167SVladimir Oltean 	for (i = 0, offset = 58; i < 5; i++, offset += 11)
3106c56e167SVladimir Oltean 		sja1105_packing(buf, &entry->maxaddrp[i],
3116c56e167SVladimir Oltean 				offset + 10, offset + 0, size, op);
3128aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->maxage,         57,  43, size, op);
3130803948eSVladimir Oltean 	sja1105_packing(buf, &entry->start_dynspc,   42,  33, size, op);
3140803948eSVladimir Oltean 	sja1105_packing(buf, &entry->drpnolearn,     32,  28, size, op);
3158aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->shared_learn,   27,  27, size, op);
3168aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->no_enf_hostprt, 26,  26, size, op);
3178aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->no_mgmt_learn,  25,  25, size, op);
3180803948eSVladimir Oltean 	sja1105_packing(buf, &entry->use_static,     24,  24, size, op);
3190803948eSVladimir Oltean 	sja1105_packing(buf, &entry->owr_dyn,        23,  23, size, op);
3200803948eSVladimir Oltean 	sja1105_packing(buf, &entry->learn_once,     22,  22, size, op);
3218aa9ebccSVladimir Oltean 	return size;
3228aa9ebccSVladimir Oltean }
3238aa9ebccSVladimir Oltean 
sja1110_l2_lookup_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)3243e77e59bSVladimir Oltean size_t sja1110_l2_lookup_params_entry_packing(void *buf, void *entry_ptr,
3253e77e59bSVladimir Oltean 					      enum packing_op op)
3263e77e59bSVladimir Oltean {
3273e77e59bSVladimir Oltean 	struct sja1105_l2_lookup_params_entry *entry = entry_ptr;
3283e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_L2_LOOKUP_PARAMS_ENTRY;
3293e77e59bSVladimir Oltean 	int offset, i;
3303e77e59bSVladimir Oltean 
3313e77e59bSVladimir Oltean 	for (i = 0, offset = 70; i < SJA1110_NUM_PORTS; i++, offset += 11)
3323e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->maxaddrp[i],
3333e77e59bSVladimir Oltean 				offset + 10, offset + 0, size, op);
3343e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->maxage,         69,  55, size, op);
3353e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->start_dynspc,   54,  45, size, op);
3363e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->drpnolearn,     44,  34, size, op);
3373e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->shared_learn,   33,  33, size, op);
3383e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->no_enf_hostprt, 32,  32, size, op);
3393e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->no_mgmt_learn,  31,  31, size, op);
3403e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->use_static,     30,  30, size, op);
3413e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->owr_dyn,        29,  29, size, op);
3423e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->learn_once,     28,  28, size, op);
3433e77e59bSVladimir Oltean 	return size;
3443e77e59bSVladimir Oltean }
3453e77e59bSVladimir Oltean 
sja1105et_l2_lookup_entry_packing(void * buf,void * entry_ptr,enum packing_op op)3468aa9ebccSVladimir Oltean size_t sja1105et_l2_lookup_entry_packing(void *buf, void *entry_ptr,
3478aa9ebccSVladimir Oltean 					 enum packing_op op)
3488aa9ebccSVladimir Oltean {
3498aa9ebccSVladimir Oltean 	const size_t size = SJA1105ET_SIZE_L2_LOOKUP_ENTRY;
3508aa9ebccSVladimir Oltean 	struct sja1105_l2_lookup_entry *entry = entry_ptr;
3518aa9ebccSVladimir Oltean 
3528aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,    95, 84, size, op);
3538aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->macaddr,   83, 36, size, op);
3548aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->destports, 35, 31, size, op);
3558aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->enfport,   30, 30, size, op);
3568aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->index,     29, 20, size, op);
3578aa9ebccSVladimir Oltean 	return size;
3588aa9ebccSVladimir Oltean }
3598aa9ebccSVladimir Oltean 
sja1105pqrs_l2_lookup_entry_packing(void * buf,void * entry_ptr,enum packing_op op)3608aa9ebccSVladimir Oltean size_t sja1105pqrs_l2_lookup_entry_packing(void *buf, void *entry_ptr,
3618aa9ebccSVladimir Oltean 					   enum packing_op op)
3628aa9ebccSVladimir Oltean {
3638aa9ebccSVladimir Oltean 	const size_t size = SJA1105PQRS_SIZE_L2_LOOKUP_ENTRY;
3648aa9ebccSVladimir Oltean 	struct sja1105_l2_lookup_entry *entry = entry_ptr;
3658aa9ebccSVladimir Oltean 
3669c5098d9SVladimir Oltean 	if (entry->lockeds) {
3679c5098d9SVladimir Oltean 		sja1105_packing(buf, &entry->tsreg,    159, 159, size, op);
3689c5098d9SVladimir Oltean 		sja1105_packing(buf, &entry->mirrvlan, 158, 147, size, op);
3699c5098d9SVladimir Oltean 		sja1105_packing(buf, &entry->takets,   146, 146, size, op);
3709c5098d9SVladimir Oltean 		sja1105_packing(buf, &entry->mirr,     145, 145, size, op);
3719c5098d9SVladimir Oltean 		sja1105_packing(buf, &entry->retag,    144, 144, size, op);
3729c5098d9SVladimir Oltean 	} else {
3739c5098d9SVladimir Oltean 		sja1105_packing(buf, &entry->touched,  159, 159, size, op);
3749c5098d9SVladimir Oltean 		sja1105_packing(buf, &entry->age,      158, 144, size, op);
3759c5098d9SVladimir Oltean 	}
3769c5098d9SVladimir Oltean 	sja1105_packing(buf, &entry->mask_iotag,   143, 143, size, op);
3779c5098d9SVladimir Oltean 	sja1105_packing(buf, &entry->mask_vlanid,  142, 131, size, op);
3789c5098d9SVladimir Oltean 	sja1105_packing(buf, &entry->mask_macaddr, 130,  83, size, op);
3799c5098d9SVladimir Oltean 	sja1105_packing(buf, &entry->iotag,         82,  82, size, op);
3808aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,        81,  70, size, op);
3818aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->macaddr,       69,  22, size, op);
3828aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->destports,     21,  17, size, op);
3838aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->enfport,       16,  16, size, op);
3848aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->index,         15,   6, size, op);
3858aa9ebccSVladimir Oltean 	return size;
3868aa9ebccSVladimir Oltean }
3878aa9ebccSVladimir Oltean 
sja1110_l2_lookup_entry_packing(void * buf,void * entry_ptr,enum packing_op op)3883e77e59bSVladimir Oltean size_t sja1110_l2_lookup_entry_packing(void *buf, void *entry_ptr,
3893e77e59bSVladimir Oltean 				       enum packing_op op)
3903e77e59bSVladimir Oltean {
3913e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_L2_LOOKUP_ENTRY;
3923e77e59bSVladimir Oltean 	struct sja1105_l2_lookup_entry *entry = entry_ptr;
3933e77e59bSVladimir Oltean 
3943e77e59bSVladimir Oltean 	if (entry->lockeds) {
3953e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->trap,     168, 168, size, op);
3963e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->mirrvlan, 167, 156, size, op);
3973e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->takets,   155, 155, size, op);
3983e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->mirr,     154, 154, size, op);
3993e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->retag,    153, 153, size, op);
4003e77e59bSVladimir Oltean 	} else {
4013e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->touched,  168, 168, size, op);
4023e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->age,      167, 153, size, op);
4033e77e59bSVladimir Oltean 	}
4043e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mask_iotag,   152, 152, size, op);
4053e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mask_vlanid,  151, 140, size, op);
4063e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mask_macaddr, 139,  92, size, op);
4073e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->mask_srcport,  91,  88, size, op);
4083e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->iotag,         87,  87, size, op);
4093e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,        86,  75, size, op);
4103e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->macaddr,       74,  27, size, op);
4113e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->srcport,       26,  23, size, op);
4123e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->destports,     22,  12, size, op);
4133e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->enfport,       11,  11, size, op);
4143e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->index,         10,   1, size, op);
4153e77e59bSVladimir Oltean 	return size;
4163e77e59bSVladimir Oltean }
4173e77e59bSVladimir Oltean 
sja1105_l2_policing_entry_packing(void * buf,void * entry_ptr,enum packing_op op)4188aa9ebccSVladimir Oltean static size_t sja1105_l2_policing_entry_packing(void *buf, void *entry_ptr,
4198aa9ebccSVladimir Oltean 						enum packing_op op)
4208aa9ebccSVladimir Oltean {
4218aa9ebccSVladimir Oltean 	const size_t size = SJA1105_SIZE_L2_POLICING_ENTRY;
4228aa9ebccSVladimir Oltean 	struct sja1105_l2_policing_entry *entry = entry_ptr;
4238aa9ebccSVladimir Oltean 
4248aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->sharindx,  63, 58, size, op);
4258aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->smax,      57, 42, size, op);
4268aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->rate,      41, 26, size, op);
4278aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->maxlen,    25, 15, size, op);
4288aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->partition, 14, 12, size, op);
4298aa9ebccSVladimir Oltean 	return size;
4308aa9ebccSVladimir Oltean }
4318aa9ebccSVladimir Oltean 
sja1110_l2_policing_entry_packing(void * buf,void * entry_ptr,enum packing_op op)4323e77e59bSVladimir Oltean size_t sja1110_l2_policing_entry_packing(void *buf, void *entry_ptr,
4333e77e59bSVladimir Oltean 					 enum packing_op op)
4343e77e59bSVladimir Oltean {
4353e77e59bSVladimir Oltean 	struct sja1105_l2_policing_entry *entry = entry_ptr;
4363e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_L2_POLICING_ENTRY;
4373e77e59bSVladimir Oltean 
4383e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->sharindx, 63, 57, size, op);
4393e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->smax,     56, 39, size, op);
4403e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->rate,     38, 21, size, op);
4413e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->maxlen,   20, 10, size, op);
4423e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->partition, 9,  7, size, op);
4433e77e59bSVladimir Oltean 	return size;
4443e77e59bSVladimir Oltean }
4453e77e59bSVladimir Oltean 
sja1105et_mac_config_entry_packing(void * buf,void * entry_ptr,enum packing_op op)4468aa9ebccSVladimir Oltean static size_t sja1105et_mac_config_entry_packing(void *buf, void *entry_ptr,
4478aa9ebccSVladimir Oltean 						 enum packing_op op)
4488aa9ebccSVladimir Oltean {
4498aa9ebccSVladimir Oltean 	const size_t size = SJA1105ET_SIZE_MAC_CONFIG_ENTRY;
4508aa9ebccSVladimir Oltean 	struct sja1105_mac_config_entry *entry = entry_ptr;
4518aa9ebccSVladimir Oltean 	int offset, i;
4528aa9ebccSVladimir Oltean 
4538aa9ebccSVladimir Oltean 	for (i = 0, offset = 72; i < 8; i++, offset += 19) {
4548aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->enabled[i],
4558aa9ebccSVladimir Oltean 				offset +  0, offset +  0, size, op);
4568aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->base[i],
4578aa9ebccSVladimir Oltean 				offset +  9, offset +  1, size, op);
4588aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->top[i],
4598aa9ebccSVladimir Oltean 				offset + 18, offset + 10, size, op);
4608aa9ebccSVladimir Oltean 	}
4618aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ifg,       71, 67, size, op);
4628aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->speed,     66, 65, size, op);
4638aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->tp_delin,  64, 49, size, op);
4648aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->tp_delout, 48, 33, size, op);
4658aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->maxage,    32, 25, size, op);
4668aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlanprio,  24, 22, size, op);
4678aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,    21, 10, size, op);
4688aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ing_mirr,   9,  9, size, op);
4698aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->egr_mirr,   8,  8, size, op);
4708aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->drpnona664, 7,  7, size, op);
4718aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->drpdtag,    6,  6, size, op);
4728aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->drpuntag,   5,  5, size, op);
4738aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->retag,      4,  4, size, op);
4748aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->dyn_learn,  3,  3, size, op);
4758aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->egress,     2,  2, size, op);
4768aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ingress,    1,  1, size, op);
4778aa9ebccSVladimir Oltean 	return size;
4788aa9ebccSVladimir Oltean }
4798aa9ebccSVladimir Oltean 
sja1105pqrs_mac_config_entry_packing(void * buf,void * entry_ptr,enum packing_op op)4808aa9ebccSVladimir Oltean size_t sja1105pqrs_mac_config_entry_packing(void *buf, void *entry_ptr,
4818aa9ebccSVladimir Oltean 					    enum packing_op op)
4828aa9ebccSVladimir Oltean {
4838aa9ebccSVladimir Oltean 	const size_t size = SJA1105PQRS_SIZE_MAC_CONFIG_ENTRY;
4848aa9ebccSVladimir Oltean 	struct sja1105_mac_config_entry *entry = entry_ptr;
4858aa9ebccSVladimir Oltean 	int offset, i;
4868aa9ebccSVladimir Oltean 
4878aa9ebccSVladimir Oltean 	for (i = 0, offset = 104; i < 8; i++, offset += 19) {
4888aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->enabled[i],
4898aa9ebccSVladimir Oltean 				offset +  0, offset +  0, size, op);
4908aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->base[i],
4918aa9ebccSVladimir Oltean 				offset +  9, offset +  1, size, op);
4928aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->top[i],
4938aa9ebccSVladimir Oltean 				offset + 18, offset + 10, size, op);
4948aa9ebccSVladimir Oltean 	}
4958aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ifg,       103, 99, size, op);
4968aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->speed,      98, 97, size, op);
4978aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->tp_delin,   96, 81, size, op);
4988aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->tp_delout,  80, 65, size, op);
4998aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->maxage,     64, 57, size, op);
5008aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlanprio,   56, 54, size, op);
5018aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,     53, 42, size, op);
5028aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ing_mirr,   41, 41, size, op);
5038aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->egr_mirr,   40, 40, size, op);
5048aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->drpnona664, 39, 39, size, op);
5058aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->drpdtag,    38, 38, size, op);
5068aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->drpuntag,   35, 35, size, op);
5078aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->retag,      34, 34, size, op);
5088aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->dyn_learn,  33, 33, size, op);
5098aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->egress,     32, 32, size, op);
5108aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ingress,    31, 31, size, op);
5118aa9ebccSVladimir Oltean 	return size;
5128aa9ebccSVladimir Oltean }
5138aa9ebccSVladimir Oltean 
sja1110_mac_config_entry_packing(void * buf,void * entry_ptr,enum packing_op op)5143e77e59bSVladimir Oltean size_t sja1110_mac_config_entry_packing(void *buf, void *entry_ptr,
5153e77e59bSVladimir Oltean 					enum packing_op op)
5163e77e59bSVladimir Oltean {
5173e77e59bSVladimir Oltean 	const size_t size = SJA1105PQRS_SIZE_MAC_CONFIG_ENTRY;
5183e77e59bSVladimir Oltean 	struct sja1105_mac_config_entry *entry = entry_ptr;
5193e77e59bSVladimir Oltean 	int offset, i;
5203e77e59bSVladimir Oltean 
5213e77e59bSVladimir Oltean 	for (i = 0, offset = 104; i < 8; i++, offset += 19) {
5223e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->enabled[i],
5233e77e59bSVladimir Oltean 				offset +  0, offset +  0, size, op);
5243e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->base[i],
5253e77e59bSVladimir Oltean 				offset +  9, offset +  1, size, op);
5263e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->top[i],
5273e77e59bSVladimir Oltean 				offset + 18, offset + 10, size, op);
5283e77e59bSVladimir Oltean 	}
5293e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->speed,      98, 96, size, op);
5303e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->tp_delin,   95, 80, size, op);
5313e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->tp_delout,  79, 64, size, op);
5323e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->maxage,     63, 56, size, op);
5333e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlanprio,   55, 53, size, op);
5343e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,     52, 41, size, op);
5353e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->ing_mirr,   40, 40, size, op);
5363e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->egr_mirr,   39, 39, size, op);
5373e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->drpnona664, 38, 38, size, op);
5383e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->drpdtag,    37, 37, size, op);
5393e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->drpuntag,   34, 34, size, op);
5403e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->retag,      33, 33, size, op);
5413e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->dyn_learn,  32, 32, size, op);
5423e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->egress,     31, 31, size, op);
5433e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->ingress,    30, 30, size, op);
5443e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->ifg,        10,  5, size, op);
5453e77e59bSVladimir Oltean 	return size;
5463e77e59bSVladimir Oltean }
5473e77e59bSVladimir Oltean 
5487f1e4ba8SVladimir Oltean static size_t
sja1105_schedule_entry_points_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)5497f1e4ba8SVladimir Oltean sja1105_schedule_entry_points_params_entry_packing(void *buf, void *entry_ptr,
5507f1e4ba8SVladimir Oltean 						   enum packing_op op)
5517f1e4ba8SVladimir Oltean {
5527f1e4ba8SVladimir Oltean 	struct sja1105_schedule_entry_points_params_entry *entry = entry_ptr;
5537f1e4ba8SVladimir Oltean 	const size_t size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_PARAMS_ENTRY;
5547f1e4ba8SVladimir Oltean 
5557f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->clksrc,    31, 30, size, op);
5567f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->actsubsch, 29, 27, size, op);
5577f1e4ba8SVladimir Oltean 	return size;
5587f1e4ba8SVladimir Oltean }
5597f1e4ba8SVladimir Oltean 
5607f1e4ba8SVladimir Oltean static size_t
sja1105_schedule_entry_points_entry_packing(void * buf,void * entry_ptr,enum packing_op op)5617f1e4ba8SVladimir Oltean sja1105_schedule_entry_points_entry_packing(void *buf, void *entry_ptr,
5627f1e4ba8SVladimir Oltean 					    enum packing_op op)
5637f1e4ba8SVladimir Oltean {
5647f1e4ba8SVladimir Oltean 	struct sja1105_schedule_entry_points_entry *entry = entry_ptr;
5657f1e4ba8SVladimir Oltean 	const size_t size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_ENTRY;
5667f1e4ba8SVladimir Oltean 
5677f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->subschindx, 31, 29, size, op);
5687f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->delta,      28, 11, size, op);
5697f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->address,    10, 1,  size, op);
5707f1e4ba8SVladimir Oltean 	return size;
5717f1e4ba8SVladimir Oltean }
5727f1e4ba8SVladimir Oltean 
5733e77e59bSVladimir Oltean static size_t
sja1110_schedule_entry_points_entry_packing(void * buf,void * entry_ptr,enum packing_op op)5743e77e59bSVladimir Oltean sja1110_schedule_entry_points_entry_packing(void *buf, void *entry_ptr,
5753e77e59bSVladimir Oltean 					    enum packing_op op)
5763e77e59bSVladimir Oltean {
5773e77e59bSVladimir Oltean 	struct sja1105_schedule_entry_points_entry *entry = entry_ptr;
5783e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_SCHEDULE_ENTRY_POINTS_ENTRY;
5793e77e59bSVladimir Oltean 
5803e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->subschindx, 63, 61, size, op);
5813e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->delta,      60, 43, size, op);
5823e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->address,    42, 31, size, op);
5833e77e59bSVladimir Oltean 	return size;
5843e77e59bSVladimir Oltean }
5853e77e59bSVladimir Oltean 
sja1105_schedule_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)5867f1e4ba8SVladimir Oltean static size_t sja1105_schedule_params_entry_packing(void *buf, void *entry_ptr,
5877f1e4ba8SVladimir Oltean 						    enum packing_op op)
5887f1e4ba8SVladimir Oltean {
5897f1e4ba8SVladimir Oltean 	const size_t size = SJA1105_SIZE_SCHEDULE_PARAMS_ENTRY;
5907f1e4ba8SVladimir Oltean 	struct sja1105_schedule_params_entry *entry = entry_ptr;
5917f1e4ba8SVladimir Oltean 	int offset, i;
5927f1e4ba8SVladimir Oltean 
5937f1e4ba8SVladimir Oltean 	for (i = 0, offset = 16; i < 8; i++, offset += 10)
5947f1e4ba8SVladimir Oltean 		sja1105_packing(buf, &entry->subscheind[i],
5957f1e4ba8SVladimir Oltean 				offset + 9, offset + 0, size, op);
5967f1e4ba8SVladimir Oltean 	return size;
5977f1e4ba8SVladimir Oltean }
5987f1e4ba8SVladimir Oltean 
sja1110_schedule_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)5993e77e59bSVladimir Oltean static size_t sja1110_schedule_params_entry_packing(void *buf, void *entry_ptr,
6003e77e59bSVladimir Oltean 						    enum packing_op op)
6013e77e59bSVladimir Oltean {
6023e77e59bSVladimir Oltean 	struct sja1105_schedule_params_entry *entry = entry_ptr;
6033e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_SCHEDULE_PARAMS_ENTRY;
6043e77e59bSVladimir Oltean 	int offset, i;
6053e77e59bSVladimir Oltean 
6063e77e59bSVladimir Oltean 	for (i = 0, offset = 0; i < 8; i++, offset += 12)
6073e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->subscheind[i],
6083e77e59bSVladimir Oltean 				offset + 11, offset + 0, size, op);
6093e77e59bSVladimir Oltean 	return size;
6103e77e59bSVladimir Oltean }
6113e77e59bSVladimir Oltean 
sja1105_schedule_entry_packing(void * buf,void * entry_ptr,enum packing_op op)6127f1e4ba8SVladimir Oltean static size_t sja1105_schedule_entry_packing(void *buf, void *entry_ptr,
6137f1e4ba8SVladimir Oltean 					     enum packing_op op)
6147f1e4ba8SVladimir Oltean {
6157f1e4ba8SVladimir Oltean 	const size_t size = SJA1105_SIZE_SCHEDULE_ENTRY;
6167f1e4ba8SVladimir Oltean 	struct sja1105_schedule_entry *entry = entry_ptr;
6177f1e4ba8SVladimir Oltean 
6187f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->winstindex,  63, 54, size, op);
6197f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->winend,      53, 53, size, op);
6207f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->winst,       52, 52, size, op);
6217f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->destports,   51, 47, size, op);
6227f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->setvalid,    46, 46, size, op);
6237f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->txen,        45, 45, size, op);
6247f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->resmedia_en, 44, 44, size, op);
6257f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->resmedia,    43, 36, size, op);
6267f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->vlindex,     35, 26, size, op);
6277f1e4ba8SVladimir Oltean 	sja1105_packing(buf, &entry->delta,       25, 8,  size, op);
6287f1e4ba8SVladimir Oltean 	return size;
6297f1e4ba8SVladimir Oltean }
6307f1e4ba8SVladimir Oltean 
sja1110_schedule_entry_packing(void * buf,void * entry_ptr,enum packing_op op)6313e77e59bSVladimir Oltean static size_t sja1110_schedule_entry_packing(void *buf, void *entry_ptr,
6323e77e59bSVladimir Oltean 					     enum packing_op op)
6333e77e59bSVladimir Oltean {
6343e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_SCHEDULE_ENTRY;
6353e77e59bSVladimir Oltean 	struct sja1105_schedule_entry *entry = entry_ptr;
6363e77e59bSVladimir Oltean 
6373e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->winstindex,  95, 84, size, op);
6383e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->winend,      83, 83, size, op);
6393e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->winst,       82, 82, size, op);
6403e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->destports,   81, 71, size, op);
6413e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->setvalid,    70, 70, size, op);
6423e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->txen,        69, 69, size, op);
6433e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->resmedia_en, 68, 68, size, op);
6443e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->resmedia,    67, 60, size, op);
6453e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlindex,     59, 48, size, op);
6463e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->delta,       47, 30, size, op);
6473e77e59bSVladimir Oltean 	return size;
6483e77e59bSVladimir Oltean }
6493e77e59bSVladimir Oltean 
65094f94d4aSVladimir Oltean static size_t
sja1105_vl_forwarding_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)65194f94d4aSVladimir Oltean sja1105_vl_forwarding_params_entry_packing(void *buf, void *entry_ptr,
65294f94d4aSVladimir Oltean 					   enum packing_op op)
65394f94d4aSVladimir Oltean {
65494f94d4aSVladimir Oltean 	struct sja1105_vl_forwarding_params_entry *entry = entry_ptr;
65594f94d4aSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_FORWARDING_PARAMS_ENTRY;
65694f94d4aSVladimir Oltean 	int offset, i;
65794f94d4aSVladimir Oltean 
65894f94d4aSVladimir Oltean 	for (i = 0, offset = 16; i < 8; i++, offset += 10)
65994f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->partspc[i],
66094f94d4aSVladimir Oltean 				offset + 9, offset + 0, size, op);
66194f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->debugen, 15, 15, size, op);
66294f94d4aSVladimir Oltean 	return size;
66394f94d4aSVladimir Oltean }
66494f94d4aSVladimir Oltean 
6653e77e59bSVladimir Oltean static size_t
sja1110_vl_forwarding_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)6663e77e59bSVladimir Oltean sja1110_vl_forwarding_params_entry_packing(void *buf, void *entry_ptr,
6673e77e59bSVladimir Oltean 					   enum packing_op op)
6683e77e59bSVladimir Oltean {
6693e77e59bSVladimir Oltean 	struct sja1105_vl_forwarding_params_entry *entry = entry_ptr;
6703e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_FORWARDING_PARAMS_ENTRY;
6713e77e59bSVladimir Oltean 	int offset, i;
6723e77e59bSVladimir Oltean 
6733e77e59bSVladimir Oltean 	for (i = 0, offset = 8; i < 8; i++, offset += 11)
6743e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->partspc[i],
6753e77e59bSVladimir Oltean 				offset + 10, offset + 0, size, op);
6763e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->debugen, 7, 7, size, op);
6773e77e59bSVladimir Oltean 	return size;
6783e77e59bSVladimir Oltean }
6793e77e59bSVladimir Oltean 
sja1105_vl_forwarding_entry_packing(void * buf,void * entry_ptr,enum packing_op op)68094f94d4aSVladimir Oltean static size_t sja1105_vl_forwarding_entry_packing(void *buf, void *entry_ptr,
68194f94d4aSVladimir Oltean 						  enum packing_op op)
68294f94d4aSVladimir Oltean {
68394f94d4aSVladimir Oltean 	struct sja1105_vl_forwarding_entry *entry = entry_ptr;
68494f94d4aSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_FORWARDING_ENTRY;
68594f94d4aSVladimir Oltean 
68694f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->type,      31, 31, size, op);
68794f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->priority,  30, 28, size, op);
68894f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->partition, 27, 25, size, op);
68994f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->destports, 24, 20, size, op);
69094f94d4aSVladimir Oltean 	return size;
69194f94d4aSVladimir Oltean }
69294f94d4aSVladimir Oltean 
sja1110_vl_forwarding_entry_packing(void * buf,void * entry_ptr,enum packing_op op)6933e77e59bSVladimir Oltean static size_t sja1110_vl_forwarding_entry_packing(void *buf, void *entry_ptr,
6943e77e59bSVladimir Oltean 						  enum packing_op op)
6953e77e59bSVladimir Oltean {
6963e77e59bSVladimir Oltean 	struct sja1105_vl_forwarding_entry *entry = entry_ptr;
6973e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_FORWARDING_ENTRY;
6983e77e59bSVladimir Oltean 
6993e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->type,      31, 31, size, op);
7003e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->priority,  30, 28, size, op);
7013e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->partition, 27, 25, size, op);
7023e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->destports, 24, 14, size, op);
7033e77e59bSVladimir Oltean 	return size;
7043e77e59bSVladimir Oltean }
7053e77e59bSVladimir Oltean 
sja1105_vl_lookup_entry_packing(void * buf,void * entry_ptr,enum packing_op op)70694f94d4aSVladimir Oltean size_t sja1105_vl_lookup_entry_packing(void *buf, void *entry_ptr,
70794f94d4aSVladimir Oltean 				       enum packing_op op)
70894f94d4aSVladimir Oltean {
70994f94d4aSVladimir Oltean 	struct sja1105_vl_lookup_entry *entry = entry_ptr;
71094f94d4aSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_LOOKUP_ENTRY;
71194f94d4aSVladimir Oltean 
71294f94d4aSVladimir Oltean 	if (entry->format == SJA1105_VL_FORMAT_PSFP) {
71394f94d4aSVladimir Oltean 		/* Interpreting vllupformat as 0 */
71494f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->destports,
71594f94d4aSVladimir Oltean 				95, 91, size, op);
71694f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->iscritical,
71794f94d4aSVladimir Oltean 				90, 90, size, op);
71894f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->macaddr,
71994f94d4aSVladimir Oltean 				89, 42, size, op);
72094f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->vlanid,
72194f94d4aSVladimir Oltean 				41, 30, size, op);
72294f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->port,
72394f94d4aSVladimir Oltean 				29, 27, size, op);
72494f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->vlanprior,
72594f94d4aSVladimir Oltean 				26, 24, size, op);
72694f94d4aSVladimir Oltean 	} else {
72794f94d4aSVladimir Oltean 		/* Interpreting vllupformat as 1 */
72894f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->egrmirr,
72994f94d4aSVladimir Oltean 				95, 91, size, op);
73094f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->ingrmirr,
73194f94d4aSVladimir Oltean 				90, 90, size, op);
73294f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->vlid,
73394f94d4aSVladimir Oltean 				57, 42, size, op);
73494f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->port,
73594f94d4aSVladimir Oltean 				29, 27, size, op);
73694f94d4aSVladimir Oltean 	}
73794f94d4aSVladimir Oltean 	return size;
73894f94d4aSVladimir Oltean }
73994f94d4aSVladimir Oltean 
sja1110_vl_lookup_entry_packing(void * buf,void * entry_ptr,enum packing_op op)7403e77e59bSVladimir Oltean size_t sja1110_vl_lookup_entry_packing(void *buf, void *entry_ptr,
7413e77e59bSVladimir Oltean 				       enum packing_op op)
7423e77e59bSVladimir Oltean {
7433e77e59bSVladimir Oltean 	struct sja1105_vl_lookup_entry *entry = entry_ptr;
7443e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_LOOKUP_ENTRY;
7453e77e59bSVladimir Oltean 
7463e77e59bSVladimir Oltean 	if (entry->format == SJA1105_VL_FORMAT_PSFP) {
7473e77e59bSVladimir Oltean 		/* Interpreting vllupformat as 0 */
7483e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->destports,
7493e77e59bSVladimir Oltean 				94, 84, size, op);
7503e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->iscritical,
7513e77e59bSVladimir Oltean 				83, 83, size, op);
7523e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->macaddr,
7533e77e59bSVladimir Oltean 				82, 35, size, op);
7543e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->vlanid,
7553e77e59bSVladimir Oltean 				34, 23, size, op);
7563e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->port,
7573e77e59bSVladimir Oltean 				22, 19, size, op);
7583e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->vlanprior,
7593e77e59bSVladimir Oltean 				18, 16, size, op);
7603e77e59bSVladimir Oltean 	} else {
7613e77e59bSVladimir Oltean 		/* Interpreting vllupformat as 1 */
7623e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->egrmirr,
7633e77e59bSVladimir Oltean 				94, 84, size, op);
7643e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->ingrmirr,
7653e77e59bSVladimir Oltean 				83, 83, size, op);
7663e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->vlid,
7673e77e59bSVladimir Oltean 				50, 35, size, op);
7683e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->port,
7693e77e59bSVladimir Oltean 				22, 19, size, op);
7703e77e59bSVladimir Oltean 	}
7713e77e59bSVladimir Oltean 	return size;
7723e77e59bSVladimir Oltean }
7733e77e59bSVladimir Oltean 
sja1105_vl_policing_entry_packing(void * buf,void * entry_ptr,enum packing_op op)77494f94d4aSVladimir Oltean static size_t sja1105_vl_policing_entry_packing(void *buf, void *entry_ptr,
77594f94d4aSVladimir Oltean 						enum packing_op op)
77694f94d4aSVladimir Oltean {
77794f94d4aSVladimir Oltean 	struct sja1105_vl_policing_entry *entry = entry_ptr;
77894f94d4aSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_POLICING_ENTRY;
77994f94d4aSVladimir Oltean 
78094f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->type,      63, 63, size, op);
78194f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->maxlen,    62, 52, size, op);
78294f94d4aSVladimir Oltean 	sja1105_packing(buf, &entry->sharindx,  51, 42, size, op);
78394f94d4aSVladimir Oltean 	if (entry->type == 0) {
78494f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->bag,    41, 28, size, op);
78594f94d4aSVladimir Oltean 		sja1105_packing(buf, &entry->jitter, 27, 18, size, op);
78694f94d4aSVladimir Oltean 	}
78794f94d4aSVladimir Oltean 	return size;
78894f94d4aSVladimir Oltean }
78994f94d4aSVladimir Oltean 
sja1110_vl_policing_entry_packing(void * buf,void * entry_ptr,enum packing_op op)7903e77e59bSVladimir Oltean size_t sja1110_vl_policing_entry_packing(void *buf, void *entry_ptr,
7913e77e59bSVladimir Oltean 					 enum packing_op op)
7923e77e59bSVladimir Oltean {
7933e77e59bSVladimir Oltean 	struct sja1105_vl_policing_entry *entry = entry_ptr;
7943e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_VL_POLICING_ENTRY;
7953e77e59bSVladimir Oltean 
7963e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->type,      63, 63, size, op);
7973e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->maxlen,    62, 52, size, op);
7983e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->sharindx,  51, 40, size, op);
7993e77e59bSVladimir Oltean 	if (entry->type == 0) {
8003e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->bag,    41, 28, size, op);
8013e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->jitter, 27, 18, size, op);
8023e77e59bSVladimir Oltean 	}
8033e77e59bSVladimir Oltean 	return size;
8043e77e59bSVladimir Oltean }
8053e77e59bSVladimir Oltean 
sja1105_vlan_lookup_entry_packing(void * buf,void * entry_ptr,enum packing_op op)8068aa9ebccSVladimir Oltean size_t sja1105_vlan_lookup_entry_packing(void *buf, void *entry_ptr,
8078aa9ebccSVladimir Oltean 					 enum packing_op op)
8088aa9ebccSVladimir Oltean {
8098aa9ebccSVladimir Oltean 	const size_t size = SJA1105_SIZE_VLAN_LOOKUP_ENTRY;
8108aa9ebccSVladimir Oltean 	struct sja1105_vlan_lookup_entry *entry = entry_ptr;
8118aa9ebccSVladimir Oltean 
8128aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->ving_mirr,  63, 59, size, op);
8138aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vegr_mirr,  58, 54, size, op);
8148aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vmemb_port, 53, 49, size, op);
8158aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlan_bc,    48, 44, size, op);
8168aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->tag_port,   43, 39, size, op);
8178aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,     38, 27, size, op);
8188aa9ebccSVladimir Oltean 	return size;
8198aa9ebccSVladimir Oltean }
8208aa9ebccSVladimir Oltean 
sja1110_vlan_lookup_entry_packing(void * buf,void * entry_ptr,enum packing_op op)8213e77e59bSVladimir Oltean size_t sja1110_vlan_lookup_entry_packing(void *buf, void *entry_ptr,
8223e77e59bSVladimir Oltean 					 enum packing_op op)
8233e77e59bSVladimir Oltean {
8243e77e59bSVladimir Oltean 	struct sja1105_vlan_lookup_entry *entry = entry_ptr;
8253e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_VLAN_LOOKUP_ENTRY;
8263e77e59bSVladimir Oltean 
8273e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->ving_mirr,  95, 85, size, op);
8283e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vegr_mirr,  84, 74, size, op);
8293e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vmemb_port, 73, 63, size, op);
8303e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlan_bc,    62, 52, size, op);
8313e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->tag_port,   51, 41, size, op);
8323e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->type_entry, 40, 39, size, op);
8333e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlanid,     38, 27, size, op);
8343e77e59bSVladimir Oltean 	return size;
8353e77e59bSVladimir Oltean }
8363e77e59bSVladimir Oltean 
sja1105_xmii_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)8378aa9ebccSVladimir Oltean static size_t sja1105_xmii_params_entry_packing(void *buf, void *entry_ptr,
8388aa9ebccSVladimir Oltean 						enum packing_op op)
8398aa9ebccSVladimir Oltean {
8408aa9ebccSVladimir Oltean 	const size_t size = SJA1105_SIZE_XMII_PARAMS_ENTRY;
8418aa9ebccSVladimir Oltean 	struct sja1105_xmii_params_entry *entry = entry_ptr;
8428aa9ebccSVladimir Oltean 	int offset, i;
8438aa9ebccSVladimir Oltean 
8448aa9ebccSVladimir Oltean 	for (i = 0, offset = 17; i < 5; i++, offset += 3) {
8458aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->xmii_mode[i],
8468aa9ebccSVladimir Oltean 				offset + 1, offset + 0, size, op);
8478aa9ebccSVladimir Oltean 		sja1105_packing(buf, &entry->phy_mac[i],
8488aa9ebccSVladimir Oltean 				offset + 2, offset + 2, size, op);
8498aa9ebccSVladimir Oltean 	}
8508aa9ebccSVladimir Oltean 	return size;
8518aa9ebccSVladimir Oltean }
8528aa9ebccSVladimir Oltean 
sja1110_xmii_params_entry_packing(void * buf,void * entry_ptr,enum packing_op op)8533e77e59bSVladimir Oltean size_t sja1110_xmii_params_entry_packing(void *buf, void *entry_ptr,
8543e77e59bSVladimir Oltean 					 enum packing_op op)
8553e77e59bSVladimir Oltean {
8563e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_XMII_PARAMS_ENTRY;
8573e77e59bSVladimir Oltean 	struct sja1105_xmii_params_entry *entry = entry_ptr;
8583e77e59bSVladimir Oltean 	int offset, i;
8593e77e59bSVladimir Oltean 
8603e77e59bSVladimir Oltean 	for (i = 0, offset = 20; i < SJA1110_NUM_PORTS; i++, offset += 4) {
8613e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->xmii_mode[i],
8623e77e59bSVladimir Oltean 				offset + 1, offset + 0, size, op);
8633e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->phy_mac[i],
8643e77e59bSVladimir Oltean 				offset + 2, offset + 2, size, op);
8653e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->special[i],
8663e77e59bSVladimir Oltean 				offset + 3, offset + 3, size, op);
8673e77e59bSVladimir Oltean 	}
8683e77e59bSVladimir Oltean 	return size;
8693e77e59bSVladimir Oltean }
8703e77e59bSVladimir Oltean 
sja1105_retagging_entry_packing(void * buf,void * entry_ptr,enum packing_op op)87188cac0faSVladimir Oltean size_t sja1105_retagging_entry_packing(void *buf, void *entry_ptr,
87288cac0faSVladimir Oltean 				       enum packing_op op)
87388cac0faSVladimir Oltean {
87488cac0faSVladimir Oltean 	struct sja1105_retagging_entry *entry = entry_ptr;
87588cac0faSVladimir Oltean 	const size_t size = SJA1105_SIZE_RETAGGING_ENTRY;
87688cac0faSVladimir Oltean 
87788cac0faSVladimir Oltean 	sja1105_packing(buf, &entry->egr_port,       63, 59, size, op);
87888cac0faSVladimir Oltean 	sja1105_packing(buf, &entry->ing_port,       58, 54, size, op);
87988cac0faSVladimir Oltean 	sja1105_packing(buf, &entry->vlan_ing,       53, 42, size, op);
88088cac0faSVladimir Oltean 	sja1105_packing(buf, &entry->vlan_egr,       41, 30, size, op);
88188cac0faSVladimir Oltean 	sja1105_packing(buf, &entry->do_not_learn,   29, 29, size, op);
88288cac0faSVladimir Oltean 	sja1105_packing(buf, &entry->use_dest_ports, 28, 28, size, op);
88388cac0faSVladimir Oltean 	sja1105_packing(buf, &entry->destports,      27, 23, size, op);
88488cac0faSVladimir Oltean 	return size;
88588cac0faSVladimir Oltean }
88688cac0faSVladimir Oltean 
sja1110_retagging_entry_packing(void * buf,void * entry_ptr,enum packing_op op)8873e77e59bSVladimir Oltean size_t sja1110_retagging_entry_packing(void *buf, void *entry_ptr,
8883e77e59bSVladimir Oltean 				       enum packing_op op)
8893e77e59bSVladimir Oltean {
8903e77e59bSVladimir Oltean 	struct sja1105_retagging_entry *entry = entry_ptr;
8913e77e59bSVladimir Oltean 	const size_t size = SJA1105_SIZE_RETAGGING_ENTRY;
8923e77e59bSVladimir Oltean 
8933e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->egr_port,       63, 53, size, op);
8943e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->ing_port,       52, 42, size, op);
8953e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlan_ing,       41, 30, size, op);
8963e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->vlan_egr,       29, 18, size, op);
8973e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->do_not_learn,   17, 17, size, op);
8983e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->use_dest_ports, 16, 16, size, op);
8993e77e59bSVladimir Oltean 	sja1105_packing(buf, &entry->destports,      15, 5, size, op);
9003e77e59bSVladimir Oltean 	return size;
9013e77e59bSVladimir Oltean }
9023e77e59bSVladimir Oltean 
sja1110_pcp_remapping_entry_packing(void * buf,void * entry_ptr,enum packing_op op)9033e77e59bSVladimir Oltean static size_t sja1110_pcp_remapping_entry_packing(void *buf, void *entry_ptr,
9043e77e59bSVladimir Oltean 						  enum packing_op op)
9053e77e59bSVladimir Oltean {
9063e77e59bSVladimir Oltean 	struct sja1110_pcp_remapping_entry *entry = entry_ptr;
9073e77e59bSVladimir Oltean 	const size_t size = SJA1110_SIZE_PCP_REMAPPING_ENTRY;
9083e77e59bSVladimir Oltean 	int offset, i;
9093e77e59bSVladimir Oltean 
9103e77e59bSVladimir Oltean 	for (i = 0, offset = 8; i < SJA1105_NUM_TC; i++, offset += 3)
9113e77e59bSVladimir Oltean 		sja1105_packing(buf, &entry->egrpcp[i],
9123e77e59bSVladimir Oltean 				offset + 2, offset + 0, size, op);
9133e77e59bSVladimir Oltean 
9143e77e59bSVladimir Oltean 	return size;
9153e77e59bSVladimir Oltean }
9163e77e59bSVladimir Oltean 
sja1105_table_header_packing(void * buf,void * entry_ptr,enum packing_op op)9178aa9ebccSVladimir Oltean size_t sja1105_table_header_packing(void *buf, void *entry_ptr,
9188aa9ebccSVladimir Oltean 				    enum packing_op op)
9198aa9ebccSVladimir Oltean {
9208aa9ebccSVladimir Oltean 	const size_t size = SJA1105_SIZE_TABLE_HEADER;
9218aa9ebccSVladimir Oltean 	struct sja1105_table_header *entry = entry_ptr;
9228aa9ebccSVladimir Oltean 
9238aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->block_id, 31, 24, size, op);
9248aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->len,      55, 32, size, op);
9258aa9ebccSVladimir Oltean 	sja1105_packing(buf, &entry->crc,      95, 64, size, op);
9268aa9ebccSVladimir Oltean 	return size;
9278aa9ebccSVladimir Oltean }
9288aa9ebccSVladimir Oltean 
9298aa9ebccSVladimir Oltean /* WARNING: the *hdr pointer is really non-const, because it is
9308aa9ebccSVladimir Oltean  * modifying the CRC of the header for a 2-stage packing operation
9318aa9ebccSVladimir Oltean  */
9328aa9ebccSVladimir Oltean void
sja1105_table_header_pack_with_crc(void * buf,struct sja1105_table_header * hdr)9338aa9ebccSVladimir Oltean sja1105_table_header_pack_with_crc(void *buf, struct sja1105_table_header *hdr)
9348aa9ebccSVladimir Oltean {
9358aa9ebccSVladimir Oltean 	/* First pack the table as-is, then calculate the CRC, and
9368aa9ebccSVladimir Oltean 	 * finally put the proper CRC into the packed buffer
9378aa9ebccSVladimir Oltean 	 */
9388aa9ebccSVladimir Oltean 	memset(buf, 0, SJA1105_SIZE_TABLE_HEADER);
9398aa9ebccSVladimir Oltean 	sja1105_table_header_packing(buf, hdr, PACK);
9408aa9ebccSVladimir Oltean 	hdr->crc = sja1105_crc32(buf, SJA1105_SIZE_TABLE_HEADER - 4);
9418aa9ebccSVladimir Oltean 	sja1105_pack(buf + SJA1105_SIZE_TABLE_HEADER - 4, &hdr->crc, 31, 0, 4);
9428aa9ebccSVladimir Oltean }
9438aa9ebccSVladimir Oltean 
sja1105_table_write_crc(u8 * table_start,u8 * crc_ptr)9448aa9ebccSVladimir Oltean static void sja1105_table_write_crc(u8 *table_start, u8 *crc_ptr)
9458aa9ebccSVladimir Oltean {
9468aa9ebccSVladimir Oltean 	u64 computed_crc;
9478aa9ebccSVladimir Oltean 	int len_bytes;
9488aa9ebccSVladimir Oltean 
9498aa9ebccSVladimir Oltean 	len_bytes = (uintptr_t)(crc_ptr - table_start);
9508aa9ebccSVladimir Oltean 	computed_crc = sja1105_crc32(table_start, len_bytes);
9518aa9ebccSVladimir Oltean 	sja1105_pack(crc_ptr, &computed_crc, 31, 0, 4);
9528aa9ebccSVladimir Oltean }
9538aa9ebccSVladimir Oltean 
9548aa9ebccSVladimir Oltean /* The block IDs that the switches support are unfortunately sparse, so keep a
9558aa9ebccSVladimir Oltean  * mapping table to "block indices" and translate back and forth so that we
9568aa9ebccSVladimir Oltean  * don't waste useless memory in struct sja1105_static_config.
9578aa9ebccSVladimir Oltean  * Also, since the block id comes from essentially untrusted input (unpacking
9588aa9ebccSVladimir Oltean  * the static config from userspace) it has to be sanitized (range-checked)
9598aa9ebccSVladimir Oltean  * before blindly indexing kernel memory with the blk_idx.
9608aa9ebccSVladimir Oltean  */
9618aa9ebccSVladimir Oltean static u64 blk_id_map[BLK_IDX_MAX] = {
9627f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE] = BLKID_SCHEDULE,
9637f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS] = BLKID_SCHEDULE_ENTRY_POINTS,
96494f94d4aSVladimir Oltean 	[BLK_IDX_VL_LOOKUP] = BLKID_VL_LOOKUP,
96594f94d4aSVladimir Oltean 	[BLK_IDX_VL_POLICING] = BLKID_VL_POLICING,
96694f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING] = BLKID_VL_FORWARDING,
9678aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = BLKID_L2_LOOKUP,
9688aa9ebccSVladimir Oltean 	[BLK_IDX_L2_POLICING] = BLKID_L2_POLICING,
9698aa9ebccSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = BLKID_VLAN_LOOKUP,
9708aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = BLKID_L2_FORWARDING,
9718aa9ebccSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = BLKID_MAC_CONFIG,
9727f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_PARAMS] = BLKID_SCHEDULE_PARAMS,
9737f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS_PARAMS] = BLKID_SCHEDULE_ENTRY_POINTS_PARAMS,
97494f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING_PARAMS] = BLKID_VL_FORWARDING_PARAMS,
9758aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = BLKID_L2_LOOKUP_PARAMS,
9768aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = BLKID_L2_FORWARDING_PARAMS,
97724c01949SVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = BLKID_AVB_PARAMS,
9788aa9ebccSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = BLKID_GENERAL_PARAMS,
97988cac0faSVladimir Oltean 	[BLK_IDX_RETAGGING] = BLKID_RETAGGING,
9808aa9ebccSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = BLKID_XMII_PARAMS,
9813e77e59bSVladimir Oltean 	[BLK_IDX_PCP_REMAPPING] = BLKID_PCP_REMAPPING,
9828aa9ebccSVladimir Oltean };
9838aa9ebccSVladimir Oltean 
9848aa9ebccSVladimir Oltean const char *sja1105_static_config_error_msg[] = {
9858aa9ebccSVladimir Oltean 	[SJA1105_CONFIG_OK] = "",
9867f1e4ba8SVladimir Oltean 	[SJA1105_TTETHERNET_NOT_SUPPORTED] =
9877f1e4ba8SVladimir Oltean 		"schedule-table present, but TTEthernet is "
9887f1e4ba8SVladimir Oltean 		"only supported on T and Q/S",
9897f1e4ba8SVladimir Oltean 	[SJA1105_INCORRECT_TTETHERNET_CONFIGURATION] =
9907f1e4ba8SVladimir Oltean 		"schedule-table present, but one of "
9917f1e4ba8SVladimir Oltean 		"schedule-entry-points-table, schedule-parameters-table or "
9927f1e4ba8SVladimir Oltean 		"schedule-entry-points-parameters table is empty",
99394f94d4aSVladimir Oltean 	[SJA1105_INCORRECT_VIRTUAL_LINK_CONFIGURATION] =
99494f94d4aSVladimir Oltean 		"vl-lookup-table present, but one of vl-policing-table, "
99594f94d4aSVladimir Oltean 		"vl-forwarding-table or vl-forwarding-parameters-table is empty",
9968aa9ebccSVladimir Oltean 	[SJA1105_MISSING_L2_POLICING_TABLE] =
9978aa9ebccSVladimir Oltean 		"l2-policing-table needs to have at least one entry",
9988aa9ebccSVladimir Oltean 	[SJA1105_MISSING_L2_FORWARDING_TABLE] =
9998aa9ebccSVladimir Oltean 		"l2-forwarding-table is either missing or incomplete",
10008aa9ebccSVladimir Oltean 	[SJA1105_MISSING_L2_FORWARDING_PARAMS_TABLE] =
10018aa9ebccSVladimir Oltean 		"l2-forwarding-parameters-table is missing",
10028aa9ebccSVladimir Oltean 	[SJA1105_MISSING_GENERAL_PARAMS_TABLE] =
10038aa9ebccSVladimir Oltean 		"general-parameters-table is missing",
10048aa9ebccSVladimir Oltean 	[SJA1105_MISSING_VLAN_TABLE] =
10058aa9ebccSVladimir Oltean 		"vlan-lookup-table needs to have at least the default untagged VLAN",
10068aa9ebccSVladimir Oltean 	[SJA1105_MISSING_XMII_TABLE] =
10078aa9ebccSVladimir Oltean 		"xmii-table is missing",
10088aa9ebccSVladimir Oltean 	[SJA1105_MISSING_MAC_TABLE] =
10098aa9ebccSVladimir Oltean 		"mac-configuration-table needs to contain an entry for each port",
10108aa9ebccSVladimir Oltean 	[SJA1105_OVERCOMMITTED_FRAME_MEMORY] =
10118aa9ebccSVladimir Oltean 		"Not allowed to overcommit frame memory. L2 memory partitions "
10128aa9ebccSVladimir Oltean 		"and VL memory partitions share the same space. The sum of all "
10138aa9ebccSVladimir Oltean 		"16 memory partitions is not allowed to be larger than 929 "
10148aa9ebccSVladimir Oltean 		"128-byte blocks (or 910 with retagging). Please adjust "
10158aa9ebccSVladimir Oltean 		"l2-forwarding-parameters-table.part_spc and/or "
10168aa9ebccSVladimir Oltean 		"vl-forwarding-parameters-table.partspc.",
10178aa9ebccSVladimir Oltean };
10188aa9ebccSVladimir Oltean 
10195ee907f7SYueHaibing static sja1105_config_valid_t
static_config_check_memory_size(const struct sja1105_table * tables,int max_mem)10201bf658eeSVladimir Oltean static_config_check_memory_size(const struct sja1105_table *tables, int max_mem)
10218aa9ebccSVladimir Oltean {
10228aa9ebccSVladimir Oltean 	const struct sja1105_l2_forwarding_params_entry *l2_fwd_params;
102394f94d4aSVladimir Oltean 	const struct sja1105_vl_forwarding_params_entry *vl_fwd_params;
10241bf658eeSVladimir Oltean 	int i, mem = 0;
10258aa9ebccSVladimir Oltean 
10268aa9ebccSVladimir Oltean 	l2_fwd_params = tables[BLK_IDX_L2_FORWARDING_PARAMS].entries;
10278aa9ebccSVladimir Oltean 
10288aa9ebccSVladimir Oltean 	for (i = 0; i < 8; i++)
10298aa9ebccSVladimir Oltean 		mem += l2_fwd_params->part_spc[i];
10308aa9ebccSVladimir Oltean 
103194f94d4aSVladimir Oltean 	if (tables[BLK_IDX_VL_FORWARDING_PARAMS].entry_count) {
103294f94d4aSVladimir Oltean 		vl_fwd_params = tables[BLK_IDX_VL_FORWARDING_PARAMS].entries;
103394f94d4aSVladimir Oltean 		for (i = 0; i < 8; i++)
103494f94d4aSVladimir Oltean 			mem += vl_fwd_params->partspc[i];
103594f94d4aSVladimir Oltean 	}
103694f94d4aSVladimir Oltean 
103788cac0faSVladimir Oltean 	if (tables[BLK_IDX_RETAGGING].entry_count)
10381bf658eeSVladimir Oltean 		max_mem -= SJA1105_FRAME_MEMORY_RETAGGING_OVERHEAD;
103988cac0faSVladimir Oltean 
104088cac0faSVladimir Oltean 	if (mem > max_mem)
10418aa9ebccSVladimir Oltean 		return SJA1105_OVERCOMMITTED_FRAME_MEMORY;
10428aa9ebccSVladimir Oltean 
10438aa9ebccSVladimir Oltean 	return SJA1105_CONFIG_OK;
10448aa9ebccSVladimir Oltean }
10458aa9ebccSVladimir Oltean 
10468aa9ebccSVladimir Oltean sja1105_config_valid_t
sja1105_static_config_check_valid(const struct sja1105_static_config * config,int max_mem)10471bf658eeSVladimir Oltean sja1105_static_config_check_valid(const struct sja1105_static_config *config,
10481bf658eeSVladimir Oltean 				  int max_mem)
10498aa9ebccSVladimir Oltean {
10508aa9ebccSVladimir Oltean 	const struct sja1105_table *tables = config->tables;
10518aa9ebccSVladimir Oltean #define IS_FULL(blk_idx) \
10528aa9ebccSVladimir Oltean 	(tables[blk_idx].entry_count == tables[blk_idx].ops->max_entry_count)
10538aa9ebccSVladimir Oltean 
10547f1e4ba8SVladimir Oltean 	if (tables[BLK_IDX_SCHEDULE].entry_count) {
10551303e7f9SVladimir Oltean 		if (!tables[BLK_IDX_SCHEDULE].ops->max_entry_count)
10567f1e4ba8SVladimir Oltean 			return SJA1105_TTETHERNET_NOT_SUPPORTED;
10577f1e4ba8SVladimir Oltean 
10587f1e4ba8SVladimir Oltean 		if (tables[BLK_IDX_SCHEDULE_ENTRY_POINTS].entry_count == 0)
10597f1e4ba8SVladimir Oltean 			return SJA1105_INCORRECT_TTETHERNET_CONFIGURATION;
10607f1e4ba8SVladimir Oltean 
10617f1e4ba8SVladimir Oltean 		if (!IS_FULL(BLK_IDX_SCHEDULE_PARAMS))
10627f1e4ba8SVladimir Oltean 			return SJA1105_INCORRECT_TTETHERNET_CONFIGURATION;
10637f1e4ba8SVladimir Oltean 
10647f1e4ba8SVladimir Oltean 		if (!IS_FULL(BLK_IDX_SCHEDULE_ENTRY_POINTS_PARAMS))
10657f1e4ba8SVladimir Oltean 			return SJA1105_INCORRECT_TTETHERNET_CONFIGURATION;
10667f1e4ba8SVladimir Oltean 	}
106794f94d4aSVladimir Oltean 	if (tables[BLK_IDX_VL_LOOKUP].entry_count) {
106894f94d4aSVladimir Oltean 		struct sja1105_vl_lookup_entry *vl_lookup;
106994f94d4aSVladimir Oltean 		bool has_critical_links = false;
107094f94d4aSVladimir Oltean 		int i;
107194f94d4aSVladimir Oltean 
107294f94d4aSVladimir Oltean 		vl_lookup = tables[BLK_IDX_VL_LOOKUP].entries;
107394f94d4aSVladimir Oltean 
107494f94d4aSVladimir Oltean 		for (i = 0; i < tables[BLK_IDX_VL_LOOKUP].entry_count; i++) {
107594f94d4aSVladimir Oltean 			if (vl_lookup[i].iscritical) {
107694f94d4aSVladimir Oltean 				has_critical_links = true;
107794f94d4aSVladimir Oltean 				break;
107894f94d4aSVladimir Oltean 			}
107994f94d4aSVladimir Oltean 		}
108094f94d4aSVladimir Oltean 
108194f94d4aSVladimir Oltean 		if (tables[BLK_IDX_VL_POLICING].entry_count == 0 &&
108294f94d4aSVladimir Oltean 		    has_critical_links)
108394f94d4aSVladimir Oltean 			return SJA1105_INCORRECT_VIRTUAL_LINK_CONFIGURATION;
108494f94d4aSVladimir Oltean 
108594f94d4aSVladimir Oltean 		if (tables[BLK_IDX_VL_FORWARDING].entry_count == 0 &&
108694f94d4aSVladimir Oltean 		    has_critical_links)
108794f94d4aSVladimir Oltean 			return SJA1105_INCORRECT_VIRTUAL_LINK_CONFIGURATION;
108894f94d4aSVladimir Oltean 
108994f94d4aSVladimir Oltean 		if (tables[BLK_IDX_VL_FORWARDING_PARAMS].entry_count == 0 &&
109094f94d4aSVladimir Oltean 		    has_critical_links)
109194f94d4aSVladimir Oltean 			return SJA1105_INCORRECT_VIRTUAL_LINK_CONFIGURATION;
109294f94d4aSVladimir Oltean 	}
10937f1e4ba8SVladimir Oltean 
10948aa9ebccSVladimir Oltean 	if (tables[BLK_IDX_L2_POLICING].entry_count == 0)
10958aa9ebccSVladimir Oltean 		return SJA1105_MISSING_L2_POLICING_TABLE;
10968aa9ebccSVladimir Oltean 
10978aa9ebccSVladimir Oltean 	if (tables[BLK_IDX_VLAN_LOOKUP].entry_count == 0)
10988aa9ebccSVladimir Oltean 		return SJA1105_MISSING_VLAN_TABLE;
10998aa9ebccSVladimir Oltean 
11008aa9ebccSVladimir Oltean 	if (!IS_FULL(BLK_IDX_L2_FORWARDING))
11018aa9ebccSVladimir Oltean 		return SJA1105_MISSING_L2_FORWARDING_TABLE;
11028aa9ebccSVladimir Oltean 
11038aa9ebccSVladimir Oltean 	if (!IS_FULL(BLK_IDX_MAC_CONFIG))
11048aa9ebccSVladimir Oltean 		return SJA1105_MISSING_MAC_TABLE;
11058aa9ebccSVladimir Oltean 
11068aa9ebccSVladimir Oltean 	if (!IS_FULL(BLK_IDX_L2_FORWARDING_PARAMS))
11078aa9ebccSVladimir Oltean 		return SJA1105_MISSING_L2_FORWARDING_PARAMS_TABLE;
11088aa9ebccSVladimir Oltean 
11098aa9ebccSVladimir Oltean 	if (!IS_FULL(BLK_IDX_GENERAL_PARAMS))
11108aa9ebccSVladimir Oltean 		return SJA1105_MISSING_GENERAL_PARAMS_TABLE;
11118aa9ebccSVladimir Oltean 
11128aa9ebccSVladimir Oltean 	if (!IS_FULL(BLK_IDX_XMII_PARAMS))
11138aa9ebccSVladimir Oltean 		return SJA1105_MISSING_XMII_TABLE;
11148aa9ebccSVladimir Oltean 
11151bf658eeSVladimir Oltean 	return static_config_check_memory_size(tables, max_mem);
11168aa9ebccSVladimir Oltean #undef IS_FULL
11178aa9ebccSVladimir Oltean }
11188aa9ebccSVladimir Oltean 
11198aa9ebccSVladimir Oltean void
sja1105_static_config_pack(void * buf,struct sja1105_static_config * config)11208aa9ebccSVladimir Oltean sja1105_static_config_pack(void *buf, struct sja1105_static_config *config)
11218aa9ebccSVladimir Oltean {
11228aa9ebccSVladimir Oltean 	struct sja1105_table_header header = {0};
11238aa9ebccSVladimir Oltean 	enum sja1105_blk_idx i;
11248aa9ebccSVladimir Oltean 	char *p = buf;
11258aa9ebccSVladimir Oltean 	int j;
11268aa9ebccSVladimir Oltean 
11278aa9ebccSVladimir Oltean 	sja1105_pack(p, &config->device_id, 31, 0, 4);
11288aa9ebccSVladimir Oltean 	p += SJA1105_SIZE_DEVICE_ID;
11298aa9ebccSVladimir Oltean 
11308aa9ebccSVladimir Oltean 	for (i = 0; i < BLK_IDX_MAX; i++) {
11318aa9ebccSVladimir Oltean 		const struct sja1105_table *table;
11328aa9ebccSVladimir Oltean 		char *table_start;
11338aa9ebccSVladimir Oltean 
11348aa9ebccSVladimir Oltean 		table = &config->tables[i];
11358aa9ebccSVladimir Oltean 		if (!table->entry_count)
11368aa9ebccSVladimir Oltean 			continue;
11378aa9ebccSVladimir Oltean 
11388aa9ebccSVladimir Oltean 		header.block_id = blk_id_map[i];
11398aa9ebccSVladimir Oltean 		header.len = table->entry_count *
11408aa9ebccSVladimir Oltean 			     table->ops->packed_entry_size / 4;
11418aa9ebccSVladimir Oltean 		sja1105_table_header_pack_with_crc(p, &header);
11428aa9ebccSVladimir Oltean 		p += SJA1105_SIZE_TABLE_HEADER;
11438aa9ebccSVladimir Oltean 		table_start = p;
11448aa9ebccSVladimir Oltean 		for (j = 0; j < table->entry_count; j++) {
11458aa9ebccSVladimir Oltean 			u8 *entry_ptr = table->entries;
11468aa9ebccSVladimir Oltean 
11478aa9ebccSVladimir Oltean 			entry_ptr += j * table->ops->unpacked_entry_size;
11488aa9ebccSVladimir Oltean 			memset(p, 0, table->ops->packed_entry_size);
11498aa9ebccSVladimir Oltean 			table->ops->packing(p, entry_ptr, PACK);
11508aa9ebccSVladimir Oltean 			p += table->ops->packed_entry_size;
11518aa9ebccSVladimir Oltean 		}
11528aa9ebccSVladimir Oltean 		sja1105_table_write_crc(table_start, p);
11538aa9ebccSVladimir Oltean 		p += 4;
11548aa9ebccSVladimir Oltean 	}
11558aa9ebccSVladimir Oltean 	/* Final header:
11568aa9ebccSVladimir Oltean 	 * Block ID does not matter
11578aa9ebccSVladimir Oltean 	 * Length of 0 marks that header is final
11588aa9ebccSVladimir Oltean 	 * CRC will be replaced on-the-fly on "config upload"
11598aa9ebccSVladimir Oltean 	 */
11608aa9ebccSVladimir Oltean 	header.block_id = 0;
11618aa9ebccSVladimir Oltean 	header.len = 0;
11628aa9ebccSVladimir Oltean 	header.crc = 0xDEADBEEF;
11638aa9ebccSVladimir Oltean 	memset(p, 0, SJA1105_SIZE_TABLE_HEADER);
11648aa9ebccSVladimir Oltean 	sja1105_table_header_packing(p, &header, PACK);
11658aa9ebccSVladimir Oltean }
11668aa9ebccSVladimir Oltean 
11678aa9ebccSVladimir Oltean size_t
sja1105_static_config_get_length(const struct sja1105_static_config * config)11688aa9ebccSVladimir Oltean sja1105_static_config_get_length(const struct sja1105_static_config *config)
11698aa9ebccSVladimir Oltean {
11708aa9ebccSVladimir Oltean 	unsigned int sum;
11718aa9ebccSVladimir Oltean 	unsigned int header_count;
11728aa9ebccSVladimir Oltean 	enum sja1105_blk_idx i;
11738aa9ebccSVladimir Oltean 
11748aa9ebccSVladimir Oltean 	/* Ending header */
11758aa9ebccSVladimir Oltean 	header_count = 1;
11768aa9ebccSVladimir Oltean 	sum = SJA1105_SIZE_DEVICE_ID;
11778aa9ebccSVladimir Oltean 
11788aa9ebccSVladimir Oltean 	/* Tables (headers and entries) */
11798aa9ebccSVladimir Oltean 	for (i = 0; i < BLK_IDX_MAX; i++) {
11808aa9ebccSVladimir Oltean 		const struct sja1105_table *table;
11818aa9ebccSVladimir Oltean 
11828aa9ebccSVladimir Oltean 		table = &config->tables[i];
11838aa9ebccSVladimir Oltean 		if (table->entry_count)
11848aa9ebccSVladimir Oltean 			header_count++;
11858aa9ebccSVladimir Oltean 
11868aa9ebccSVladimir Oltean 		sum += table->ops->packed_entry_size * table->entry_count;
11878aa9ebccSVladimir Oltean 	}
11888aa9ebccSVladimir Oltean 	/* Headers have an additional CRC at the end */
11898aa9ebccSVladimir Oltean 	sum += header_count * (SJA1105_SIZE_TABLE_HEADER + 4);
11908aa9ebccSVladimir Oltean 	/* Last header does not have an extra CRC because there is no data */
11918aa9ebccSVladimir Oltean 	sum -= 4;
11928aa9ebccSVladimir Oltean 
11938aa9ebccSVladimir Oltean 	return sum;
11948aa9ebccSVladimir Oltean }
11958aa9ebccSVladimir Oltean 
11968aa9ebccSVladimir Oltean /* Compatibility matrices */
11978aa9ebccSVladimir Oltean 
11988aa9ebccSVladimir Oltean /* SJA1105E: First generation, no TTEthernet */
1199718e44b6SVladimir Oltean const struct sja1105_table_ops sja1105e_table_ops[BLK_IDX_MAX] = {
12008aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = {
12018aa9ebccSVladimir Oltean 		.packing = sja1105et_l2_lookup_entry_packing,
12028aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_entry),
12038aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_L2_LOOKUP_ENTRY,
12048aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_COUNT,
12058aa9ebccSVladimir Oltean 	},
12068aa9ebccSVladimir Oltean 	[BLK_IDX_L2_POLICING] = {
12078aa9ebccSVladimir Oltean 		.packing = sja1105_l2_policing_entry_packing,
12088aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_policing_entry),
12098aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_POLICING_ENTRY,
12108aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_POLICING_COUNT,
12118aa9ebccSVladimir Oltean 	},
12128aa9ebccSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = {
12138aa9ebccSVladimir Oltean 		.packing = sja1105_vlan_lookup_entry_packing,
12148aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vlan_lookup_entry),
12158aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VLAN_LOOKUP_ENTRY,
12168aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VLAN_LOOKUP_COUNT,
12178aa9ebccSVladimir Oltean 	},
12188aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = {
12198aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_entry_packing,
12208aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_entry),
12218aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_ENTRY,
12228aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_COUNT,
12238aa9ebccSVladimir Oltean 	},
12248aa9ebccSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = {
12258aa9ebccSVladimir Oltean 		.packing = sja1105et_mac_config_entry_packing,
12268aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_mac_config_entry),
12278aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_MAC_CONFIG_ENTRY,
12288aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_MAC_CONFIG_COUNT,
12298aa9ebccSVladimir Oltean 	},
12308aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = {
12318aa9ebccSVladimir Oltean 		.packing = sja1105et_l2_lookup_params_entry_packing,
12328aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_params_entry),
12338aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_L2_LOOKUP_PARAMS_ENTRY,
12348aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_PARAMS_COUNT,
12358aa9ebccSVladimir Oltean 	},
12368aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = {
12378aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_params_entry_packing,
12388aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_params_entry),
12398aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY,
12408aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_PARAMS_COUNT,
12418aa9ebccSVladimir Oltean 	},
124224c01949SVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = {
124324c01949SVladimir Oltean 		.packing = sja1105et_avb_params_entry_packing,
124424c01949SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_avb_params_entry),
124524c01949SVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_AVB_PARAMS_ENTRY,
124624c01949SVladimir Oltean 		.max_entry_count = SJA1105_MAX_AVB_PARAMS_COUNT,
124724c01949SVladimir Oltean 	},
12488aa9ebccSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = {
12498aa9ebccSVladimir Oltean 		.packing = sja1105et_general_params_entry_packing,
12508aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_general_params_entry),
12518aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_GENERAL_PARAMS_ENTRY,
12528aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_GENERAL_PARAMS_COUNT,
12538aa9ebccSVladimir Oltean 	},
125488cac0faSVladimir Oltean 	[BLK_IDX_RETAGGING] = {
125588cac0faSVladimir Oltean 		.packing = sja1105_retagging_entry_packing,
125688cac0faSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_retagging_entry),
125788cac0faSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_RETAGGING_ENTRY,
125888cac0faSVladimir Oltean 		.max_entry_count = SJA1105_MAX_RETAGGING_COUNT,
125988cac0faSVladimir Oltean 	},
12608aa9ebccSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = {
12618aa9ebccSVladimir Oltean 		.packing = sja1105_xmii_params_entry_packing,
12628aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_xmii_params_entry),
12638aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_XMII_PARAMS_ENTRY,
12648aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_XMII_PARAMS_COUNT,
12658aa9ebccSVladimir Oltean 	},
12668aa9ebccSVladimir Oltean };
12678aa9ebccSVladimir Oltean 
12688aa9ebccSVladimir Oltean /* SJA1105T: First generation, TTEthernet */
1269718e44b6SVladimir Oltean const struct sja1105_table_ops sja1105t_table_ops[BLK_IDX_MAX] = {
12707f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE] = {
12717f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_packing,
12727f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry),
12737f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY,
12747f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_COUNT,
12757f1e4ba8SVladimir Oltean 	},
12767f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS] = {
12777f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_points_entry_packing,
12787f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_entry),
12797f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_ENTRY,
12807f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_COUNT,
12817f1e4ba8SVladimir Oltean 	},
128294f94d4aSVladimir Oltean 	[BLK_IDX_VL_LOOKUP] = {
128394f94d4aSVladimir Oltean 		.packing = sja1105_vl_lookup_entry_packing,
128494f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_lookup_entry),
128594f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_LOOKUP_ENTRY,
128694f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_LOOKUP_COUNT,
128794f94d4aSVladimir Oltean 	},
128894f94d4aSVladimir Oltean 	[BLK_IDX_VL_POLICING] = {
128994f94d4aSVladimir Oltean 		.packing = sja1105_vl_policing_entry_packing,
129094f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_policing_entry),
129194f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_POLICING_ENTRY,
129294f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_POLICING_COUNT,
129394f94d4aSVladimir Oltean 	},
129494f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING] = {
129594f94d4aSVladimir Oltean 		.packing = sja1105_vl_forwarding_entry_packing,
129694f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_entry),
129794f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_ENTRY,
129894f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_FORWARDING_COUNT,
129994f94d4aSVladimir Oltean 	},
13008aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = {
13018aa9ebccSVladimir Oltean 		.packing = sja1105et_l2_lookup_entry_packing,
13028aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_entry),
13038aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_L2_LOOKUP_ENTRY,
13048aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_COUNT,
13058aa9ebccSVladimir Oltean 	},
13068aa9ebccSVladimir Oltean 	[BLK_IDX_L2_POLICING] = {
13078aa9ebccSVladimir Oltean 		.packing = sja1105_l2_policing_entry_packing,
13088aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_policing_entry),
13098aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_POLICING_ENTRY,
13108aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_POLICING_COUNT,
13118aa9ebccSVladimir Oltean 	},
13128aa9ebccSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = {
13138aa9ebccSVladimir Oltean 		.packing = sja1105_vlan_lookup_entry_packing,
13148aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vlan_lookup_entry),
13158aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VLAN_LOOKUP_ENTRY,
13168aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VLAN_LOOKUP_COUNT,
13178aa9ebccSVladimir Oltean 	},
13188aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = {
13198aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_entry_packing,
13208aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_entry),
13218aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_ENTRY,
13228aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_COUNT,
13238aa9ebccSVladimir Oltean 	},
13248aa9ebccSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = {
13258aa9ebccSVladimir Oltean 		.packing = sja1105et_mac_config_entry_packing,
13268aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_mac_config_entry),
13278aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_MAC_CONFIG_ENTRY,
13288aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_MAC_CONFIG_COUNT,
13298aa9ebccSVladimir Oltean 	},
13307f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_PARAMS] = {
13317f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_params_entry_packing,
13327f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_params_entry),
13337f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_PARAMS_ENTRY,
13347f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_PARAMS_COUNT,
13357f1e4ba8SVladimir Oltean 	},
13367f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS_PARAMS] = {
13377f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_points_params_entry_packing,
13387f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_params_entry),
13397f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_PARAMS_ENTRY,
13407f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_PARAMS_COUNT,
13417f1e4ba8SVladimir Oltean 	},
134294f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING_PARAMS] = {
134394f94d4aSVladimir Oltean 		.packing = sja1105_vl_forwarding_params_entry_packing,
134494f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_params_entry),
134594f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_PARAMS_ENTRY,
134694f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_FORWARDING_PARAMS_COUNT,
134794f94d4aSVladimir Oltean 	},
13488aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = {
13498aa9ebccSVladimir Oltean 		.packing = sja1105et_l2_lookup_params_entry_packing,
13508aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_params_entry),
13518aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_L2_LOOKUP_PARAMS_ENTRY,
13528aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_PARAMS_COUNT,
13538aa9ebccSVladimir Oltean 	},
13548aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = {
13558aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_params_entry_packing,
13568aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_params_entry),
13578aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY,
13588aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_PARAMS_COUNT,
13598aa9ebccSVladimir Oltean 	},
136024c01949SVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = {
136124c01949SVladimir Oltean 		.packing = sja1105et_avb_params_entry_packing,
136224c01949SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_avb_params_entry),
136324c01949SVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_AVB_PARAMS_ENTRY,
136424c01949SVladimir Oltean 		.max_entry_count = SJA1105_MAX_AVB_PARAMS_COUNT,
136524c01949SVladimir Oltean 	},
13668aa9ebccSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = {
13678aa9ebccSVladimir Oltean 		.packing = sja1105et_general_params_entry_packing,
13688aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_general_params_entry),
13698aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105ET_SIZE_GENERAL_PARAMS_ENTRY,
13708aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_GENERAL_PARAMS_COUNT,
13718aa9ebccSVladimir Oltean 	},
137288cac0faSVladimir Oltean 	[BLK_IDX_RETAGGING] = {
137388cac0faSVladimir Oltean 		.packing = sja1105_retagging_entry_packing,
137488cac0faSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_retagging_entry),
137588cac0faSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_RETAGGING_ENTRY,
137688cac0faSVladimir Oltean 		.max_entry_count = SJA1105_MAX_RETAGGING_COUNT,
137788cac0faSVladimir Oltean 	},
13788aa9ebccSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = {
13798aa9ebccSVladimir Oltean 		.packing = sja1105_xmii_params_entry_packing,
13808aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_xmii_params_entry),
13818aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_XMII_PARAMS_ENTRY,
13828aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_XMII_PARAMS_COUNT,
13838aa9ebccSVladimir Oltean 	},
13848aa9ebccSVladimir Oltean };
13858aa9ebccSVladimir Oltean 
13868aa9ebccSVladimir Oltean /* SJA1105P: Second generation, no TTEthernet, no SGMII */
1387718e44b6SVladimir Oltean const struct sja1105_table_ops sja1105p_table_ops[BLK_IDX_MAX] = {
13888aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = {
13898aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_entry_packing,
13908aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_entry),
13918aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_ENTRY,
13928aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_COUNT,
13938aa9ebccSVladimir Oltean 	},
13948aa9ebccSVladimir Oltean 	[BLK_IDX_L2_POLICING] = {
13958aa9ebccSVladimir Oltean 		.packing = sja1105_l2_policing_entry_packing,
13968aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_policing_entry),
13978aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_POLICING_ENTRY,
13988aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_POLICING_COUNT,
13998aa9ebccSVladimir Oltean 	},
14008aa9ebccSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = {
14018aa9ebccSVladimir Oltean 		.packing = sja1105_vlan_lookup_entry_packing,
14028aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vlan_lookup_entry),
14038aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VLAN_LOOKUP_ENTRY,
14048aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VLAN_LOOKUP_COUNT,
14058aa9ebccSVladimir Oltean 	},
14068aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = {
14078aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_entry_packing,
14088aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_entry),
14098aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_ENTRY,
14108aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_COUNT,
14118aa9ebccSVladimir Oltean 	},
14128aa9ebccSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = {
14138aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_mac_config_entry_packing,
14148aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_mac_config_entry),
14158aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_MAC_CONFIG_ENTRY,
14168aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_MAC_CONFIG_COUNT,
14178aa9ebccSVladimir Oltean 	},
14188aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = {
14198aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_params_entry_packing,
14208aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_params_entry),
14218aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_PARAMS_ENTRY,
14228aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_PARAMS_COUNT,
14238aa9ebccSVladimir Oltean 	},
14248aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = {
14258aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_params_entry_packing,
14268aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_params_entry),
14278aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY,
14288aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_PARAMS_COUNT,
14298aa9ebccSVladimir Oltean 	},
143024c01949SVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = {
143124c01949SVladimir Oltean 		.packing = sja1105pqrs_avb_params_entry_packing,
143224c01949SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_avb_params_entry),
143324c01949SVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_AVB_PARAMS_ENTRY,
143424c01949SVladimir Oltean 		.max_entry_count = SJA1105_MAX_AVB_PARAMS_COUNT,
143524c01949SVladimir Oltean 	},
14368aa9ebccSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = {
14378aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_general_params_entry_packing,
14388aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_general_params_entry),
14398aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_GENERAL_PARAMS_ENTRY,
14408aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_GENERAL_PARAMS_COUNT,
14418aa9ebccSVladimir Oltean 	},
144288cac0faSVladimir Oltean 	[BLK_IDX_RETAGGING] = {
144388cac0faSVladimir Oltean 		.packing = sja1105_retagging_entry_packing,
144488cac0faSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_retagging_entry),
144588cac0faSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_RETAGGING_ENTRY,
144688cac0faSVladimir Oltean 		.max_entry_count = SJA1105_MAX_RETAGGING_COUNT,
144788cac0faSVladimir Oltean 	},
14488aa9ebccSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = {
14498aa9ebccSVladimir Oltean 		.packing = sja1105_xmii_params_entry_packing,
14508aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_xmii_params_entry),
14518aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_XMII_PARAMS_ENTRY,
14528aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_XMII_PARAMS_COUNT,
14538aa9ebccSVladimir Oltean 	},
14548aa9ebccSVladimir Oltean };
14558aa9ebccSVladimir Oltean 
14568aa9ebccSVladimir Oltean /* SJA1105Q: Second generation, TTEthernet, no SGMII */
1457718e44b6SVladimir Oltean const struct sja1105_table_ops sja1105q_table_ops[BLK_IDX_MAX] = {
14587f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE] = {
14597f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_packing,
14607f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry),
14617f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY,
14627f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_COUNT,
14637f1e4ba8SVladimir Oltean 	},
14647f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS] = {
14657f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_points_entry_packing,
14667f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_entry),
14677f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_ENTRY,
14687f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_COUNT,
14697f1e4ba8SVladimir Oltean 	},
147094f94d4aSVladimir Oltean 	[BLK_IDX_VL_LOOKUP] = {
147194f94d4aSVladimir Oltean 		.packing = sja1105_vl_lookup_entry_packing,
147294f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_lookup_entry),
147394f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_LOOKUP_ENTRY,
147494f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_LOOKUP_COUNT,
147594f94d4aSVladimir Oltean 	},
147694f94d4aSVladimir Oltean 	[BLK_IDX_VL_POLICING] = {
147794f94d4aSVladimir Oltean 		.packing = sja1105_vl_policing_entry_packing,
147894f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_policing_entry),
147994f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_POLICING_ENTRY,
148094f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_POLICING_COUNT,
148194f94d4aSVladimir Oltean 	},
148294f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING] = {
148394f94d4aSVladimir Oltean 		.packing = sja1105_vl_forwarding_entry_packing,
148494f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_entry),
148594f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_ENTRY,
148694f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_FORWARDING_COUNT,
148794f94d4aSVladimir Oltean 	},
14888aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = {
14898aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_entry_packing,
14908aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_entry),
14918aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_ENTRY,
14928aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_COUNT,
14938aa9ebccSVladimir Oltean 	},
14948aa9ebccSVladimir Oltean 	[BLK_IDX_L2_POLICING] = {
14958aa9ebccSVladimir Oltean 		.packing = sja1105_l2_policing_entry_packing,
14968aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_policing_entry),
14978aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_POLICING_ENTRY,
14988aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_POLICING_COUNT,
14998aa9ebccSVladimir Oltean 	},
15008aa9ebccSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = {
15018aa9ebccSVladimir Oltean 		.packing = sja1105_vlan_lookup_entry_packing,
15028aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vlan_lookup_entry),
15038aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VLAN_LOOKUP_ENTRY,
15048aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VLAN_LOOKUP_COUNT,
15058aa9ebccSVladimir Oltean 	},
15068aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = {
15078aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_entry_packing,
15088aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_entry),
15098aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_ENTRY,
15108aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_COUNT,
15118aa9ebccSVladimir Oltean 	},
15128aa9ebccSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = {
15138aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_mac_config_entry_packing,
15148aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_mac_config_entry),
15158aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_MAC_CONFIG_ENTRY,
15168aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_MAC_CONFIG_COUNT,
15178aa9ebccSVladimir Oltean 	},
15187f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_PARAMS] = {
15197f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_params_entry_packing,
15207f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_params_entry),
15217f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_PARAMS_ENTRY,
15227f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_PARAMS_COUNT,
15237f1e4ba8SVladimir Oltean 	},
15247f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS_PARAMS] = {
15257f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_points_params_entry_packing,
15267f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_params_entry),
15277f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_PARAMS_ENTRY,
15287f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_PARAMS_COUNT,
15297f1e4ba8SVladimir Oltean 	},
153094f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING_PARAMS] = {
153194f94d4aSVladimir Oltean 		.packing = sja1105_vl_forwarding_params_entry_packing,
153294f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_params_entry),
153394f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_PARAMS_ENTRY,
153494f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_FORWARDING_PARAMS_COUNT,
153594f94d4aSVladimir Oltean 	},
15368aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = {
15378aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_params_entry_packing,
15388aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_params_entry),
15398aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_PARAMS_ENTRY,
15408aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_PARAMS_COUNT,
15418aa9ebccSVladimir Oltean 	},
15428aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = {
15438aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_params_entry_packing,
15448aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_params_entry),
15458aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY,
15468aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_PARAMS_COUNT,
15478aa9ebccSVladimir Oltean 	},
154824c01949SVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = {
154924c01949SVladimir Oltean 		.packing = sja1105pqrs_avb_params_entry_packing,
155024c01949SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_avb_params_entry),
155124c01949SVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_AVB_PARAMS_ENTRY,
155224c01949SVladimir Oltean 		.max_entry_count = SJA1105_MAX_AVB_PARAMS_COUNT,
155324c01949SVladimir Oltean 	},
15548aa9ebccSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = {
15558aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_general_params_entry_packing,
15568aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_general_params_entry),
15578aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_GENERAL_PARAMS_ENTRY,
15588aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_GENERAL_PARAMS_COUNT,
15598aa9ebccSVladimir Oltean 	},
156088cac0faSVladimir Oltean 	[BLK_IDX_RETAGGING] = {
156188cac0faSVladimir Oltean 		.packing = sja1105_retagging_entry_packing,
156288cac0faSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_retagging_entry),
156388cac0faSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_RETAGGING_ENTRY,
156488cac0faSVladimir Oltean 		.max_entry_count = SJA1105_MAX_RETAGGING_COUNT,
156588cac0faSVladimir Oltean 	},
15668aa9ebccSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = {
15678aa9ebccSVladimir Oltean 		.packing = sja1105_xmii_params_entry_packing,
15688aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_xmii_params_entry),
15698aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_XMII_PARAMS_ENTRY,
15708aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_XMII_PARAMS_COUNT,
15718aa9ebccSVladimir Oltean 	},
15728aa9ebccSVladimir Oltean };
15738aa9ebccSVladimir Oltean 
15748aa9ebccSVladimir Oltean /* SJA1105R: Second generation, no TTEthernet, SGMII */
1575718e44b6SVladimir Oltean const struct sja1105_table_ops sja1105r_table_ops[BLK_IDX_MAX] = {
15768aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = {
15778aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_entry_packing,
15788aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_entry),
15798aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_ENTRY,
15808aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_COUNT,
15818aa9ebccSVladimir Oltean 	},
15828aa9ebccSVladimir Oltean 	[BLK_IDX_L2_POLICING] = {
15838aa9ebccSVladimir Oltean 		.packing = sja1105_l2_policing_entry_packing,
15848aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_policing_entry),
15858aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_POLICING_ENTRY,
15868aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_POLICING_COUNT,
15878aa9ebccSVladimir Oltean 	},
15888aa9ebccSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = {
15898aa9ebccSVladimir Oltean 		.packing = sja1105_vlan_lookup_entry_packing,
15908aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vlan_lookup_entry),
15918aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VLAN_LOOKUP_ENTRY,
15928aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VLAN_LOOKUP_COUNT,
15938aa9ebccSVladimir Oltean 	},
15948aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = {
15958aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_entry_packing,
15968aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_entry),
15978aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_ENTRY,
15988aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_COUNT,
15998aa9ebccSVladimir Oltean 	},
16008aa9ebccSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = {
16018aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_mac_config_entry_packing,
16028aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_mac_config_entry),
16038aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_MAC_CONFIG_ENTRY,
16048aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_MAC_CONFIG_COUNT,
16058aa9ebccSVladimir Oltean 	},
16068aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = {
16078aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_params_entry_packing,
16088aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_params_entry),
16098aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_PARAMS_ENTRY,
16108aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_PARAMS_COUNT,
16118aa9ebccSVladimir Oltean 	},
16128aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = {
16138aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_params_entry_packing,
16148aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_params_entry),
16158aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY,
16168aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_PARAMS_COUNT,
16178aa9ebccSVladimir Oltean 	},
161824c01949SVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = {
161924c01949SVladimir Oltean 		.packing = sja1105pqrs_avb_params_entry_packing,
162024c01949SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_avb_params_entry),
162124c01949SVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_AVB_PARAMS_ENTRY,
162224c01949SVladimir Oltean 		.max_entry_count = SJA1105_MAX_AVB_PARAMS_COUNT,
162324c01949SVladimir Oltean 	},
16248aa9ebccSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = {
16258aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_general_params_entry_packing,
16268aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_general_params_entry),
16278aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_GENERAL_PARAMS_ENTRY,
16288aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_GENERAL_PARAMS_COUNT,
16298aa9ebccSVladimir Oltean 	},
163088cac0faSVladimir Oltean 	[BLK_IDX_RETAGGING] = {
163188cac0faSVladimir Oltean 		.packing = sja1105_retagging_entry_packing,
163288cac0faSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_retagging_entry),
163388cac0faSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_RETAGGING_ENTRY,
163488cac0faSVladimir Oltean 		.max_entry_count = SJA1105_MAX_RETAGGING_COUNT,
163588cac0faSVladimir Oltean 	},
16368aa9ebccSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = {
16378aa9ebccSVladimir Oltean 		.packing = sja1105_xmii_params_entry_packing,
16388aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_xmii_params_entry),
16398aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_XMII_PARAMS_ENTRY,
16408aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_XMII_PARAMS_COUNT,
16418aa9ebccSVladimir Oltean 	},
16428aa9ebccSVladimir Oltean };
16438aa9ebccSVladimir Oltean 
16448aa9ebccSVladimir Oltean /* SJA1105S: Second generation, TTEthernet, SGMII */
1645718e44b6SVladimir Oltean const struct sja1105_table_ops sja1105s_table_ops[BLK_IDX_MAX] = {
16467f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE] = {
16477f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_packing,
16487f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry),
16497f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY,
16507f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_COUNT,
16517f1e4ba8SVladimir Oltean 	},
16527f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS] = {
16537f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_points_entry_packing,
16547f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_entry),
16557f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_ENTRY,
16567f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_COUNT,
16577f1e4ba8SVladimir Oltean 	},
165894f94d4aSVladimir Oltean 	[BLK_IDX_VL_LOOKUP] = {
165994f94d4aSVladimir Oltean 		.packing = sja1105_vl_lookup_entry_packing,
166094f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_lookup_entry),
166194f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_LOOKUP_ENTRY,
166294f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_LOOKUP_COUNT,
166394f94d4aSVladimir Oltean 	},
166494f94d4aSVladimir Oltean 	[BLK_IDX_VL_POLICING] = {
166594f94d4aSVladimir Oltean 		.packing = sja1105_vl_policing_entry_packing,
166694f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_policing_entry),
166794f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_POLICING_ENTRY,
166894f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_POLICING_COUNT,
166994f94d4aSVladimir Oltean 	},
167094f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING] = {
167194f94d4aSVladimir Oltean 		.packing = sja1105_vl_forwarding_entry_packing,
167294f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_entry),
167394f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_ENTRY,
167494f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_FORWARDING_COUNT,
167594f94d4aSVladimir Oltean 	},
16768aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = {
16778aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_entry_packing,
16788aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_entry),
16798aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_ENTRY,
16808aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_COUNT,
16818aa9ebccSVladimir Oltean 	},
16828aa9ebccSVladimir Oltean 	[BLK_IDX_L2_POLICING] = {
16838aa9ebccSVladimir Oltean 		.packing = sja1105_l2_policing_entry_packing,
16848aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_policing_entry),
16858aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_POLICING_ENTRY,
16868aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_POLICING_COUNT,
16878aa9ebccSVladimir Oltean 	},
16888aa9ebccSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = {
16898aa9ebccSVladimir Oltean 		.packing = sja1105_vlan_lookup_entry_packing,
16908aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vlan_lookup_entry),
16918aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VLAN_LOOKUP_ENTRY,
16928aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VLAN_LOOKUP_COUNT,
16938aa9ebccSVladimir Oltean 	},
16948aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = {
16958aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_entry_packing,
16968aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_entry),
16978aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_ENTRY,
16988aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_COUNT,
16998aa9ebccSVladimir Oltean 	},
17008aa9ebccSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = {
17018aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_mac_config_entry_packing,
17028aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_mac_config_entry),
17038aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_MAC_CONFIG_ENTRY,
17048aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_MAC_CONFIG_COUNT,
17058aa9ebccSVladimir Oltean 	},
17067f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_PARAMS] = {
17077f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_params_entry_packing,
17087f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_params_entry),
17097f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_PARAMS_ENTRY,
17107f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_PARAMS_COUNT,
17117f1e4ba8SVladimir Oltean 	},
17127f1e4ba8SVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS_PARAMS] = {
17137f1e4ba8SVladimir Oltean 		.packing = sja1105_schedule_entry_points_params_entry_packing,
17147f1e4ba8SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_params_entry),
17157f1e4ba8SVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_PARAMS_ENTRY,
17167f1e4ba8SVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_PARAMS_COUNT,
17177f1e4ba8SVladimir Oltean 	},
171894f94d4aSVladimir Oltean 	[BLK_IDX_VL_FORWARDING_PARAMS] = {
171994f94d4aSVladimir Oltean 		.packing = sja1105_vl_forwarding_params_entry_packing,
172094f94d4aSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_params_entry),
172194f94d4aSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_PARAMS_ENTRY,
172294f94d4aSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_FORWARDING_PARAMS_COUNT,
172394f94d4aSVladimir Oltean 	},
17248aa9ebccSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = {
17258aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_l2_lookup_params_entry_packing,
17268aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_params_entry),
17278aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_L2_LOOKUP_PARAMS_ENTRY,
17288aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_PARAMS_COUNT,
17298aa9ebccSVladimir Oltean 	},
17308aa9ebccSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = {
17318aa9ebccSVladimir Oltean 		.packing = sja1105_l2_forwarding_params_entry_packing,
17328aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_params_entry),
17338aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY,
17348aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_PARAMS_COUNT,
17358aa9ebccSVladimir Oltean 	},
173624c01949SVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = {
173724c01949SVladimir Oltean 		.packing = sja1105pqrs_avb_params_entry_packing,
173824c01949SVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_avb_params_entry),
173924c01949SVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_AVB_PARAMS_ENTRY,
174024c01949SVladimir Oltean 		.max_entry_count = SJA1105_MAX_AVB_PARAMS_COUNT,
174124c01949SVladimir Oltean 	},
17428aa9ebccSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = {
17438aa9ebccSVladimir Oltean 		.packing = sja1105pqrs_general_params_entry_packing,
17448aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_general_params_entry),
17458aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_GENERAL_PARAMS_ENTRY,
17468aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_GENERAL_PARAMS_COUNT,
17478aa9ebccSVladimir Oltean 	},
174888cac0faSVladimir Oltean 	[BLK_IDX_RETAGGING] = {
174988cac0faSVladimir Oltean 		.packing = sja1105_retagging_entry_packing,
175088cac0faSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_retagging_entry),
175188cac0faSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_RETAGGING_ENTRY,
175288cac0faSVladimir Oltean 		.max_entry_count = SJA1105_MAX_RETAGGING_COUNT,
175388cac0faSVladimir Oltean 	},
17548aa9ebccSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = {
17558aa9ebccSVladimir Oltean 		.packing = sja1105_xmii_params_entry_packing,
17568aa9ebccSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_xmii_params_entry),
17578aa9ebccSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_XMII_PARAMS_ENTRY,
17588aa9ebccSVladimir Oltean 		.max_entry_count = SJA1105_MAX_XMII_PARAMS_COUNT,
17598aa9ebccSVladimir Oltean 	},
17608aa9ebccSVladimir Oltean };
17618aa9ebccSVladimir Oltean 
17623e77e59bSVladimir Oltean /* SJA1110A: Third generation */
17633e77e59bSVladimir Oltean const struct sja1105_table_ops sja1110_table_ops[BLK_IDX_MAX] = {
17643e77e59bSVladimir Oltean 	[BLK_IDX_SCHEDULE] = {
17653e77e59bSVladimir Oltean 		.packing = sja1110_schedule_entry_packing,
17663e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry),
17673e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_SCHEDULE_ENTRY,
17683e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_SCHEDULE_COUNT,
17693e77e59bSVladimir Oltean 	},
17703e77e59bSVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS] = {
17713e77e59bSVladimir Oltean 		.packing = sja1110_schedule_entry_points_entry_packing,
17723e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_entry),
17733e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_SCHEDULE_ENTRY_POINTS_ENTRY,
17743e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_COUNT,
17753e77e59bSVladimir Oltean 	},
17763e77e59bSVladimir Oltean 	[BLK_IDX_VL_LOOKUP] = {
17773e77e59bSVladimir Oltean 		.packing = sja1110_vl_lookup_entry_packing,
17783e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_lookup_entry),
17793e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_LOOKUP_ENTRY,
17803e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_VL_LOOKUP_COUNT,
17813e77e59bSVladimir Oltean 	},
17823e77e59bSVladimir Oltean 	[BLK_IDX_VL_POLICING] = {
17833e77e59bSVladimir Oltean 		.packing = sja1110_vl_policing_entry_packing,
17843e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_policing_entry),
17853e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_POLICING_ENTRY,
17863e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_VL_POLICING_COUNT,
17873e77e59bSVladimir Oltean 	},
17883e77e59bSVladimir Oltean 	[BLK_IDX_VL_FORWARDING] = {
17893e77e59bSVladimir Oltean 		.packing = sja1110_vl_forwarding_entry_packing,
17903e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_entry),
17913e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_ENTRY,
17923e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_VL_FORWARDING_COUNT,
17933e77e59bSVladimir Oltean 	},
17943e77e59bSVladimir Oltean 	[BLK_IDX_L2_LOOKUP] = {
17953e77e59bSVladimir Oltean 		.packing = sja1110_l2_lookup_entry_packing,
17963e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_entry),
17973e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_L2_LOOKUP_ENTRY,
17983e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_COUNT,
17993e77e59bSVladimir Oltean 	},
18003e77e59bSVladimir Oltean 	[BLK_IDX_L2_POLICING] = {
18013e77e59bSVladimir Oltean 		.packing = sja1110_l2_policing_entry_packing,
18023e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_policing_entry),
18033e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_POLICING_ENTRY,
18043e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_L2_POLICING_COUNT,
18053e77e59bSVladimir Oltean 	},
18063e77e59bSVladimir Oltean 	[BLK_IDX_VLAN_LOOKUP] = {
18073e77e59bSVladimir Oltean 		.packing = sja1110_vlan_lookup_entry_packing,
18083e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vlan_lookup_entry),
18093e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_VLAN_LOOKUP_ENTRY,
18103e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VLAN_LOOKUP_COUNT,
18113e77e59bSVladimir Oltean 	},
18123e77e59bSVladimir Oltean 	[BLK_IDX_L2_FORWARDING] = {
18133e77e59bSVladimir Oltean 		.packing = sja1110_l2_forwarding_entry_packing,
18143e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_entry),
18153e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_ENTRY,
18163e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_L2_FORWARDING_COUNT,
18173e77e59bSVladimir Oltean 	},
18183e77e59bSVladimir Oltean 	[BLK_IDX_MAC_CONFIG] = {
18193e77e59bSVladimir Oltean 		.packing = sja1110_mac_config_entry_packing,
18203e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_mac_config_entry),
18213e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_MAC_CONFIG_ENTRY,
18223e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_MAC_CONFIG_COUNT,
18233e77e59bSVladimir Oltean 	},
18243e77e59bSVladimir Oltean 	[BLK_IDX_SCHEDULE_PARAMS] = {
18253e77e59bSVladimir Oltean 		.packing = sja1110_schedule_params_entry_packing,
18263e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_params_entry),
18273e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_PARAMS_ENTRY,
18283e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_PARAMS_COUNT,
18293e77e59bSVladimir Oltean 	},
18303e77e59bSVladimir Oltean 	[BLK_IDX_SCHEDULE_ENTRY_POINTS_PARAMS] = {
18313e77e59bSVladimir Oltean 		.packing = sja1105_schedule_entry_points_params_entry_packing,
18323e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_schedule_entry_points_params_entry),
18333e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_SCHEDULE_ENTRY_POINTS_PARAMS_ENTRY,
18343e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_SCHEDULE_ENTRY_POINTS_PARAMS_COUNT,
18353e77e59bSVladimir Oltean 	},
18363e77e59bSVladimir Oltean 	[BLK_IDX_VL_FORWARDING_PARAMS] = {
18373e77e59bSVladimir Oltean 		.packing = sja1110_vl_forwarding_params_entry_packing,
18383e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_vl_forwarding_params_entry),
18393e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_VL_FORWARDING_PARAMS_ENTRY,
18403e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_VL_FORWARDING_PARAMS_COUNT,
18413e77e59bSVladimir Oltean 	},
18423e77e59bSVladimir Oltean 	[BLK_IDX_L2_LOOKUP_PARAMS] = {
18433e77e59bSVladimir Oltean 		.packing = sja1110_l2_lookup_params_entry_packing,
18443e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_lookup_params_entry),
18453e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_L2_LOOKUP_PARAMS_ENTRY,
18463e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_LOOKUP_PARAMS_COUNT,
18473e77e59bSVladimir Oltean 	},
18483e77e59bSVladimir Oltean 	[BLK_IDX_L2_FORWARDING_PARAMS] = {
18493e77e59bSVladimir Oltean 		.packing = sja1110_l2_forwarding_params_entry_packing,
18503e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_l2_forwarding_params_entry),
18513e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_L2_FORWARDING_PARAMS_ENTRY,
18523e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_L2_FORWARDING_PARAMS_COUNT,
18533e77e59bSVladimir Oltean 	},
18543e77e59bSVladimir Oltean 	[BLK_IDX_AVB_PARAMS] = {
18553e77e59bSVladimir Oltean 		.packing = sja1105pqrs_avb_params_entry_packing,
18563e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_avb_params_entry),
18573e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105PQRS_SIZE_AVB_PARAMS_ENTRY,
18583e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_AVB_PARAMS_COUNT,
18593e77e59bSVladimir Oltean 	},
18603e77e59bSVladimir Oltean 	[BLK_IDX_GENERAL_PARAMS] = {
18613e77e59bSVladimir Oltean 		.packing = sja1110_general_params_entry_packing,
18623e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_general_params_entry),
18633e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_GENERAL_PARAMS_ENTRY,
18643e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_GENERAL_PARAMS_COUNT,
18653e77e59bSVladimir Oltean 	},
18663e77e59bSVladimir Oltean 	[BLK_IDX_RETAGGING] = {
18673e77e59bSVladimir Oltean 		.packing = sja1110_retagging_entry_packing,
18683e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_retagging_entry),
18693e77e59bSVladimir Oltean 		.packed_entry_size = SJA1105_SIZE_RETAGGING_ENTRY,
18703e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_RETAGGING_COUNT,
18713e77e59bSVladimir Oltean 	},
18723e77e59bSVladimir Oltean 	[BLK_IDX_XMII_PARAMS] = {
18733e77e59bSVladimir Oltean 		.packing = sja1110_xmii_params_entry_packing,
18743e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1105_xmii_params_entry),
18753e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_XMII_PARAMS_ENTRY,
18763e77e59bSVladimir Oltean 		.max_entry_count = SJA1105_MAX_XMII_PARAMS_COUNT,
18773e77e59bSVladimir Oltean 	},
18783e77e59bSVladimir Oltean 	[BLK_IDX_PCP_REMAPPING] = {
18793e77e59bSVladimir Oltean 		.packing = sja1110_pcp_remapping_entry_packing,
18803e77e59bSVladimir Oltean 		.unpacked_entry_size = sizeof(struct sja1110_pcp_remapping_entry),
18813e77e59bSVladimir Oltean 		.packed_entry_size = SJA1110_SIZE_PCP_REMAPPING_ENTRY,
18823e77e59bSVladimir Oltean 		.max_entry_count = SJA1110_MAX_PCP_REMAPPING_COUNT,
18833e77e59bSVladimir Oltean 	},
18843e77e59bSVladimir Oltean };
18853e77e59bSVladimir Oltean 
sja1105_static_config_init(struct sja1105_static_config * config,const struct sja1105_table_ops * static_ops,u64 device_id)18868aa9ebccSVladimir Oltean int sja1105_static_config_init(struct sja1105_static_config *config,
18878aa9ebccSVladimir Oltean 			       const struct sja1105_table_ops *static_ops,
18888aa9ebccSVladimir Oltean 			       u64 device_id)
18898aa9ebccSVladimir Oltean {
18908aa9ebccSVladimir Oltean 	enum sja1105_blk_idx i;
18918aa9ebccSVladimir Oltean 
18928aa9ebccSVladimir Oltean 	*config = (struct sja1105_static_config) {0};
18938aa9ebccSVladimir Oltean 
18948aa9ebccSVladimir Oltean 	/* Transfer static_ops array from priv into per-table ops
18958aa9ebccSVladimir Oltean 	 * for handier access
18968aa9ebccSVladimir Oltean 	 */
18978aa9ebccSVladimir Oltean 	for (i = 0; i < BLK_IDX_MAX; i++)
18988aa9ebccSVladimir Oltean 		config->tables[i].ops = &static_ops[i];
18998aa9ebccSVladimir Oltean 
19008aa9ebccSVladimir Oltean 	config->device_id = device_id;
19018aa9ebccSVladimir Oltean 	return 0;
19028aa9ebccSVladimir Oltean }
19038aa9ebccSVladimir Oltean 
sja1105_static_config_free(struct sja1105_static_config * config)19048aa9ebccSVladimir Oltean void sja1105_static_config_free(struct sja1105_static_config *config)
19058aa9ebccSVladimir Oltean {
19068aa9ebccSVladimir Oltean 	enum sja1105_blk_idx i;
19078aa9ebccSVladimir Oltean 
19088aa9ebccSVladimir Oltean 	for (i = 0; i < BLK_IDX_MAX; i++) {
19098aa9ebccSVladimir Oltean 		if (config->tables[i].entry_count) {
19108aa9ebccSVladimir Oltean 			kfree(config->tables[i].entries);
19118aa9ebccSVladimir Oltean 			config->tables[i].entry_count = 0;
19128aa9ebccSVladimir Oltean 		}
19138aa9ebccSVladimir Oltean 	}
19148aa9ebccSVladimir Oltean }
19156666cebcSVladimir Oltean 
sja1105_table_delete_entry(struct sja1105_table * table,int i)19166666cebcSVladimir Oltean int sja1105_table_delete_entry(struct sja1105_table *table, int i)
19176666cebcSVladimir Oltean {
19186666cebcSVladimir Oltean 	size_t entry_size = table->ops->unpacked_entry_size;
19196666cebcSVladimir Oltean 	u8 *entries = table->entries;
19206666cebcSVladimir Oltean 
19216666cebcSVladimir Oltean 	if (i > table->entry_count)
19226666cebcSVladimir Oltean 		return -ERANGE;
19236666cebcSVladimir Oltean 
19246666cebcSVladimir Oltean 	memmove(entries + i * entry_size, entries + (i + 1) * entry_size,
19256666cebcSVladimir Oltean 		(table->entry_count - i) * entry_size);
19266666cebcSVladimir Oltean 
19276666cebcSVladimir Oltean 	table->entry_count--;
19286666cebcSVladimir Oltean 
19296666cebcSVladimir Oltean 	return 0;
19306666cebcSVladimir Oltean }
19316666cebcSVladimir Oltean 
19326666cebcSVladimir Oltean /* No pointers to table->entries should be kept when this is called. */
sja1105_table_resize(struct sja1105_table * table,size_t new_count)19336666cebcSVladimir Oltean int sja1105_table_resize(struct sja1105_table *table, size_t new_count)
19346666cebcSVladimir Oltean {
19356666cebcSVladimir Oltean 	size_t entry_size = table->ops->unpacked_entry_size;
19366666cebcSVladimir Oltean 	void *new_entries, *old_entries = table->entries;
19376666cebcSVladimir Oltean 
19386666cebcSVladimir Oltean 	if (new_count > table->ops->max_entry_count)
19396666cebcSVladimir Oltean 		return -ERANGE;
19406666cebcSVladimir Oltean 
19416666cebcSVladimir Oltean 	new_entries = kcalloc(new_count, entry_size, GFP_KERNEL);
19426666cebcSVladimir Oltean 	if (!new_entries)
19436666cebcSVladimir Oltean 		return -ENOMEM;
19446666cebcSVladimir Oltean 
19456666cebcSVladimir Oltean 	memcpy(new_entries, old_entries, min(new_count, table->entry_count) *
19466666cebcSVladimir Oltean 		entry_size);
19476666cebcSVladimir Oltean 
19486666cebcSVladimir Oltean 	table->entries = new_entries;
19496666cebcSVladimir Oltean 	table->entry_count = new_count;
19506666cebcSVladimir Oltean 	kfree(old_entries);
19516666cebcSVladimir Oltean 	return 0;
19526666cebcSVladimir Oltean }
1953