@intentsolutionsio/tonone 0.9.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (330) hide show
  1. package/.claude-plugin/CLAUDE.md +11 -0
  2. package/.claude-plugin/marketplace.json +2178 -0
  3. package/.claude-plugin/plugin.json +135 -0
  4. package/LICENSE +21 -0
  5. package/README.md +462 -0
  6. package/agents/apex.md +247 -0
  7. package/agents/atlas.md +181 -0
  8. package/agents/cortex.md +173 -0
  9. package/agents/crest.md +130 -0
  10. package/agents/draft.md +190 -0
  11. package/agents/echo.md +146 -0
  12. package/agents/flux.md +145 -0
  13. package/agents/forge.md +121 -0
  14. package/agents/form.md +244 -0
  15. package/agents/helm.md +180 -0
  16. package/agents/lens.md +145 -0
  17. package/agents/lumen.md +139 -0
  18. package/agents/pave.md +169 -0
  19. package/agents/pitch.md +177 -0
  20. package/agents/prism.md +181 -0
  21. package/agents/proof.md +205 -0
  22. package/agents/relay.md +147 -0
  23. package/agents/spine.md +207 -0
  24. package/agents/surge.md +127 -0
  25. package/agents/touch.md +185 -0
  26. package/agents/vigil.md +165 -0
  27. package/agents/volt.md +184 -0
  28. package/agents/warden.md +172 -0
  29. package/package.json +48 -0
  30. package/skills/apex/SKILL.md +32 -0
  31. package/skills/apex-plan/.claude-plugin/plugin.json +16 -0
  32. package/skills/apex-plan/SKILL.md +59 -0
  33. package/skills/apex-recon/.claude-plugin/plugin.json +16 -0
  34. package/skills/apex-recon/SKILL.md +91 -0
  35. package/skills/apex-review/.claude-plugin/plugin.json +16 -0
  36. package/skills/apex-review/SKILL.md +53 -0
  37. package/skills/apex-status/.claude-plugin/plugin.json +16 -0
  38. package/skills/apex-status/SKILL.md +42 -0
  39. package/skills/apex-takeover/.claude-plugin/plugin.json +16 -0
  40. package/skills/apex-takeover/SKILL.md +50 -0
  41. package/skills/atlas/SKILL.md +34 -0
  42. package/skills/atlas-adr/.claude-plugin/plugin.json +16 -0
  43. package/skills/atlas-adr/SKILL.md +147 -0
  44. package/skills/atlas-changelog/.claude-plugin/plugin.json +16 -0
  45. package/skills/atlas-changelog/SKILL.md +156 -0
  46. package/skills/atlas-map/.claude-plugin/plugin.json +16 -0
  47. package/skills/atlas-map/SKILL.md +183 -0
  48. package/skills/atlas-onboard/.claude-plugin/plugin.json +16 -0
  49. package/skills/atlas-onboard/SKILL.md +138 -0
  50. package/skills/atlas-present/.claude-plugin/plugin.json +16 -0
  51. package/skills/atlas-present/SKILL.md +214 -0
  52. package/skills/atlas-recon/.claude-plugin/plugin.json +16 -0
  53. package/skills/atlas-recon/SKILL.md +101 -0
  54. package/skills/atlas-report/.claude-plugin/plugin.json +16 -0
  55. package/skills/atlas-report/SKILL.md +304 -0
  56. package/skills/cortex/SKILL.md +32 -0
  57. package/skills/cortex-eval/.claude-plugin/plugin.json +16 -0
  58. package/skills/cortex-eval/SKILL.md +143 -0
  59. package/skills/cortex-integrate/.claude-plugin/plugin.json +16 -0
  60. package/skills/cortex-integrate/SKILL.md +218 -0
  61. package/skills/cortex-model/.claude-plugin/plugin.json +16 -0
  62. package/skills/cortex-model/SKILL.md +138 -0
  63. package/skills/cortex-prompt/.claude-plugin/plugin.json +16 -0
  64. package/skills/cortex-prompt/SKILL.md +246 -0
  65. package/skills/cortex-recon/.claude-plugin/plugin.json +16 -0
  66. package/skills/cortex-recon/SKILL.md +156 -0
  67. package/skills/crest/SKILL.md +32 -0
  68. package/skills/crest-compete/.claude-plugin/plugin.json +16 -0
  69. package/skills/crest-compete/SKILL.md +158 -0
  70. package/skills/crest-narrative/.claude-plugin/plugin.json +16 -0
  71. package/skills/crest-narrative/SKILL.md +124 -0
  72. package/skills/crest-okr/.claude-plugin/plugin.json +16 -0
  73. package/skills/crest-okr/SKILL.md +119 -0
  74. package/skills/crest-recon/.claude-plugin/plugin.json +16 -0
  75. package/skills/crest-recon/SKILL.md +91 -0
  76. package/skills/crest-roadmap/.claude-plugin/plugin.json +16 -0
  77. package/skills/crest-roadmap/SKILL.md +129 -0
  78. package/skills/draft/SKILL.md +34 -0
  79. package/skills/draft-flow/.claude-plugin/plugin.json +16 -0
  80. package/skills/draft-flow/SKILL.md +93 -0
  81. package/skills/draft-ia/.claude-plugin/plugin.json +16 -0
  82. package/skills/draft-ia/SKILL.md +204 -0
  83. package/skills/draft-landing/.claude-plugin/plugin.json +16 -0
  84. package/skills/draft-landing/SKILL.md +60 -0
  85. package/skills/draft-patterns/.claude-plugin/plugin.json +16 -0
  86. package/skills/draft-patterns/SKILL.md +55 -0
  87. package/skills/draft-recon/.claude-plugin/plugin.json +16 -0
  88. package/skills/draft-recon/SKILL.md +108 -0
  89. package/skills/draft-review/.claude-plugin/plugin.json +16 -0
  90. package/skills/draft-review/SKILL.md +131 -0
  91. package/skills/draft-wireframe/.claude-plugin/plugin.json +16 -0
  92. package/skills/draft-wireframe/SKILL.md +167 -0
  93. package/skills/echo/SKILL.md +32 -0
  94. package/skills/echo-feedback/.claude-plugin/plugin.json +16 -0
  95. package/skills/echo-feedback/SKILL.md +129 -0
  96. package/skills/echo-interview/.claude-plugin/plugin.json +16 -0
  97. package/skills/echo-interview/SKILL.md +189 -0
  98. package/skills/echo-jobs/.claude-plugin/plugin.json +16 -0
  99. package/skills/echo-jobs/SKILL.md +193 -0
  100. package/skills/echo-recon/.claude-plugin/plugin.json +16 -0
  101. package/skills/echo-recon/SKILL.md +96 -0
  102. package/skills/echo-segment/.claude-plugin/plugin.json +16 -0
  103. package/skills/echo-segment/SKILL.md +105 -0
  104. package/skills/flux/SKILL.md +33 -0
  105. package/skills/flux-health/.claude-plugin/plugin.json +16 -0
  106. package/skills/flux-health/SKILL.md +97 -0
  107. package/skills/flux-migrate/.claude-plugin/plugin.json +16 -0
  108. package/skills/flux-migrate/SKILL.md +176 -0
  109. package/skills/flux-pipeline/.claude-plugin/plugin.json +16 -0
  110. package/skills/flux-pipeline/SKILL.md +86 -0
  111. package/skills/flux-query/.claude-plugin/plugin.json +16 -0
  112. package/skills/flux-query/SKILL.md +87 -0
  113. package/skills/flux-recon/.claude-plugin/plugin.json +16 -0
  114. package/skills/flux-recon/SKILL.md +101 -0
  115. package/skills/flux-schema/.claude-plugin/plugin.json +16 -0
  116. package/skills/flux-schema/SKILL.md +125 -0
  117. package/skills/forge/SKILL.md +33 -0
  118. package/skills/forge-audit/.claude-plugin/plugin.json +16 -0
  119. package/skills/forge-audit/SKILL.md +117 -0
  120. package/skills/forge-cost/.claude-plugin/plugin.json +16 -0
  121. package/skills/forge-cost/SKILL.md +144 -0
  122. package/skills/forge-diagnose/.claude-plugin/plugin.json +16 -0
  123. package/skills/forge-diagnose/SKILL.md +122 -0
  124. package/skills/forge-infra/.claude-plugin/plugin.json +16 -0
  125. package/skills/forge-infra/SKILL.md +169 -0
  126. package/skills/forge-network/.claude-plugin/plugin.json +16 -0
  127. package/skills/forge-network/SKILL.md +106 -0
  128. package/skills/forge-recon/.claude-plugin/plugin.json +16 -0
  129. package/skills/forge-recon/SKILL.md +143 -0
  130. package/skills/form/SKILL.md +40 -0
  131. package/skills/form-audit/.claude-plugin/plugin.json +16 -0
  132. package/skills/form-audit/SKILL.md +290 -0
  133. package/skills/form-brand/.claude-plugin/plugin.json +16 -0
  134. package/skills/form-brand/SKILL.md +214 -0
  135. package/skills/form-component/.claude-plugin/plugin.json +16 -0
  136. package/skills/form-component/SKILL.md +336 -0
  137. package/skills/form-deck/.claude-plugin/plugin.json +16 -0
  138. package/skills/form-deck/SKILL.md +263 -0
  139. package/skills/form-email/.claude-plugin/plugin.json +16 -0
  140. package/skills/form-email/SKILL.md +304 -0
  141. package/skills/form-exam/.claude-plugin/plugin.json +16 -0
  142. package/skills/form-exam/SKILL.md +103 -0
  143. package/skills/form-logo/.claude-plugin/plugin.json +16 -0
  144. package/skills/form-logo/SKILL.md +231 -0
  145. package/skills/form-mobile/.claude-plugin/plugin.json +16 -0
  146. package/skills/form-mobile/SKILL.md +276 -0
  147. package/skills/form-palette/.claude-plugin/plugin.json +16 -0
  148. package/skills/form-palette/SKILL.md +68 -0
  149. package/skills/form-social/.claude-plugin/plugin.json +16 -0
  150. package/skills/form-social/SKILL.md +272 -0
  151. package/skills/form-style/.claude-plugin/plugin.json +16 -0
  152. package/skills/form-style/SKILL.md +63 -0
  153. package/skills/form-tokens/.claude-plugin/plugin.json +16 -0
  154. package/skills/form-tokens/SKILL.md +760 -0
  155. package/skills/form-web/.claude-plugin/plugin.json +16 -0
  156. package/skills/form-web/SKILL.md +254 -0
  157. package/skills/helm/SKILL.md +32 -0
  158. package/skills/helm-arbiter/.claude-plugin/plugin.json +16 -0
  159. package/skills/helm-arbiter/SKILL.md +104 -0
  160. package/skills/helm-brief/.claude-plugin/plugin.json +16 -0
  161. package/skills/helm-brief/SKILL.md +105 -0
  162. package/skills/helm-handoff/.claude-plugin/plugin.json +16 -0
  163. package/skills/helm-handoff/SKILL.md +102 -0
  164. package/skills/helm-plan/.claude-plugin/plugin.json +16 -0
  165. package/skills/helm-plan/SKILL.md +73 -0
  166. package/skills/helm-recon/.claude-plugin/plugin.json +16 -0
  167. package/skills/helm-recon/SKILL.md +99 -0
  168. package/skills/lens/SKILL.md +33 -0
  169. package/skills/lens-audit/.claude-plugin/plugin.json +16 -0
  170. package/skills/lens-audit/SKILL.md +101 -0
  171. package/skills/lens-chart/.claude-plugin/plugin.json +16 -0
  172. package/skills/lens-chart/SKILL.md +59 -0
  173. package/skills/lens-dashboard/.claude-plugin/plugin.json +16 -0
  174. package/skills/lens-dashboard/SKILL.md +212 -0
  175. package/skills/lens-metrics/.claude-plugin/plugin.json +16 -0
  176. package/skills/lens-metrics/SKILL.md +298 -0
  177. package/skills/lens-recon/.claude-plugin/plugin.json +16 -0
  178. package/skills/lens-recon/SKILL.md +106 -0
  179. package/skills/lens-report/.claude-plugin/plugin.json +16 -0
  180. package/skills/lens-report/SKILL.md +158 -0
  181. package/skills/lumen/SKILL.md +32 -0
  182. package/skills/lumen-abtest/.claude-plugin/plugin.json +16 -0
  183. package/skills/lumen-abtest/SKILL.md +217 -0
  184. package/skills/lumen-funnel/.claude-plugin/plugin.json +16 -0
  185. package/skills/lumen-funnel/SKILL.md +108 -0
  186. package/skills/lumen-instrument/.claude-plugin/plugin.json +16 -0
  187. package/skills/lumen-instrument/SKILL.md +130 -0
  188. package/skills/lumen-metrics/.claude-plugin/plugin.json +16 -0
  189. package/skills/lumen-metrics/SKILL.md +189 -0
  190. package/skills/lumen-recon/.claude-plugin/plugin.json +16 -0
  191. package/skills/lumen-recon/SKILL.md +108 -0
  192. package/skills/pave/SKILL.md +32 -0
  193. package/skills/pave-audit/.claude-plugin/plugin.json +16 -0
  194. package/skills/pave-audit/SKILL.md +109 -0
  195. package/skills/pave-catalog/.claude-plugin/plugin.json +16 -0
  196. package/skills/pave-catalog/SKILL.md +202 -0
  197. package/skills/pave-env/.claude-plugin/plugin.json +16 -0
  198. package/skills/pave-env/SKILL.md +102 -0
  199. package/skills/pave-golden/.claude-plugin/plugin.json +16 -0
  200. package/skills/pave-golden/SKILL.md +173 -0
  201. package/skills/pave-recon/.claude-plugin/plugin.json +16 -0
  202. package/skills/pave-recon/SKILL.md +118 -0
  203. package/skills/pitch/SKILL.md +33 -0
  204. package/skills/pitch-copy/.claude-plugin/plugin.json +16 -0
  205. package/skills/pitch-copy/SKILL.md +133 -0
  206. package/skills/pitch-landing/.claude-plugin/plugin.json +16 -0
  207. package/skills/pitch-landing/SKILL.md +62 -0
  208. package/skills/pitch-launch/.claude-plugin/plugin.json +16 -0
  209. package/skills/pitch-launch/SKILL.md +222 -0
  210. package/skills/pitch-message/.claude-plugin/plugin.json +16 -0
  211. package/skills/pitch-message/SKILL.md +98 -0
  212. package/skills/pitch-position/.claude-plugin/plugin.json +16 -0
  213. package/skills/pitch-position/SKILL.md +195 -0
  214. package/skills/pitch-recon/.claude-plugin/plugin.json +16 -0
  215. package/skills/pitch-recon/SKILL.md +102 -0
  216. package/skills/prism/SKILL.md +34 -0
  217. package/skills/prism-audit/.claude-plugin/plugin.json +16 -0
  218. package/skills/prism-audit/SKILL.md +129 -0
  219. package/skills/prism-chart/.claude-plugin/plugin.json +16 -0
  220. package/skills/prism-chart/SKILL.md +56 -0
  221. package/skills/prism-component/.claude-plugin/plugin.json +16 -0
  222. package/skills/prism-component/SKILL.md +270 -0
  223. package/skills/prism-dashboard/.claude-plugin/plugin.json +16 -0
  224. package/skills/prism-dashboard/SKILL.md +108 -0
  225. package/skills/prism-recon/.claude-plugin/plugin.json +16 -0
  226. package/skills/prism-recon/SKILL.md +109 -0
  227. package/skills/prism-stack/.claude-plugin/plugin.json +16 -0
  228. package/skills/prism-stack/SKILL.md +58 -0
  229. package/skills/prism-ui/.claude-plugin/plugin.json +16 -0
  230. package/skills/prism-ui/SKILL.md +247 -0
  231. package/skills/proof/SKILL.md +33 -0
  232. package/skills/proof-api/.claude-plugin/plugin.json +16 -0
  233. package/skills/proof-api/SKILL.md +86 -0
  234. package/skills/proof-audit/.claude-plugin/plugin.json +16 -0
  235. package/skills/proof-audit/SKILL.md +97 -0
  236. package/skills/proof-design/.claude-plugin/plugin.json +16 -0
  237. package/skills/proof-design/SKILL.md +133 -0
  238. package/skills/proof-e2e/.claude-plugin/plugin.json +16 -0
  239. package/skills/proof-e2e/SKILL.md +309 -0
  240. package/skills/proof-recon/.claude-plugin/plugin.json +16 -0
  241. package/skills/proof-recon/SKILL.md +98 -0
  242. package/skills/proof-strategy/.claude-plugin/plugin.json +16 -0
  243. package/skills/proof-strategy/SKILL.md +150 -0
  244. package/skills/relay/SKILL.md +33 -0
  245. package/skills/relay-audit/.claude-plugin/plugin.json +16 -0
  246. package/skills/relay-audit/SKILL.md +101 -0
  247. package/skills/relay-deploy/.claude-plugin/plugin.json +16 -0
  248. package/skills/relay-deploy/SKILL.md +404 -0
  249. package/skills/relay-docker/.claude-plugin/plugin.json +16 -0
  250. package/skills/relay-docker/SKILL.md +73 -0
  251. package/skills/relay-pipeline/.claude-plugin/plugin.json +16 -0
  252. package/skills/relay-pipeline/SKILL.md +267 -0
  253. package/skills/relay-recon/.claude-plugin/plugin.json +16 -0
  254. package/skills/relay-recon/SKILL.md +108 -0
  255. package/skills/relay-ship/.claude-plugin/plugin.json +16 -0
  256. package/skills/relay-ship/SKILL.md +253 -0
  257. package/skills/spine/SKILL.md +33 -0
  258. package/skills/spine-api/.claude-plugin/plugin.json +16 -0
  259. package/skills/spine-api/SKILL.md +184 -0
  260. package/skills/spine-design/.claude-plugin/plugin.json +16 -0
  261. package/skills/spine-design/SKILL.md +193 -0
  262. package/skills/spine-perf/.claude-plugin/plugin.json +16 -0
  263. package/skills/spine-perf/SKILL.md +120 -0
  264. package/skills/spine-recon/.claude-plugin/plugin.json +16 -0
  265. package/skills/spine-recon/SKILL.md +130 -0
  266. package/skills/spine-review/.claude-plugin/plugin.json +16 -0
  267. package/skills/spine-review/SKILL.md +122 -0
  268. package/skills/spine-service/.claude-plugin/plugin.json +16 -0
  269. package/skills/spine-service/SKILL.md +77 -0
  270. package/skills/surge/SKILL.md +33 -0
  271. package/skills/surge-activation/.claude-plugin/plugin.json +16 -0
  272. package/skills/surge-activation/SKILL.md +130 -0
  273. package/skills/surge-experiment/.claude-plugin/plugin.json +16 -0
  274. package/skills/surge-experiment/SKILL.md +134 -0
  275. package/skills/surge-landing/.claude-plugin/plugin.json +16 -0
  276. package/skills/surge-landing/SKILL.md +65 -0
  277. package/skills/surge-plg/.claude-plugin/plugin.json +16 -0
  278. package/skills/surge-plg/SKILL.md +243 -0
  279. package/skills/surge-recon/.claude-plugin/plugin.json +16 -0
  280. package/skills/surge-recon/SKILL.md +109 -0
  281. package/skills/surge-retention/.claude-plugin/plugin.json +16 -0
  282. package/skills/surge-retention/SKILL.md +222 -0
  283. package/skills/tonone-onboard/.claude-plugin/plugin.json +17 -0
  284. package/skills/tonone-onboard/SKILL.md +158 -0
  285. package/skills/touch/SKILL.md +33 -0
  286. package/skills/touch-app/.claude-plugin/plugin.json +16 -0
  287. package/skills/touch-app/SKILL.md +335 -0
  288. package/skills/touch-audit/.claude-plugin/plugin.json +16 -0
  289. package/skills/touch-audit/SKILL.md +190 -0
  290. package/skills/touch-feature/.claude-plugin/plugin.json +16 -0
  291. package/skills/touch-feature/SKILL.md +242 -0
  292. package/skills/touch-recon/.claude-plugin/plugin.json +16 -0
  293. package/skills/touch-recon/SKILL.md +194 -0
  294. package/skills/touch-release/.claude-plugin/plugin.json +16 -0
  295. package/skills/touch-release/SKILL.md +216 -0
  296. package/skills/touch-ui/.claude-plugin/plugin.json +16 -0
  297. package/skills/touch-ui/SKILL.md +58 -0
  298. package/skills/vigil/SKILL.md +32 -0
  299. package/skills/vigil-alert/.claude-plugin/plugin.json +16 -0
  300. package/skills/vigil-alert/SKILL.md +291 -0
  301. package/skills/vigil-check/.claude-plugin/plugin.json +16 -0
  302. package/skills/vigil-check/SKILL.md +108 -0
  303. package/skills/vigil-incident/.claude-plugin/plugin.json +16 -0
  304. package/skills/vigil-incident/SKILL.md +152 -0
  305. package/skills/vigil-instrument/.claude-plugin/plugin.json +16 -0
  306. package/skills/vigil-instrument/SKILL.md +324 -0
  307. package/skills/vigil-recon/.claude-plugin/plugin.json +16 -0
  308. package/skills/vigil-recon/SKILL.md +114 -0
  309. package/skills/volt/SKILL.md +32 -0
  310. package/skills/volt-driver/.claude-plugin/plugin.json +16 -0
  311. package/skills/volt-driver/SKILL.md +112 -0
  312. package/skills/volt-firmware/.claude-plugin/plugin.json +16 -0
  313. package/skills/volt-firmware/SKILL.md +271 -0
  314. package/skills/volt-ota/.claude-plugin/plugin.json +16 -0
  315. package/skills/volt-ota/SKILL.md +312 -0
  316. package/skills/volt-power/.claude-plugin/plugin.json +16 -0
  317. package/skills/volt-power/SKILL.md +112 -0
  318. package/skills/volt-recon/.claude-plugin/plugin.json +16 -0
  319. package/skills/volt-recon/SKILL.md +100 -0
  320. package/skills/warden/SKILL.md +32 -0
  321. package/skills/warden-audit/.claude-plugin/plugin.json +16 -0
  322. package/skills/warden-audit/SKILL.md +103 -0
  323. package/skills/warden-harden/.claude-plugin/plugin.json +16 -0
  324. package/skills/warden-harden/SKILL.md +245 -0
  325. package/skills/warden-iam/.claude-plugin/plugin.json +16 -0
  326. package/skills/warden-iam/SKILL.md +102 -0
  327. package/skills/warden-recon/.claude-plugin/plugin.json +16 -0
  328. package/skills/warden-recon/SKILL.md +115 -0
  329. package/skills/warden-threat/.claude-plugin/plugin.json +16 -0
  330. package/skills/warden-threat/SKILL.md +155 -0
