惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

F
Full Disclosure
V
Vulnerabilities – Threatpost
Attack and Defense Labs
Attack and Defense Labs
N
News and Events Feed by Topic
SecWiki News
SecWiki News
S
Security @ Cisco Blogs
Schneier on Security
Schneier on Security
B
Blog
TaoSecurity Blog
TaoSecurity Blog
The Last Watchdog
The Last Watchdog
H
Hacker News: Front Page
Hacker News - Newest:
Hacker News - Newest: "LLM"
博客园_首页
D
Docker
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Y
Y Combinator Blog
W
WeLiveSecurity
N
News and Events Feed by Topic
F
Fortinet All Blogs
PCI Perspectives
PCI Perspectives
WordPress大学
WordPress大学
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Recent Announcements
Recent Announcements
Forbes - Security
Forbes - Security
T
Tailwind CSS Blog
Hacker News: Ask HN
Hacker News: Ask HN
爱范儿
爱范儿
腾讯CDC
Last Week in AI
Last Week in AI
月光博客
月光博客
C
Cybersecurity and Infrastructure Security Agency CISA
P
Proofpoint News Feed
Help Net Security
Help Net Security
V
V2EX
C
Cyber Attacks, Cyber Crime and Cyber Security
C
CXSECURITY Database RSS Feed - CXSecurity.com
H
Heimdal Security Blog
L
LINUX DO - 最新话题
GbyAI
GbyAI
The Hacker News
The Hacker News
罗磊的独立博客
S
SegmentFault 最新的问题
H
Hackread – Cybersecurity News, Data Breaches, AI and More
博客园 - 【当耐特】
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
V2EX - 技术
V2EX - 技术
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
O
OpenAI News
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻

Show HN

