-
-
Notifications
You must be signed in to change notification settings - Fork 100
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
i2c address on mainline kernels #80
Comments
This could also be a kernel bug, I haven't checked with the mailing list at all to find out. |
This also appears to be Pi4 specific as the pi3 only shows i2c-{0,1,2} |
Is the patch I'm currently using; this isn't likely correct, and should probably do some detection of if on a mainline vs raspbian kernel, but as far as I know, there isn't an "easy" way to do that. I was thinking something along the lines of (pseudo code) |
Thanks for reporting this issue. I'm not sure why you would see i2c-3 on those pins, other than because of a configuration issue in I'll have to take a deeper look and figure out what's causing it. You could try to manually assign i2c1 and i2c3 through |
Yeah, I'm not entirely sure how to set it in config.txt with the mainline kernel, or the interaction between the mainline kernel and it. e.g. i don't have The kernel command line And like my other comment says, it works fine on the Pi3 (same card) - so it's definitely specific to the Pi4 on mainline. |
Considering i2c3 is a valid I2C bus for those pins, even though it's not the one that should be set by default, I'll add a check for it for the Raspberry Pi 4 when i2c1 isn't available. |
This has been fixed in the current master branch, and will be part of the upcoming 0.12.0 release. |
Version 0.12.0 is now live. Once PiSugar PowerManager switches over to using 0.12.0, that should fix your issue. |
Thanks! In looking closer, it seems the Raspbian kernel deletes an i2c node, and mainline kernels do not do so, on the Pi4, so it could be that that is why. I'm trying to free up some time to test if that actually works on a mainline kernel or not, to force it back to i2c-1. |
I tested the deleting the i2c node and that didn't work - I also bumped rppal locally, and that didn't work either - so i cloned rppal and swapped the logic, testing bus 3 first, and falling back to 1 if it fails, and that works. Could it be because i2c-1 also exists on the rpi4 with mainline kernel?
|
On the PI 4B, i2c1 can be bound to either the default pins, or to the (internal) GPIO lines 44 and 45, which is likely happening in your case. Unfortunately I can't switch the checks, because someone could theoretically have set up i2c3 on GPIO 4 and 5, and i2c3 on GPIO 2 and 3, so that would enable the wrong I2C bus by default. This sounds like something that needs to be changed in the mainline kernel, since it doesn't really make sense to have a different I2C bus bound to GPIO2 and GPIO3 by default. I could add a check like you mentioned, although I'm not quite sure how to check if we're running a mainline kernel or Raspberry Pi OS/Raspbian. I'll re-open this issue for now until we can get this resolved. |
Actually, could you show me the output of |
And while we're at it, |
lsb_release -a:
Note: this is NOT a common setup - this is done by me using the same scripts that Debian uses to create theirs, just pointed at our (I'm a Kali dev) repos instead of debian's, and using our 5.10 kernel instead of the usual raspberry pi foundation's kernel. But it would be the same as a debian setup from https://wiki.debian.org/RaspberryPiImages |
Let's try a different approach, as basing the selection on which kernel is used could lead to problems down the road when this configuration issue is fixed. Instead, I'd like to see if I can check the mode the relevant pins (GPIO2 and GPIO3 for physical pins 3 and 5) are set to. Normally this should be easy enough, but it relies on the GPIO peripheral being configured properly by default, which I have my doubts about considering these I2C issues. I'm not sure how experienced you are in using Rust, so to keep things simple, and since you already have rppal cloned locally, can you run the gpio_status example with |
I only know enough rust to be dangerous. Not enough to write my own app, but enough to poke at others :D That said... here is the output:
|
Thanks for testing that. While it's great that works, the results are odd to say the least. Did you run that on the Pi where I2C3 has to be selected? Because that output indicates GPIO2 and 3 are configured as ALT0, which would mean I2C1 is active on those pins, so needing to use If that's the case, I'm afraid there's not much I can do with rppal. I can't rely on checking if you're on the mainline kernel, since this bug might be fixed in the future which would result in rppal returning the wrong bus. I can't rely on checking which I2C bus is active on those pins, because linux is using an incorrect numbering scheme in your case. I think your best bet is to get this addressed in the mainline kernel, and until that's fixed, fork PiSugar PowerManager and instead of using the |
This is indeed on a Pi4 8GB, with the pisugar 2 pro connected to it, using the debian/kali 5.10 kernel. I'll definitely send a mail to the i2c/rpi kernel mailing lists to figure out what is going on. I'm definitely not an i2c expert by any stretch of the imagination, and I'm not sure what is going on either. Based on a look at https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/log/drivers/i2c/busses/i2c-bcm2835.c - the i2c driver hasn't been touched since September of 2020, so it has been broken for a long while. I'll be using the output of the example in my mail to the mailing list as well, so thank you for that! |
For what it's worth, I ran the example on a different rpi 4 8GB (with the raspberrypi foundation 5.10 kernel) and the output is slightly different:
|
The differences on the other pins can be explained as either Raspberry Pi OS having a different default configuration where some peripherals are enabled by default, or changes made manually through either If you're curious what those alternate functions do, check out chapter 5.3 in https://datasheets.raspberrypi.org/bcm2711/bcm2711-peripherals.pdf |
On a mainline kernel (5.10) using an rpi4, the i2c address ends up being i2c-3 and not i2c-0 or i2c-1. This causes errors like
Invalid slave address: 117
orInvalid slave address: 50
- I did a clone locally and changed the line that sets the address to 1 to be 3 and things work here. I reported this downstream to the PiSugar PowerManager repository at PiSugar/pisugar-power-manager-rs#24 - I'm no rust expert and I'm not sure the best way to go about properly fixing this aside from forking the repository.The text was updated successfully, but these errors were encountered: