-
Notifications
You must be signed in to change notification settings - Fork 7.5k
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 Slave not implemented #118
Comments
did you find a solution for that issue? |
no news? i've done with esp-idf but arduino way is simpler and clearer |
@stickbreaker is working on slave I2C (https://github.com/stickbreaker/arduino-esp32/tree/master/libraries/Wire). Not sure where he is at with it, but development is active. |
Found out it...
many errors in compile...
Il 14/05/2018 15:14, lbernstone ha scritto:
…
@stickbreaker <https://github.com/stickbreaker> is working on slave
I2C
(https://github.com/stickbreaker/arduino-esp32/tree/master/libraries/Wire).
Not sure where he is at with it, but development is active.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#118 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AHSe24shLRHFJIzYM4QyD6lNilDrSxa3ks5tyYMagaJpZM4LbtDd>.
--
Marco Lettieri
Head of Developments
microBees Technology Ltd
|
Updates? |
I've got a working Slave mode, but I am still working through coexistence with Master mode. Slave mode on ESP32 has to call
It is base on a re-implementation of Chuck. |
Hi @stickbreaker , Any news ? |
BUMP! Anyone have a slave receive solution/fix/workaround? |
BUMP! Surely there must be enough demand for this feature to warrant some serious development from those that know how? |
Update? How can we help? |
Any Update This issues? |
@JAICHANGPARK i2c slave does work on the Arduino Uno. This issue is for ESP32. |
@ameer1234567890 I already know. |
Any updates? Or example how to workaround that issue? |
Please help, I also need to use an ESP32 in slave mode but get this error: |
Thanks for your efforts Chuck. Another bump for i2c as a slave mode when you have a chance. Would be really useful. |
@netkruzer Not ready yet. It's not yet code that I want my name attached to. And, I do not want to even think of supporting it as is. Chuck. |
Darn, I'm also wanting this feature.. |
@stickbreaker Hi Chuck. Any date in the foreseeable future that you can provide to have a release of the I2C solution for ESP32? I have been dreaming for a while to use it for some projects I have. Let us know! Thanks |
It was reported on #1697 by @laercionit that "Someone had succeeded in putting as SLAVE?" Any details on this? |
I couldn't ... I don't think TwoWire is ready for that. |
I have made a workaround library not based on interrupts, but based on the only two slave methods currently available from ESP-IDF. |
If you are still interested, I2C Slave is on the way: #5746 |
@me-no-dev awesome |
Interesting - will it be proper implementation using ESP32 hardware or some workaround on software level? |
Yep - still very interested in having the esp32 as a slave - and it to be able to get a read request, then live get data and send it back - without polling etc etc. ie what the 328P can easily do.. It really should have been able to do it on the first release - as I said above, at least the serial port guys did it right... OK, it is calling i2c_slave_attach_callbacks - which sounds promising. It's in esp32-hal-i2c-slave.h esp_err_t i2c_slave_attach_callbacks(uint8_t num, i2c_slave_request_cb_t request_callback, i2c_slave_receive_cb_t receive_callback, void * arg); Which looks like it is doing something similar to the uarts - ie interrupts and queues, using some things I didn't know existed to do some of the i2c stuff ie This call looks interesting too i2c_ll_write_txfifo (out of components/soc/src/esp32/include/hal/i2c_ll.h) So prob my fault, but I hadn't know some of these calls existed.. But using what's about to be committed as an example it looks like we might be able to write what is needed! |
So... the ESP32 I2C peripheral does not support clock stretching when in Slave Mode. Therefore, by the time that you get the event and fill the fifo, transaction has already been started and if there were bytes in the FIFO, those would have started sending, else NACK has been sent. What you ask for DOES work on ESP32-S2 and onward, but not on ESP32. |
OK, so you are saying that the esp32 won't be supporting the full i2c slave model - but the s2 onwards will. That's grreat, as I could move to the s2 for the slave, and will prob be going to the s3 generally anyway (more pins!) - price willing. Of course, I could just write a bit banging slave for the esp32 - looking at the above code late last night I was assuming that was what you had half done, otherwise you can't support Wire.onRequest(requestEvent); - as it of course generates the bytes to be returned to the master.. So is the above code only for the -s2 and onwards? |
it work on all chips, but on ESP32 it just behaves a bit differently. You need to pre-load the data that the master will be able to read. ESP32 as master is also not liking having the clock stretched for too long. Let's say you use S2 as Slave and ESP32 as Master. The slave needs to handle the onRequest as fast as possible to ensure that the ESP32 will not give up waiting for the clock to stop stretching. |
yes, so it doesn't work on the esp32. Preloading the data IS the core issue and has been since the esp32 was released - preloading is no good for many many many things. No point the master getting data that might be very old.. And yes, onRequest (or whatever it is called as I don't use the ardunio wire library) is always done fast. Typically you just copy the data from somewhere safe, and then exit. You never do any work in it... |
I would not call it that big of an issue really... you can use one GPIO on the Slave to signal that there is new data (like many sensors work) and then release the IO in |
you're making a lot of assumptions with that ie 1) that there is a pin free (A real big problem..), 2) that you want the master interrupt driven (I agree sometimes useful), and 3) it might be the master knows when it wants a value, not the slave, and then (of course) it wants the most recent one. ie at times you want the master to be the master.. I'm putting another device into a product now that has interrupt pins, and I can i2c read it. I'm not using the interrupt pins. |
I'm giving you options. not making assumptions :D |
I'm just glad you fixed the hardware with the later versions - as it was a mistake with the esp32. I could still do a software one for the esp32 - I just haven't had time. The esp32 is easily fast enough. |
* Rework the lib-builder for ESP-IDF v5.1 * Update package json with tolls matching the ESP-IDF version * fix: rainmaker examples crashing on s3 due to low stack memory. (espressif#106) (espressif#107) * Update scripts with the latest requirements * Update configs + SR Support * Add esp-elf-gdp to the list of packages * Fix RainMaker builds and new sr models path * Temporary force arduino branch for CI to work * fix target branch * Delete esp-dl component manifest for requiring IDF 4.4.x * Temporary changes to allow Cron CI to run * Support builds based on ESP-IDF tag * Push to esp32-arduino-libs * Update repository_dispatch.sh * Rework scripts to allow build when either dst needs it * Github complains when pushing to the libs repo * Authenticate to the libs repo * Attempt at splitting SDK from Arduino * Archive only the result and reorder deploy commands * Update cron.sh * Fix script and zip paths * Fix download URL and json merger * Change sdk folder structure and fix json generation * Switch output folder from sdk to esp32-arduino-libs * arduino_tinyusb: compile support for DFU mode (espressif#116) * Update PlatformIO build script templates (espressif#118) Adds support for new package with precompiled SDK libraries * Autogenerate PlatformIO manifest file for prebuilt SDK libs (espressif#119) * Autogenerate PlatformIO manifest file for prebuilt SDK libs - Add a special Python script that generates "package.json" with IDF revision from the "version.txt" according to SemVer * Tidy up * Refactor manifest generator Now IDF version and commit hash are passed directly from Git client instead of reading from a pregenerated "version.txt" file * Move IDF definitions to be available with any build * Use more components from registry and add mp3 decoder * esp-sr component requires clearing before each build * revert ESP_SR from component manager * Build ESP_SR only for ESP32-S3 for now * [TinyUSB] Update esp32sx dcd and add dwc2 option * Workaround for recent change in ESP-Insights * Add initial support for ESP32-C6 * Run build tests on ESP32-C6 * Remove -mlongcalls for non-xtensa chips * Temp fix for ESP-Insights on C6 * Add support for ESP32H2 * Added tflite-micro component (espressif#128) * Update build badge in README.md * Added tflite-micro component --------- Co-authored-by: Me No Dev <[email protected]> * Make cron rebuild the libs if they need to be pushed to Arduino For when we change something in the lib-builder, but no new updates are available in ESP-IDF * Update build actions * Fix permissions * Do not build for obsolete Flash modes * Try separate detect for cron builds * Add permissions to github api * Try more basic commit detection * another try to pass vars and get commit * Update push.yml * Update config.sh * Enable builds again * Update build.sh * Combine the artifacts from all jobs * fix and test deploy check * Update push.yml * Disable Memprot to allow loading external elfs * Fix archive name * Disable coredump to flash * Enable SPI ETH KSZ8851SNL * Add temporary support for Arduino SPI Ethernet * Add a temporary fix for relative include in BT lib * Enable Classic BT HID Host and Device for ESP32 * Revert "Enable Classic BT HID Host and Device for ESP32" This reverts commit aa0040ad271d00ac507fd2b478ee143b6c118615. * C6 was added to ESP-SR * Update Ethernet and remove SR workaround * Pin RainMaker version * Update target branch * Add back cron.sh --------- Co-authored-by: Sanket Wadekar <[email protected]> Co-authored-by: Luca Burelli <[email protected]> Co-authored-by: Valerii Koval <[email protected]>
README update
Description
It seams that the I2C slave functionality from the Arduino Wire Lib is not implemented.
Code example
Error occured during compilation
EDIT: Fixed errror message.
The text was updated successfully, but these errors were encountered: