2022-05-30 1:53 AM
Hi All,
we are evaluating the possibilty to use a BiSS-C encoder in our project. First time using BiSS-C.
From the BiSS-C standard it seems to me that BiSS-C can be implemented at STM32 level by mean of an SPI peripheral connected to an Rs422 transceiver.
Things that is bugging me is that BiSS-C frame seems to not be aligned to 8-bit boundary (e.g. to transfer 26-bits exactly 26 clock pulses have to be yielded) so SPI cannot be fit for this application.
Does anyone already implemented BiSS-C interface with STM32? How to?
Thanks in advance for your support,
Bucky
2022-05-30 4:09 AM
Which STM32, there's hundreds, some support alternative bit lengths.
The F7 should support 13-bit words, so two words would clock 26-bits.
Others yes, you'd probably need to bit-bang the interface to get quirky counts, or find some least common denominator
2022-05-30 7:20 AM
It's not that uncommon for SPI masters to be restricted to multiples of 8 bits so, presumably, the same problem must exist beyond STM32?
Are you sure that extra clocks are strictly not allowed?
Could you look at using a USART in sync mode?
What does the encoder manufacturer suggest?
As @Community member says, bit-banging gives you ultimate control...
2022-05-30 8:12 AM
Hi All,
thanks for the answers.
The target uC is STM32G474RE but, as pointed out by @Andrew Neil, it's rather common that SPI yield data aligned to 8-bit boundary.
Extra Clock pulses cannot be fed to encoder device (at least as last as I've understood) and the manufacturer doesn't suggest anything since it specifies to comply to BiSS-C interface (and that's all).
The issue is present also with other Silicon Vendor (exception done Texas Ins.) but we intend to use STM32 to reuse code from previous projects and also for strong knowledge base that we built up during those years.
Does a reference design for BiSS-C interface is available for STM32?
Thanks again for your support,
Bucky
2022-05-30 9:36 AM
Maybe BiSS Association can help?
https://biss-interface.com/support/
Seems that many are using FPGA, and interface chips are available:
https://biss-interface.com/c/products/integrated-circuits/
https://biss-interface.com/c/products/support-services/
2023-04-13 1:00 PM - edited 2023-11-20 8:24 AM
I found a good solution to read BiSS-C/BIS3 packets over a SPI bus. In my case I am reading 30 bits from a Zettlex Inductive Encoder into a Nucleo-G474RE STM32 development board. The Reference Manual (RM0440 Rev 7) has a subsection in section 39.5.9 called "Sequence Handling" that mentions how to get the clock to run as long as you need until you get any number of bits that you want:
"In receive-only modes, half-duplex (BIDIMODE=1, BIDIOE=0) or simplex (BIDIMODE=0, RXONLY=1) the master starts the sequence immediately when both SPI is enabled and receive-only mode is activated. The clock signal is provided by the master and it does not stop until either SPI or receive-only mode is disabled by the master. The master receives data frames continuously up to this moment."
I set my data size to 8 bits. I call HAL_SPI_Receive(&hspi, pdata, 6, 1000) to receive 48 bits (just needs to be more than 30 bits). Now can I parse through the returned pdata array and pull out the data bits, nE/nW bits, and CRC bits as I need them. See the included Logic Analyzer image to see how the data is the same no matter if it's analyzed as BiSS-C or SPI. Just needs to be a bit massaged (pun intended).
Good luck!
Spencer
Reference Manual for STM32G4:
2023-09-03 12:36 AM
Hi
I am doing a project with BISS-C to read the position. Are you willing to share your code?
thanks.
2024-10-02 9:55 AM
Hi, I have to do the same, but he problem I don't know how to stop the clock. Maybe cou can help me?
2024-10-02 9:56 AM
Hi, did you find the solution? if yes can you share it with me please?
2025-07-10 4:03 AM
BiSS C encoders can happily accept more clock pulses than written in the documentation. After last important bit is transmitted, everything else will be some kind of garbage, either repetition of last 8 or 16 bits, or all 0, or all 1. It does not matter, you simply ignore the rest.
How to read BiSS C encoder with a microcontroller:
1. Wire the encoder through RS422 tranceiver chip to SPI SCK & MISO lines. MOSI and CS are left unconnected.
2. Set-up correct CPHA and CPOL. Set-up DMA or interrupt-driven transmission. Total data length must cover full encoder's frame, including ACK phase.
3. Start the SPI and send out all 0; it will receive data from the encoder.
4. Make sure data transmission is stopped for more than required Timeout duration - typically 20 us. This will reset the encoder's interface.
5. Shift through the received data bit by bit, search for ACK-START-CDS (sequence 010). This will mark the beginning of the real data.
6. Extract Position, Error, Warning, CRC. See document: https://www.rls.si/eng/media-center?search=e201d02#documentation
7. Calculate CRC. See document: https://www.rls.si/eng/media-center?search=crc
For any issues with CRC you can use my calculator tool: https://www.rls.si/eng/media-center?search=crc
Written by the BiSS C encoder manufacturer.
