Indexing of touch-sensing analog groups is inconsistent
Opened this issue · 4 comments
Depending on the specific STM32 device, the Touch-Sensing Controller (TSC) supports up to 8 analog groups. These groups are labeled 1 through 8, in multiple places:
- In the reference manual by ST
- In the
IOSCR
andIOCCR
registers, with thegX_ioY
bits (where X is the group number) - In the
IOGCSR
register, with thegXe
andgXs
bits (where X is the group number). - And in the output
IOGxCR
register, where x is the group number
In the reference manual and in stm32-metapac, the convention is that groups are named 1 through 6 (or 8, depending on the device). However, stm32-metapac exposes an (otherwise convenient) function iogcr(n)
to retrieve the IOGxCR register of a given group, and this specific function uses a 0-based index. This is very inconsistent. For example, to enable then read the first analog group, one would currently need to write:
TSC.iogcsr().modify(|v|{
v.set_g1e(true);
}
TSC.iogcr(0).read().cnt();
Notice how we have to use the value of 1
on the first block and 0
in the second.
I would suggest making the iogcr()
function use a 1-based index. Maybe a patch like this would work:
data/registers/tsc_v1.yaml
- name: IOGCR
description: I/O group x counter register.
array:
- len: 6
+ len: 7
stride: 4
- byte_offset: 52
+ byte_offset: 48
Might not be the cleanest though (it wouldn't yield an error on iogcr(0)
), but at least it's easy to implement. If this is something you'd be interested in, I'd be happy to provide a PR.
Actual indices (handled in the code as usize
s) should be always 0-based, otherwise usage becomes much more complicated. For example if the user creates an array to store state per channel they either have to waste RAM for the unused 0th index, or remember to add/subtract 1 every time.
ST loves to use 1-based names, we already live with this inconsistency in many places. For example "DMA channel 1" is index 0, etc.
In this particular case, it seems to me all the gX_ioY, gXe, gXs bits could (should!) be turned into arrays, making them 0-based, so there's no inconsistency anymore within the PAC.
Smart. Indeed I don't mind too much the ST/PAC inconsistency. I do mind the inconsistency within the PAC though.
I think I might be able figure out on my own how to convert the gXe
and gXs
bits into arrays, but would you have any pointers on how to convert the gX_ioY
bits into two-dimensional arrays?
into two-dimensional arrays?
ah, indeed this is not supported in chiptool :( you can do it for registers by using blocks, but you can't do it for bits within a fieldset.
we could add it, or we could arrayify only one dimension and just rename the fields in the other to be 0-based.