CSP Radar GitHub - awebai/aweb-team-coord-worktrees: An aweb team template for a minimum team with a permanent coordinator and worktrees with local developers. GitHub - fujibee/agmsg GitHub - lucastononro/notify: 100% local, free, offline attention skill for Claude Code: plays a sound and speaks a short status update when a long task finishes, blocks, or needs a decision. GitHub - sebastianwessel/skills: AI Skills tivatdoar / workout-to-work · GitLab GitHub - enumura1/py-sql-cleaner: Find, format, and safely extract embedded SQL from Python files. GitHub - intent-bench/intent-bench: Intent fulfillment benchmark for agentic AI engineering GitHub - steveking-gh/firmion: Firmion is DSL and engine for firmware image generation. GitHub - villagesql/villagesql-skills: Agent skills for VillageSQL - gemini-cli-extension; claude-code-plugin GitHub - 0gsd/enough: a personal language system for planning, writing, and translation. GitHub - Kaelio/ktx: ktx is an executable context layer for data and analytics agents 🐙 Allow Claude Code, Codex, and any AI agent to query data accurately through MCP with skills, memory and a semantic layer GitHub - ThatXliner/xtras: Xliner's Claude Code Skills GitHub - flightdeckhq/flightdeck: Observability and control plane for AI agents. GitHub - search-router/simple-search: Open-source reference app on top of the Search Router API: FastAPI + Jinja metasearch service with pluggable backends, deterministic mocks (no API key needed), RTL UI, Redis cache, and a demo ads cabinet. CSP Radar GitHub - Light-Heart-Labs/DreamServer: Turn your PC, Mac, or Linux box into an AI server. LLM inference, chat UI, voice, agents, workflows, RAG, and image generation. GitHub - Diplomat-ai/diplomat-agent-ts: What can your TypeScript AI agent do to the real world? Scan your code. See which tool calls have zero checks Code Block Selector - Visual Studio Marketplace Prometheus dependency graph — interactive showcase | Riftmap Show HN: I made a vi-like modal keyboard plugin for Figma GitHub - run-llama/liteparse: A fast, helpful, and open-source document parser GitHub - dalemyers/Roar: A macOS CLI tool for notifications GitHub - district-solutions/open-agent-tools-coder: Enables small-to-large self-hosted ai models to use local source code when running tool-calling agentic workloads. We actively data mine 20,900+ (2+ TB) popular github repos using large and small ai models to create reuseable: json, markdown and parquet files for local-first tool-calling models. GitHub - progapandist/stripeek: A local TUI proxy for real-time Stripe API debugging, built for navigating complex payloads fast. GitHub - sir1st/hermes-desktop: All-in-one cross-platform desktop app for Hermes Agent — bundles Python + hermes-agent + hermes-web-ui GitHub - astefanutti/shaderbang: Shebang for Shaders Show HN: Generate Claude Code Workflows using Spec Driven Development approach GitHub - nixys/nxs-universal-chart: The Helm chart you can use to install any of your applications into Kubernetes/OpenShift Show HN: AI agents for UK GDAD PCF roles and their skills The Two Pillars: Mixer Mode and Meta-Software in the Reorganization of Software Work After AI GitHub - JaiCode08/teleport-env What 1,000+ Harness Experiments Taught Me About Self-Improving Agents Show HN: Liiists, a Markdown-first, iOS and CLI list app SwiperTab – Get this Extension for 🦊 Firefox (en-US) GitHub - kouhxp/fftext: Summarize, explain, fact-check, or translate any text, URL, or file. No GPU. No cloud. One command GitHub - sweetpad-dev/sweetpad: Develop Swift/iOS projects using VSCode GitHub - dogmaticdev/IRON: IRON a.k.a. Intermediate Representation Object Notation is a Interpreter/Database that is used to create Programming Languages. GitHub - sjhalani7/vaen: Package your AI coding harness into a portable .agent file, and share it across repos, teams, & the community without ever having to copy-paste instructions, skills, MCP config, or secrets. Show HN: Gandalf the Grader Show HN: Citadeld – replay any CI failure locally from a single file GitHub - tdortman/cuSBF: High-Performance GPU Super Bloom Filter coral-ai/claude-code-token-xray at main · Coral-Bricks-AI/coral-ai GitHub - ulyssestenn/funes: Funes is a Git-based framework for LLM-managed knowledge work: an AI Librarian ingests raw sources, builds an interlinked Markdown knowledge base, and uses it to produce cited reports, analyses, and other outputs. GitHub - ThatXliner/gah: Git Add Hunk, built for agents to use GitHub - harmont-dev/harmont-cli: Command-line client for the Harmont CI platform GitHub - brooksmcmillin/mcp-authflow: OAuth 2.0 Authorization Server framework for MCP servers GitHub - javaid-codes/audit-supply-chain-agents GitHub - amorey/gochan: A small library of common channel architectures for Go, inspired by Rust GitHub - arifozgun/OpenGem: Free, Open-Source AI API Gateway with Gemini, OpenAI & Anthropic Compatibility in 1 file GitHub - Pranesh950/BioPetals: 🌸 Run BIOxAI models at home, BitTorrent-style. Fine-tuning and inference up to 10x faster than offloading GitHub - cnguyen14/bounty-doctor: Diagnose a GitHub bounty issue before you waste hours: detects honeypot scam repos, AI-bot attempt swarms, and stale contests. Show HN: CoreMCP – MCP Server for On-Prem DBs Show HN: KittyHTML – Render HTML/CSS as an inline image in your terminal GitHub - bingud/filemat: Web-based file manager Show HN: TruthLens – Free multi-signal deepfake image detector GitHub - apexlocal-jz/claude-usage-tray: Windows system-tray app showing your Claude Code rate-limit usage at a glance. Zero deps, ~300 lines of PowerShell. Cross-IDE (works regardless of VS Code, Cursor, plain terminal). Release v0.1.2.1 · kouhxp/yapsnap GitHub - noopolis/moltnet: Self-hostable chat network for AI agents. Pre-built bridges for Claude Code, Codex, and the Claws. Rooms, DMs, history. No Slack bots, no Matrix, no glue code. GitHub - tamerh/enju: Coordinating Humans, AI Agents, and Compute as Peers on a Shared Workflow Graph Show HN: Continuity-auth – Respect-weighted rate limits for the open web GitHub - luml-ai/luml: AI lifecycle platform where engineers and agents track experiments, train models, and ship to production. GitHub - mrdanielcasper/CoreTex: A UNIX-inspired, biomimetic, flat-file AI harness and knowledge engine. GitHub - clemg/pierre-github: Pierre's diffs.com and trees.software for Github GitHub - lyriks-io/unspaghettit: Behavior-driven AI development without prompt spaghetti. GitHub - sofumel/claude-handoff-revive: Resume Claude Code work after rate/usage/context limits without replaying the prior transcript. Auto-saves at 90%/95% usage. Plugin-installable, 10 languages. GitHub - dotexorg/saferpc: Typed, end-to-end encrypted RPC over any bidirectional channel. GitHub - BeeZeeAgent/beezee: Agent harness orchestration Legato Next.js Boilerplate for Internal Tools · CoreUI GitHub - clark-labs-inc/clark-hash: Clark Hash, 32x smaller searchable sketches for embeddings GitHub - ZeroPointRepo/youtube-mcp: The fastest YouTube transcript + YouTube search MCP for AI agents. Try for free. Typing Mastery — climb toward 100+ WPM, deliberately GitHub - Andebugulin/Awareen GitHub - fayzan123/claude-workflow-composer: Visual desktop app for composing multi-agent coding workflows. Drag agents, attach skills and MCPs, wire handoffs, export to .claude/ GitHub - StackOneHQ/stack-nudge We hardened an LLM agent. Each defense we added made it more exploitable. GitHub - alkait/WhatsKept: Agent-queryable WhatsApp history from an iOS backup — a single Go binary. GitHub - octelium/cordium: Open-source, general-purpose sandbox platform for devs and AI agents that provides identity-based secure access to infrastructure without credentials. GitHub - scosman/videowright: Build animated explainer videos with your coding agent GitHub - dipankar/dscode: The code editor you can take apart. GitHub - zoharbabin/web-researcher-mcp: MCP server (Go) for AI assistants: web search, content extraction, academic/patent/news research. Multi-provider routing, 4-tier scraping, search lenses. Works with Claude, Cursor, and any MCP client. GitHub - scanaislop/aislop: Catch the slop AI coding agents leave in your code: narrative comments, swallowed exceptions, as-any casts, dead code, oversized functions. 50+ rules across 7 languages (TypeScript, JavaScript, Python, Go, Rust, Ruby, PHP). Sub-second, deterministic, no LLM at runtime. MIT-licensed. GitHub - kouhxp/cheap-im: CPU-only voice agent approximating Thinking Machines' Interaction Models demo GitHub - unprovable/OrchidMantis: Orchid Mantis — standalone framework for Zero-Knowledge Proofs of eXploit (ZKPoX). GitHub - TangibleResearch/Halgorithem: A Algo designed to detect AI Hallucitions GitHub - CarpseDeam/Aura-IDE: An AI coding harness that shaped itself - Planner/Worker agents, repo awareness, surgical edits, validation, recovery, and safe diff approvals. GitHub - chojs23/concord: A feature-rich TUI client for Discord GitHub - aerf-spec/aerf: Agent Evidence Receipt Format (AERF) — an open specification for tamper-evident, independently verifiable records of AI agent actions. GitHub - Jwrede/tokentoll: Catch LLM cost changes in code review. Infracost for LLM spend. GitHub - samchon/ttsc: A `typescript-go` toolchain for compiler-powered plugins and type-safe execution + 500x faster lint integrated into compiler GitHub - Higangssh/homebutler: 🏠 Manage your homelab from chat. Single binary, zero dependencies. GitHub - olalie/tapmap: See where your computer connects and what stands out on a live world map. GitHub - Diplomat-ai/diplomat-agent: What can your AI agent do to the real world? Scan your code. See which tool calls have zero checks GitHub - Bajusz15/beacon: Open-source agent for secure remote access, monitoring, and deploys across home-lab and self-hosted machines like Raspberry Pi, N100, or any Linux server. Open web based TTY or tunnel Home Assistant and other local services securely without opening ports. BigTech AI News - Chrome 应用商店 GitHub - vinhnx/VTCode: VT Code is an open-source coding agent with LLM-native code understanding and robust shell safety. Supports multiple LLM providers with automatic failover and efficient context management. GitHub - Lumen-Labs/brainapi2: BrainAPI is a knowledge graph–powered AI memory layer that transforms unstructured data into structured knowledge, enabling intelligent search, recommendations, and contextual memory for AI agents and applications. GitHub - familiar-software/familiar: Let AI watch you work. Familiar lets your AI update its memory, skills, and knowledge by watching your screen. make sidebar/address bar rounded corner toggleable
GitHub - oldrev/lwdt: A lightweight device-tree and driver framework solution for ESP-IDF board variants
oldrev · 2026-06-26 · via Show HN

ESP-IDF Build ESP-IDF License Language

English | 简中

LWDT is inspired by Zephyr RTOS, especially its decoupled driver model, device-tree based hardware description, board IDs, and priority-sorted device initialization. The reason it does not simply use Zephyr is pragmatic: many ESP32 products still need Espressif's battle-tested native ESP-IDF ecosystem, including BLE provisioning, Wi-Fi, mesh networking, vendor examples, tooling, and silicon-day-one support.

The pain LWDT addresses is the way traditional ESP-IDF projects tend to drift into #ifdef branches, hardcoded GPIO tables, and duplicated driver glue when supporting multiple hardware variants or reusing custom drivers across boards.

The solution is a lightweight Python/Jsonnet pipeline that turns board.lwdt into Zephyr-like generated C access macros, plus a small drvfx runtime that provides priority-sorted initialization entries and static device objects fully inside native ESP-IDF CMake. The result is board-selectable, reusable hardware abstraction with zero runtime parsing overhead and without giving up ESP-IDF.

If this project saved you time, please consider buying me a coffee. Your support helps keep this project maintained, thank you!

Buy me a coffee

A board ID is always written as vendor/model. Each board directory uses fixed file names:

  • board.lwdt: Jsonnet device-tree description
  • board.cmake: board metadata, including LWDT_BOARD_IDF_TARGET
  • .lwdt.overlay or board.lwdt.overlay: optional project overlay

