esp-homekit-demo
Demo of Apple HomeKit accessory server library.
Usage
- Initialize and sync all submodules (recursively):
git submodule update --init --recursive
-
Copy wifi.h.sample -> wifi.h and edit it with correct WiFi SSID and password.
-
Install esp-open-sdk, build it with
make toolchain esptool libhal STANDALONE=n
, then edit your PATH and add the generated toolchain bin directory. The path will be something like /path/to/esp-open-sdk/xtensa-lx106-elf/bin. (Despite the similar name esp-open-sdk has different maintainers - but we think it's fantastic!) -
Install esptool.py and make it available on your PATH. If you used esp-open-sdk then this is done already.
-
Checkout esp-open-rtos and set SDK_PATH environment variable pointing to it.
-
Configure settings:
- If you use ESP8266 with 4MB of flash (32m bit), then you're fine. If you have 1MB chip, you need to set following environment variables:
export FLASH_SIZE=8 export HOMEKIT_SPI_FLASH_BASE_ADDR=0x7a000
- If you're debugging stuff, or have troubles and want to file issue and attach log, please enable DEBUG output:
export HOMEKIT_DEBUG=1
- Depending on your device, it might be required to change the flash mode:
export FLASH_MODE=dout
(see issue #80)
-
Build example:
make -C examples/led all
- Set ESPPORT environment variable pointing to USB device your ESP8266 is attached to (assuming your device is at /dev/tty.SLAB_USBtoUART):
export ESPPORT=/dev/tty.SLAB_USBtoUART
- To prevent any effects from previous firmware (e.g. firmware crashing right at start), highly recommend to erase flash:
make -C examples/led erase_flash
- Upload firmware to ESP:
make -C examples/led test
or
make -C examples/led flash
make -C examples/led monitor
ESP32
- Initialize and sync all submodules (recursively):
git submodule update --init --recursive
-
Copy wifi.h.sample -> wifi.h and edit it with correct WiFi SSID and password.
-
Install esp-idf by following instructions on esp-idf project page. At the end you should have xtensa-esp32-elf toolchain in your path and IDF_PATH environment variable pointing to esp-idf directory.
-
Configure project:
make -C examples/esp32/led menuconfig
There are many settings there, but at least you should configure "Serial flasher config -> Default serial port". Also, check "Components -> HomeKit" menu section.
- Build example:
make -C examples/esp32/led all
- To prevent any effects from previous firmware (e.g. firmware crashing right at start), highly recommend to erase flash:
make -C examples/led erase_flash
- Upload firmware to ESP32:
make -C examples/led flash
make -C examples/led monitor