[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <87sed1shwl.fsf@prevas.dk>
Date: Tue, 23 Dec 2025 09:48:26 +0100
From: Rasmus Villemoes <ravi@...vas.dk>
To: Daniel Golle <daniel@...rotopia.org>
Cc: netdev@...r.kernel.org, "Benny (Ying-Tsan) Weng" <yweng@...linear.com>
Subject: question on gswip_pce_table_entry_write() in lantiq_gswip_common.c
Hi
Reading gswip_pce_table_entry_write() in lantiq_gswip_common.c, I'm
wondering if it really has to do all that it does. In particular, it
seems to write the same value to (a subset of) the GSWIP_PCE_TBL_CTRL
reg twice, then it reads the reg value back, manually tweaks the
remaining bits appropriately and folds in the "start access bit", then
writes the whole value to the register.
Why couldn't that be done by reading the register, do all the masking
and bit setting, then doing a single write of the whole thing?
The data sheet doesn't say anything about this complicated scheme being
necessary.
Another thing: I'd really appreciate it if someone could point me to
documentation on the various tables, i.e. what does val[2] of an entry
in GSWIP_TABLE_VLAN_MAPPING actually mean? I can see that BIT(port) is
either set or cleared from it depending on 'untagged', so I can
sort-of-guess, but I'd prefer to have it documented so I don't have to
guess. AFAICT, none of the documents I can download from MaxLinear spell
this out in any way.
Rasmus
Powered by blists - more mailing lists