What It Does

LWDT currently provides:

  • board selection through -DLWDT_BOARD_ID=<vendor>/<model> or LWDT_BOARD_ID
  • automatic ESP-IDF target selection from board metadata
  • built-in BSP-style board definitions under the LWDT component
  • project-local board definitions that override built-in boards
  • Jsonnet overlays applied after the selected base board
  • generated C headers consumed by the LWDT driver framework

Repository Layout

  • components/lwdt/: reusable ESP-IDF component, generator, runtime framework, common device-tree includes, and built-in boards
  • components/lwdt/boards/<vendor>/<model>/: built-in board BSP definitions
  • components/lwdt/dt/: shared Jsonnet SoC and device-tree fragments
  • example/: ESP-IDF blink example
  • example/boards/<vendor>/<model>/: project-local board definitions or overlays
  • .github/workflows/: CI build coverage using the ESP-IDF Docker image

Board Resolution

When an application configures LWDT, board roots are searched in this order:

  1. The project boards/ directory
  2. Additional roots from LWDT_BOARD_ROOTS
  3. Built-in boards from components/lwdt/boards/

The first directory containing both board.cmake and board.lwdt wins. This means an application can override a built-in board by creating:

boards/<vendor>/<model>/board.cmake
boards/<vendor>/<model>/board.lwdt

A project can also keep the built-in board and only add an overlay:

boards/<vendor>/<model>/.lwdt.overlay

Application-wide overlay is also supported:

Explicit overlay files can be passed with -DLWDT_OVERLAYS=<path1>;<path2> or the LWDT_OVERLAYS environment variable. Overlays are applied after board.lwdt, in list order, using Jsonnet + semantics.

On Windows, use semicolon-separated lists for LWDT_BOARD_ROOTS and LWDT_OVERLAYS. Do not use : because drive letters already contain colons.

Quick Start

Set up the ESP-IDF environment, then build the example with a board ID:

cd example
idf.py build -DLWDT_BOARD_ID=nologo/esp32-c3-supermini

You can also use an environment variable:

$env:LWDT_BOARD_ID = "nologo/esp32-c3-supermini"
idf.py build

Flash and monitor with the usual ESP-IDF commands:

Built-In Boards

The component currently includes these built-in board definitions:

  • espressif/esp32-devkitc-1
  • espressif/esp32-c3-devkitm-1
  • nologo/esp32-c3-supermini
  • espressif/esp32-s3-devkitc-1

Using LWDT In An ESP-IDF Project

