On Wed, 27 Jul 2022 13:30:54 +0200 Marc Kleine-Budde <mkl@xxxxxxxxxxxxxx> wrote: > As far as I understand, setting the btr is an alternative way to set the > bitrate, right? I don't like the idea of poking arbitrary values into a > hardware from user space. I agree with Marc here. This is a modification across the whole stack, specific to a single device, when there are ways around. If I understand correctly, the CAN232 "S" command sets one of the fixed bitrates, whereas "s" sets the two BTR registers. Now the question is, what do BTR0/BTR1 mean, and what are they? If they are merely a divider in a CAN controller's master clock, like in ELM327, then you could a) Calculate the BTR values from the bitrate userspace requests, or b) pre-calculate a huge table of possible bitrates and present them all to userspace. Sounds horrible, but that's what I did in can327, haha. Maybe I should have reigned them in a little, to the most useful values. c) just limit the bitrates to whatever seems most useful (like the "S" command's table), and let users complain if they really need something else. In the meantime, they are still free to slcand or minicom to their heart's content before attaching slcan, thanks to your backwards compatibility efforts. In short, to me, this isn't a deal breaker for your patch series. Max