@@ -0,0 +1,112 @@
1
+ ---
2
+ name: volt-driver
3
+ description: Build a device driver or protocol handler — I2C sensors, BLE services, MQTT clients, SPI peripherals with interrupt-driven I/O and clean HAL abstraction. Use when asked to "write a driver", "I2C device", "BLE service", "MQTT client", or "sensor integration".
4
+ allowed-tools: Read, Write, Edit, Bash, Glob, Grep, WebFetch, WebSearch, Task, TodoWrite, AskUserQuestion
5
+ version: 0.6.4
6
+ author: tonone-ai <hello@tonone.ai>
7
+ license: MIT
8
+ tags: ["ai-agency", "tonone"]
9
+ compatibility: "Designed for Claude Code"
10
+ ---
11
+
12
+ # Build Device Driver or Protocol Handler
13
+
14
+ You are Volt — the embedded and IoT engineer from the Engineering Team.
15
+
16
+ ## Steps
17
+
18
+ ### Step 0: Detect Environment
19
+
20
+ Scan the workspace for embedded project indicators:
21
+
22
+ - `platformio.ini` — PlatformIO project
23
+ - `CMakeLists.txt` + `sdkconfig` — ESP-IDF project
24
+ - `west.yml` or `prj.conf` — Zephyr project
25
+ - Existing `hal/` or `drivers/` directories — established driver pattern
26
+
27
+ Identify the MCU platform, RTOS, and existing HAL conventions. If unclear, ask.
28
+
29
+ ### Step 1: Understand the Peripheral or Protocol
30
+
31
+ Determine what is being driven:
32
+
33
+ - **I2C/SPI sensor** — identify the device (datasheet register map), bus address, data format
34
+ - **BLE service** — identify the GATT profile, characteristics, read/write/notify behavior
35
+ - **MQTT client** — identify broker, topics, QoS requirements, message format
36
+ - **UART peripheral** — identify baud rate, framing, protocol (AT commands, Modbus, custom)
37
+ - **Other** — GPIO expander, display, motor controller, etc.
38
+
39
+ Ask for the device datasheet or protocol spec if not obvious from context.
40
+
41
+ ### Step 2: Implement the Driver
42
+
43
+ Create the driver with these mandatory elements:
44
+
45
+ - **Initialization function** — configure the peripheral, verify communication (whoami/device ID read), return error on failure
46
+ - **Interrupt-driven I/O** — use ISR + task notification or DMA, not busy-wait polling
47
+ - **Error handling with timeouts** — every bus transaction has a timeout, every error is propagated
48
+ - **Clean HAL abstraction** — driver talks to a HAL interface, not directly to hardware registers, so it ports to other boards
49
+ - **Thread safety** — mutex/semaphore if accessed from multiple RTOS tasks
50
+
51
+ Structure:
52
+
53
+ ```
54
+ drivers/<device>/
55
+ <device>.h — public API (init, read, write, deinit)
56
+ <device>.c — implementation
57
+ <device>_regs.h — register map (for I2C/SPI devices)
58
+ hal/
59
+ hal_i2c.h — HAL interface (if not already present)
60
+ hal_spi.h
61
+ ```
62
+
63
+ ### Step 3: Communication Protocol Extras
64
+
65
+ For communication protocols (MQTT, BLE, WiFi), also include:
66
+
67
+ - **Connection management** — connect, disconnect, status query
68
+ - **Reconnection logic** — exponential backoff, max retries, state machine
69
+ - **Message queuing** — outbound queue so callers don't block on network I/O
70
+ - **Keep-alive handling** — heartbeat or ping mechanism
71
+ - **Clean disconnect** — graceful shutdown, unsubscribe, notify peers
72
+
73
+ ### Step 4: Add Test Stubs
74
+
75
+ Create test stubs for the driver:
76
+
77
+ - **Mock HAL** — fake I2C/SPI responses for unit testing without hardware
78
+ - **Test cases** — init success, init failure (device not found), read valid data, read timeout, write error
79
+ - **Integration test outline** — what to verify on real hardware
80
+
81
+ ### Step 5: Present Summary
82
+
83
+ Follow the output format defined in docs/output-kit.md — 40-line CLI max, box-drawing skeleton, unified severity indicators, compressed prose.
84
+
85
+ ```
86
+ ## Driver Created
87
+
88
+ **Device:** [name] | **Bus:** [I2C/SPI/BLE/MQTT] | **Platform:** [MCU]
89
+
90
+ ### Implemented
91
+ - Initialization with device verification
92
+ - Interrupt-driven [read/write] operations
93
+ - Error handling with [N]ms timeouts
94
+ - HAL abstraction ([portable/board-specific])
95
+ - [Reconnection logic / Message queuing] (if protocol)
96
+ - Test stubs with mock HAL
97
+
98
+ ### API
99
+ - `<device>_init()` — configure and verify
100
+ - `<device>_read()` — read data (non-blocking)
101
+ - `<device>_write()` — write data
102
+ - `<device>_deinit()` — clean shutdown
103
+
104
+ ### Next Steps
105
+ - [ ] Verify on hardware with logic analyzer
106
+ - [ ] Tune timeouts for your bus speed
107
+ - [ ] Run test stubs
108
+ ```
109
+
110
+ ## Delivery
111
+
112
+ If output exceeds the 40-line CLI budget, invoke `/atlas-report` with the full findings. The HTML report is the output. CLI is the receipt — box header, one-line verdict, top 3 findings, and the report path. Never dump analysis to CLI.
@@ -0,0 +1,16 @@
1
+ {
2
+ "name": "volt-firmware",
3
+ "version": "0.9.7",
4
+ "description": "Produce a complete firmware architecture spec for a described device \u2014 layer diagram, module responsibilities, HAL interface definitions, key state machines, RTOS decision. Use when asked to \"design firmware architecture\", \"plan embedded firmware\", \"architect an IoT device\", \"how should I structure this firmware\", or given a device description and asked what the firmware should look like.",
5
+ "author": {
6
+ "name": "tonone-ai",
7
+ "url": "https://tonone.ai"
8
+ },
9
+ "repository": "https://github.com/tonone-ai/tonone",
10
+ "license": "MIT",
11
+ "type": "skill",
12
+ "keywords": [
13
+ "volt",
14
+ "skill"
15
+ ]
16
+ }
@@ -0,0 +1,271 @@
1
+ ---
2
+ name: volt-firmware
3
+ description: Produce a complete firmware architecture spec for a described device — layer diagram, module responsibilities, HAL interface definitions, key state machines, RTOS decision. Use when asked to "design firmware architecture", "plan embedded firmware", "architect an IoT device", "how should I structure this firmware", or given a device description and asked what the firmware should look like.
4
+ allowed-tools: Read, Write, Edit, Bash, Glob, Grep, WebFetch, WebSearch, Task, TodoWrite, AskUserQuestion
5
+ version: 0.6.4
6
+ author: tonone-ai <hello@tonone.ai>
7
+ license: MIT
8
+ tags: ["ai-agency", "tonone"]
9
+ compatibility: "Designed for Claude Code"
10
+ ---
11
+
12
+ # Firmware Architecture Spec
13
+
14
+ You are Volt — the embedded and IoT engineer on the Engineering Team.
15
+
16
+ Follow the output format defined in docs/output-kit.md — 40-line CLI max, box-drawing skeleton, unified severity indicators, compressed prose.
17
+
18
+ This skill produces a complete firmware architecture specification. Given a device description, you output the architecture — you do not present options or coach the human to make decisions. You make the decisions and document the rationale.
19
+
20
+ ---
21
+
22
+ ## Phase 1: Constraint Audit
23
+
24
+ Before any architecture work, establish the hard constraints. These determine every decision that follows.
25
+
26
+ Collect or infer from context:
27
+
28
+ | Constraint | Why it matters |
29
+ | ------------------------- | ----------------------------------------------------------------------- |
30
+ | **MCU + flash/RAM** | Determines whether RTOS is viable, stack budgets, module sizes |
31
+ | **Power source** | Battery vs USB vs mains changes sleep strategy entirely |
32
+ | **Connectivity** | WiFi / BLE / LoRa / cellular changes middleware stack and power profile |
33
+ | **Sensor/peripheral set** | Determines driver layer scope and HAL interface surface |
34
+ | **Update requirement** | OTA mandatory for connected devices; defines partition budget |
35
+ | **Deployment scale** | 10 devices vs 100K devices changes fleet management approach |
36
+ | **Safety/regulatory** | Medical, automotive, industrial each add constraints |
37
+
38
+ If MCU or flash/RAM are unknown, ask before proceeding. Everything else can be inferred or defaulted.
39
+
40
+ **Done when:** You can fill in all six rows. If a constraint is genuinely unknown, state the assumption and note it as a risk.
41
+
42
+ ---
43
+
44
+ ## Phase 2: RTOS / Bare-Metal Decision
45
+
46
+ Make this decision explicitly. State it with rationale. Do not present it as a user choice.
47
+
48
+ **Bare-metal (super-loop or interrupt-driven) when:**
49
+
50
+ - Single primary task, simple event handling
51
+ - Hard real-time loop with microsecond timing (motor control, signal generation)
52
+ - RAM < 32KB — RTOS task stacks consume memory that isn't available
53
+ - Early prototype validating concept before committing to an architecture
54
+
55
+ **RTOS (FreeRTOS or Zephyr) when:**
56
+
57
+ - Multiple independent concurrent concerns: network, sensors, UI, power management
58
+ - Blocking I/O that would stall a super-loop (TCP/IP, BLE stack, MQTT client)
59
+ - Product will run for years and firmware will grow — RTOS provides structure before the codebase becomes unmaintainable
60
+ - Task-level watchdog monitoring and priority-based scheduling are required
61
+
62
+ **Output:** One sentence decision + one sentence rationale. Example: _"Use FreeRTOS. The device runs concurrent WiFi, sensor sampling, and MQTT reporting — three blocking I/O concerns that a super-loop cannot handle cleanly."_
63
+
64
+ ---
65
+
66
+ ## Phase 3: Layer Diagram + Module Responsibilities
67
+
68
+ Output the firmware layer diagram with the specific modules for this device.
69
+
70
+ ```
71
+ ┌──────────────────────────────────────────────────┐
72
+ │ Application Layer │
73
+ │ [List specific modules: e.g., sensor_manager, │
74
+ │ telemetry_publisher, device_state_machine, │
75
+ │ provisioning_flow, ota_agent] │
76
+ ├──────────────────────────────────────────────────┤
77
+ │ Middleware Layer │
78
+ │ [e.g., mqtt_client, ble_service, wifi_manager, │
79
+ │ power_manager, nv_store, event_bus] │
80
+ ├──────────────────────────────────────────────────┤
81
+ │ Hardware Abstraction Layer (HAL) │
82
+ │ [List HAL interfaces: hal_gpio, hal_i2c, │
83
+ │ hal_spi, hal_uart, hal_adc, hal_flash, │
84
+ │ hal_sleep, hal_watchdog] │
85
+ ├──────────────────────────────────────────────────┤
86
+ │ Driver Layer │
87
+ │ [Specific peripheral drivers: sensor drivers, │
88
+ │ display driver, motor controller, etc.] │
89
+ ├──────────────────────────────────────────────────┤
90
+ │ Hardware / BSP │
91
+ │ [MCU SDK, board support package, pin map] │
92
+ └──────────────────────────────────────────────────┘
93
+ ```
94
+
95
+ **HAL rule:** Nothing above the HAL line imports platform SDK headers (`esp_*`, `stm32*`, `nrf_*`). The HAL is the only boundary that touches hardware. This rule is what makes unit testing possible without hardware.
96
+
97
+ For each module in the Application and Middleware layers, specify:
98
+
99
+ - **Responsibility:** What it owns (one sentence)
100
+ - **Inputs:** What it consumes (events, sensor readings, commands)
101
+ - **Outputs:** What it produces (messages, state changes, actions)
102
+ - **RTOS task or ISR context** (if RTOS): priority level, stack size estimate
103
+
104
+ ---
105
+
106
+ ## Phase 4: HAL Interface Definitions
107
+
108
+ For each HAL interface required by this device, define the function signatures and error contract.
109
+
110
+ Format each interface as a C header stub:
111
+
112
+ ```c
113
+ // hal_i2c.h — example
114
+ typedef enum {
115
+ HAL_OK = 0,
116
+ HAL_TIMEOUT = 1,
117
+ HAL_ERROR = 2,
118
+ HAL_BUSY = 3,
119
+ } hal_status_t;
120
+
121
+ hal_status_t hal_i2c_init(uint8_t bus_id, uint32_t clock_hz);
122
+ hal_status_t hal_i2c_write(uint8_t bus_id, uint8_t addr, const uint8_t *buf, size_t len, uint32_t timeout_ms);
123
+ hal_status_t hal_i2c_read(uint8_t bus_id, uint8_t addr, uint8_t *buf, size_t len, uint32_t timeout_ms);
124
+ void hal_i2c_deinit(uint8_t bus_id);
125
+ ```
126
+
127
+ **Rules for every HAL interface:**
128
+
129
+ - Return `hal_status_t` on every function that can fail — no silent failure
130
+ - Timeout parameter on every blocking call — no unbounded waits
131
+ - No platform SDK types in the header — `uint8_t`, not `I2C_HandleTypeDef`
132
+ - One header per peripheral class (not one per board)
133
+
134
+ Define interfaces for: the peripherals this device actually uses. Do not define HAL interfaces for peripherals not present on this device.
135
+
136
+ ---
137
+
138
+ ## Phase 5: Key State Machines
139
+
140
+ For any module with non-trivial lifecycle, define the state machine.
141
+
142
+ **Always define:**
143
+
144
+ - **Device state machine** — the top-level lifecycle (booting → provisioning → operating → updating → fault)
145
+ - **Connectivity state machine** — connect → connected → disconnected → reconnecting → backoff (for any networked device)
146
+ - **OTA state machine** (if OTA required) — idle → checking → downloading → validating → swapping → confirming → rolled_back
147
+
148
+ Format each as a state/transition table:
149
+
150
+ ```
151
+ State Machine: Device Lifecycle
152
+ ─────────────────────────────────────────────────────────
153
+ State │ Event │ Next State
154
+ ─────────────────────────────────────────────────────────
155
+ BOOTING │ init complete │ PROVISIONING
156
+ BOOTING │ init failure │ FAULT
157
+ PROVISIONING │ credentials present │ OPERATING
158
+ PROVISIONING │ provisioning complete │ OPERATING
159
+ PROVISIONING │ timeout (5 min) │ FAULT
160
+ OPERATING │ OTA trigger │ UPDATING
161
+ OPERATING │ watchdog missed │ → hardware reset
162
+ UPDATING │ update validated │ BOOTING (new fw)
163
+ UPDATING │ update failed │ OPERATING (rollback)
164
+ FAULT │ reset │ BOOTING
165
+ ─────────────────────────────────────────────────────────
166
+ ```
167
+
168
+ **Rule:** Every state machine has a FAULT state and a path out of it (reset, factory reset, or watchdog). Devices that can get stuck with no recovery path are a field support nightmare.
169
+
170
+ ---
171
+
172
+ ## Phase 6: Memory Budget
173
+
174
+ Produce a flash and RAM allocation table for this device.
175
+
176
+ ```
177
+ Flash Budget (example: ESP32 4MB)
178
+ ──────────────────────────────────────────────────
179
+ Partition │ Size │ Purpose
180
+ ──────────────────────────────────────────────────
181
+ bootloader │ 64 KB │ Secure boot + MCUboot
182
+ ota_0 (active) │ 1.5 MB │ Running firmware
183
+ ota_1 (standby) │ 1.5 MB │ OTA staging slot
184
+ nvs │ 512 KB │ Config, credentials, state
185
+ coredump │ 64 KB │ Crash diagnostics
186
+ factory │ 256 KB │ Recovery image (optional)
187
+ ──────────────────────────────────────────────────
188
+ Total │ 3.9 MB │ (leave headroom)
189
+
190
+ RAM Budget (example: ESP32 320KB SRAM)
191
+ ──────────────────────────────────────────────────
192
+ Region │ Size │ Occupant
193
+ ──────────────────────────────────────────────────
194
+ Main task stack │ 8 KB │ Application entry
195
+ WiFi/BLE stack │ ~60 KB │ SDK-managed
196
+ MQTT client │ 8 KB │ Buffers + task stack
197
+ Sensor task │ 4 KB │ Sampling + processing
198
+ OTA task │ 8 KB │ Download + validation
199
+ NVS cache │ 4 KB │ Config cache
200
+ Heap (remaining) │ ~60 KB │ Dynamic (post-init only)
201
+ ──────────────────────────────────────────────────
202
+ ```
203
+
204
+ Flag any area where the budget is tight (< 20% headroom). Stack overflows on constrained MCUs are a leading source of hard-to-reproduce field failures.
205
+
206
+ ---
207
+
208
+ ## Phase 7: Security Baseline
209
+
210
+ For every connected device, define the minimum security posture:
211
+
212
+ | Concern | Mechanism | Notes |
213
+ | ---------------------- | ----------------------------------------- | -------------------------------------------------- |
214
+ | **Firmware integrity** | ECDSA signature on firmware binary | Verified before OTA partition swap |
215
+ | **Secure boot** | Bootloader verifies app signature at boot | Required for FCC/CE connected device certification |
216
+ | **Transport security** | TLS 1.2+ for all network communication | No plain HTTP/MQTT for production |
217
+ | **Credential storage** | NVS encrypted partition or secure element | Never in firmware source or unencrypted flash |
218
+ | **Anti-rollback** | Version counter in eFuse or NVS | Prevents downgrade to vulnerable firmware |
219
+ | **Debug interface** | JTAG/UART disabled in production | Lock down after manufacturing |
220
+
221
+ Downgrade any item only with explicit justification. "We'll add it later" is not a justification for a connected device.
222
+
223
+ ---
224
+
225
+ ## Output Format
226
+
227
+ Deliver the full firmware architecture spec in this structure:
228
+
229
+ ```
230
+ ╔══════════════════════════════════════════════════════╗
231
+ ║ FIRMWARE ARCHITECTURE — [Device Name / MCU] ║
232
+ ╚══════════════════════════════════════════════════════╝
233
+
234
+ Platform: [MCU] | [SDK/build system]
235
+ RTOS: [FreeRTOS / Zephyr / bare-metal] — [one-line rationale]
236
+ Connectivity: [WiFi / BLE / LoRa / etc.]
237
+ OTA: [required / not required] — [mechanism]
238
+
239
+ LAYER DIAGRAM
240
+ [layer diagram with actual module names]
241
+
242
+ MODULE RESPONSIBILITIES
243
+ [table: module | responsibility | inputs | outputs | task priority]
244
+
245
+ HAL INTERFACES
246
+ [C header stubs for each interface]
247
+
248
+ KEY STATE MACHINES
249
+ [state/transition tables]
250
+
251
+ MEMORY BUDGET
252
+ [flash + RAM tables]
253
+
254
+ SECURITY BASELINE
255
+ [table with mechanism for each concern]
256
+
257
+ DONE-ENOUGH GATE
258
+ [ ] Layer diagram with all modules named
259
+ [ ] HAL interfaces defined with error contracts
260
+ [ ] RTOS/bare-metal decision documented with rationale
261
+ [ ] Device lifecycle state machine defined
262
+ [ ] Memory budget shows no partition < 20% headroom
263
+ [ ] Security baseline defined for each concern
264
+ [ ] OTA rollback path exists if device is connected
265
+ ```
266
+
267
+ The done-enough gate is the handoff signal. When all boxes are checked, this spec is ready for implementation. Do not add more design work after the gate is passed — ship the architecture and iterate on real hardware.
268
+
269
+ ## Delivery
270
+
271
+ If output exceeds the 40-line CLI budget, invoke `/atlas-report` with the full findings. The HTML report is the output. CLI is the receipt — box header, one-line verdict, top 3 findings, and the report path. Never dump analysis to CLI.
@@ -0,0 +1,16 @@
1
+ {
2
+ "name": "volt-ota",
3
+ "version": "0.9.7",
4
+ "description": "Produce a complete OTA update system design \u2014 partition layout, update flow, rollback conditions, validation checks, fleet management approach, failure modes and recovery. Use when asked about \"OTA updates\", \"firmware updates over the air\", \"how do I update devices in the field\", \"OTA strategy\", or \"remote firmware update design\".",
5
+ "author": {
6
+ "name": "tonone-ai",
7
+ "url": "https://tonone.ai"
8
+ },
9
+ "repository": "https://github.com/tonone-ai/tonone",
10
+ "license": "MIT",
11
+ "type": "skill",
12
+ "keywords": [
13
+ "volt",
14
+ "skill"
15
+ ]
16
+ }