Add the LWDT component directory and include its board resolver before ESP-IDF's project.cmake:

cmake_minimum_required(VERSION 3.16)

set(EXTRA_COMPONENT_DIRS "path/to/devicetree/components")
include("path/to/devicetree/components/lwdt/cmake/lwdt_board.cmake")

include($ENV{IDF_PATH}/tools/cmake/project.cmake)
project(my_app)

Then implement drvfx_app_main() instead of ESP-IDF's app_main(). The LWDT runtime owns app_main() so it can run APPLICATION initializers before entering user code.

Components that define drvfx_app_main() or register entries with DRVFX_SYS_INIT() / DRVFX_SUBSYS_INIT() must be linked with WHOLE_ARCHIVE TRUE. These functions are discovered through linker sections, so normal static-library symbol extraction can otherwise discard the object files.

#include "drvfx/drvfx.h"

void drvfx_app_main(void)
{
    /* user application code */
}

Then build with:

idf.py build -DLWDT_BOARD_ID=<vendor>/<model>

Accessing Device Tree Data

Include both the helper macros and the generated header from your component code:

#include <lwdt/lwdt.h>
#include "lwdt_generated.h"

The generated symbols use the LWDT_ prefix. You can access the raw generated macros directly, but the helper macros are the preferred API.

For a board fragment like this:

{
  board: {
    label: "board",
    led_gpio: 8,
    led_active_low: 1,
    led_name: "ESP32-C3 SuperMini",
  },
}

Read properties by node label:

#define BOARD_NODE LWDT_NODELABEL(board)

#if !LWDT_NODE_EXISTS(BOARD_NODE)
#error "missing board node"
#endif

#if !LWDT_PROP_EXISTS(BOARD_NODE, led_gpio)
#error "missing board led_gpio property"
#endif

#define LED_GPIO        LWDT_PROP(BOARD_NODE, led_gpio)
#define LED_ACTIVE_LOW  LWDT_PROP(BOARD_NODE, led_active_low)
#define LED_NAME        LWDT_PROP(BOARD_NODE, led_name)

Equivalent direct generated macros are also available:

#define LED_GPIO_DIRECT LWDT_NS_board_P_led_gpio

For node paths, build a node identifier and then read properties:

#define I2C0_NODE LWDT_NODE2(soc, i2c0)
#define I2C0_ADDR LWDT_PROP(I2C0_NODE, reg)

For array properties, use the index helpers:

#define FIRST_PIN  LWDT_PROP_BY_IDX(BOARD_NODE, pins, 0)
#define PIN_COUNT  LWDT_PROP_LEN(BOARD_NODE, pins)

For phandle-style references, use LWDT_PROP_NODE() or LWDT_PROP_PHANDLE():

#define BUS_NODE LWDT_PROP_NODE(BOARD_NODE, i2c_bus)

For compatible instances, use the instance helpers. Compatible strings are normalized the same way generated C identifiers are normalized, for example "vendor,my-device" becomes vendor_my_device:

#define DEV0_NODE LWDT_INST(0, vendor_my_device)
#define DEV0_REG  LWDT_INST_PROP(0, vendor_my_device, reg)

The blink example uses the same generated data from C:

#define BOARD_NODE      LWDT_NODELABEL(board)
#define BLINK_GPIO      LWDT_PROP(BOARD_NODE, led_gpio)
#define LED_ACTIVE_LOW  LWDT_PROP(BOARD_NODE, led_active_low)
#define LED_BOARD_NAME  LWDT_PROP(BOARD_NODE, led_name)

Adding A Board

For a project-local board:

  1. Create boards/<vendor>/<model>/ in your ESP-IDF project.
  2. Add board.lwdt with the hardware description.
  3. Add board.cmake and set LWDT_BOARD_IDF_TARGET to the ESP-IDF target.
  4. Build with -DLWDT_BOARD_ID=<vendor>/<model>.

For a built-in board in LWDT itself, add the same directory under components/lwdt/boards/.

Implemented Drivers

LWDT currently includes the following drvfx drivers:

Driver Implementation Device name / API Init level Notes
I2C master bus ESP-IDF I2C master driver drvfx_i2c_* API, DT labels such as i2c0 PRE_KERNEL_2 / 50 DT-driven multi-instance via compatible: "esp32,i2c". Supports attach/detach, probe, transmit, receive, and transmit-receive.
SPI master bus ESP-IDF SPI master driver drvfx_spi_* API, DT labels such as spi2 PRE_KERNEL_2 / 50 DT-driven multi-instance via compatible: "esp32,spi". Supports acquire/release and transceive.
RTC ESP-IDF software RTC rtc_* API, device idf POST_KERNEL / 50 Legacy single-instance driver using ESP-IDF system time as an RTC-like device.
RTC DS1302 rtc_* API, device rtc_dev POST_KERNEL / 50 Legacy single-instance GPIO bit-banged DS1302 support.
RTC PCF8563 rtc_* API, DT labels such as rtc0 POST_KERNEL / 50 DT-driven multi-instance via compatible: "nxp,pcf8563"; depends on the referenced I2C bus.

The public driver headers live under components/lwdt/include/drvfx/drivers/. Driver source lives under components/lwdt/drivers/.

Developing A Driver

A modern LWDT driver should be instantiated from device-tree nodes, not from hardcoded CONFIG_*0_* wiring. The model is intentionally close to Zephyr: each node with a matching compatible string gets an instance number, and the driver expands LWDT_INST_FOREACH_STATUS_OKAY(<compat>, <macro>) at file scope. Only nodes with status: "okay" are instantiated; missing status is treated as okay.

A typical driver has four pieces:

  1. A config struct for immutable hardware configuration read from board.lwdt.
  2. A data struct for runtime state, one instance per enabled node.
  3. An init function with signature int init(const struct drvfx_device* dev).
  4. A per-instance define macro that calls DRVFX_DEVICE_DT_INST_DEFINE() or DRVFX_DEVICE_DT_INST_DEFINE_WITH_DEPS().

Example board data:

soc+: {
  i2c0+: {
    status: "okay",
    sda_gpio: 4,
    scl_gpio: 5,
    clock_frequency: 400000,
  },

  rtc0: {
    label: "rtc0",
    compatible: "nxp,pcf8563",
    status: "okay",
    bus: "i2c0",
    reg: [81],
    timeout_ms: 1000,
  },
},

Example bus driver pattern:

#include "drvfx/drvfx.h"
#include "lwdt/lwdt.h"
#include "lwdt_generated.h"

struct my_i2c_config {
    int port;
    int sda_gpio;
    int scl_gpio;
};

struct my_i2c_data {
    void* handle;
};

static int my_i2c_init(const struct drvfx_device* dev)
{
    const struct my_i2c_config* config = dev->config;
    struct my_i2c_data* data = dev->data;

    /* Configure the ESP-IDF peripheral from config. */
    return 0;
}

#define MY_I2C_DEFINE(inst, node_id)                                                                                   \
    static const struct my_i2c_config my_i2c_##inst##_config = {                                                       \
        .port = LWDT_PROP(node_id, port),                                                                              \
        .sda_gpio = LWDT_PROP(node_id, sda_gpio),                                                                      \
        .scl_gpio = LWDT_PROP(node_id, scl_gpio),                                                                      \
    };                                                                                                                 \
    static struct my_i2c_data my_i2c_##inst##_data = { 0 };                                                            \
    DRVFX_DEVICE_DT_INST_DEFINE(inst, esp32_i2c, LWDT_LABEL(node_id), my_i2c_init,                                    \
                                &my_i2c_##inst##_data, &my_i2c_##inst##_config, PRE_KERNEL_2,                         \
                                DRVFX_INIT_PRE_KERNEL_2_BUS_PRIORITY, &my_i2c_api);

#ifdef LWDT_INST_FOREACH_STATUS_OKAY_esp32_i2c
LWDT_INST_FOREACH_STATUS_OKAY(esp32_i2c, MY_I2C_DEFINE)
#endif

Example external-device dependency pattern:

#define SENSOR_DEFINE(inst, node_id)                                                                                   \
    static const struct sensor_config sensor_##inst##_config = {                                                       \
        .bus_name = LWDT_LABEL(LWDT_PROP_NODE(node_id, bus)),                                                          \
        .addr = LWDT_PROP_BY_IDX(node_id, reg, 0),                                                                     \
    };                                                                                                                 \
    static struct sensor_data sensor_##inst##_data = { 0 };                                                            \
    static const char* const sensor_##inst##_required_devices[] = {                                                    \
        LWDT_LABEL(LWDT_PROP_NODE(node_id, bus)),                                                                      \
    };                                                                                                                 \
    DRVFX_DEVICE_DT_INST_DEFINE_WITH_DEPS(inst, vendor_sensor, LWDT_LABEL(node_id), sensor_init,                      \
                                          &sensor_##inst##_data, &sensor_##inst##_config, POST_KERNEL,                 \
                                          DRVFX_INIT_POST_KERNEL_DEVICE_PRIORITY, &sensor_api,                         \
                                          sensor_##inst##_required_devices, 1);

#ifdef LWDT_INST_FOREACH_STATUS_OKAY_vendor_sensor
LWDT_INST_FOREACH_STATUS_OKAY(vendor_sensor, SENSOR_DEFINE)
#endif

Use LWDT_LABEL(node_id) for the runtime device name, LWDT_PROP() for scalar properties, LWDT_PROP_BY_IDX() for array entries such as reg, and LWDT_PROP_NODE() for phandle-style references such as bus: "i2c0".

Use PRE_KERNEL_2 / 50 for bus controllers such as I2C/SPI/UART and POST_KERNEL / 50 for normal external devices. Priority only orders entries inside the same level; real hardware dependencies should still be expressed with *_WITH_DEPS macros.

If an application component defines drvfx_app_main() or registers init entries with DRVFX_SYS_INIT() / DRVFX_SUBSYS_INIT(), link that component with WHOLE_ARCHIVE TRUE. Otherwise normal static-library extraction may discard object files that are only referenced through linker sections.

Driver Initialization Priorities

drvfx follows Zephyr's initialization level names and 0-99 priority convention. Lower priority numbers run earlier within the same level. The level names are kept for source compatibility and ordering clarity, while the actual execution points are mapped onto ESP-IDF startup hooks.

Level Priority Recommended use Notes
EARLY 0 Extremely low-level framework hooks only Avoid normal drivers here. ESP-IDF services may not be ready.
PRE_KERNEL_1 0 Clock or power primitives Use only for dependencies needed before buses.
PRE_KERNEL_1 10 System timer or watchdog-like primitives Keep minimal and non-blocking.
PRE_KERNEL_1 50 Basic GPIO controller support GPIO consumers should initialize later.
PRE_KERNEL_2 50 Internal buses such as I2C, SPI, UART, DMA Bus controllers should be ready before external devices.
PRE_KERNEL_2 80 Flash, RTC, or storage primitives needed early Use only when later stages depend on them.
POST_KERNEL 30 Console or logging-related glue ESP-IDF logging is already available, so most drivers need not use this.
POST_KERNEL 50 External devices on I2C/SPI/GPIO, sensors, RTC chips Default priority for normal hardware devices.
POST_KERNEL 60 Wi-Fi/Bluetooth controller level hardware Use for radio/controller bring-up.
POST_KERNEL 70 Network interface binding Use after controller-level network hardware.
APPLICATION 90 Middleware such as filesystems, UI stacks, protocol clients Runs from the application phase.
APPLICATION 99 Final user application hooks Last normal application priority.

Prefer the named macros in drvfx/kernel/init.h instead of raw numbers, for example DRVFX_INIT_PRE_KERNEL_2_BUS_PRIORITY or DRVFX_INIT_POST_KERNEL_DEVICE_PRIORITY. Priority controls ordering within one level only; real device dependencies should still be expressed with the *_WITH_DEPS device definition macros.

Notes

  • IDF_TARGET is selected from board.cmake, not from sdkconfig.
  • ESP-IDF still generates sdkconfig, but LWDT keeps the default example sdkconfig in the build directory so board wiring stays in board.lwdt.
  • If an existing sdkconfig was generated for a different ESP-IDF target, remove it and reconfigure. ESP-IDF validates sdkconfig target consistency before LWDT can change target cleanly.

License & Copyright

LWDT is licensed under the Apache License, Version 2.0. See LICENSE for details.

Copyright © 2026 Wei Li. All rights reserved.