当前位置: 首页 > article >正文

2.7 庐山派K230芯片I2C模块API手册:主从模式配置与Python编程实战

庐山派K230芯片I2C模块API手册主从模式配置与Python编程实战最近在玩庐山派K230开发板发现它内置了5个硬件I2C模块用起来挺方便的。I2C这个通信协议在嵌入式里太常用了各种传感器、EEPROM存储器、触摸芯片都靠它。但很多朋友刚开始用的时候对怎么配置主从模式、怎么调用API不太清楚今天我就结合官方文档手把手带大家过一遍K230的I2C编程。这篇文章适合正在使用庐山派K230开发板的嵌入式开发者特别是需要连接I2C外设的朋友。我会详细讲解machine模块里的I2C和I2C_Slave两个类从最基础的设备扫描到主从通信实战最后还会分享一个K230模拟EEPROM从机的完整例子。咱们一步步来保证你能看懂、能用上。1. K230的I2C硬件基础与模式选择在开始写代码之前咱们先了解一下K230芯片的I2C硬件家底。这决定了你能用哪些功能。K230芯片内部集成了5个独立的硬件I2C控制器编号从I2C0到I2C4。每个控制器都支持三种标准通信速率标准模式100 kbit/s快速模式400 kbit/s高速模式3.4 Mbit/s注意具体使用哪个物理引脚作为I2C的SCL时钟线和SDA数据线需要参考IOMUXIO复用模块的配置来设置。简单理解就是芯片的引脚功能不是固定的你需要通过配置告诉芯片“这个引脚现在用作I2C的SCL”。这个配置通常在板级支持包BSP或底层驱动中完成对于大多数应用开发板厂商已经帮你配好了。除了硬件I2CK230还支持软件模拟I2C。当你硬件I2C的引脚被其他功能占用或者需要更多的I2C通道时就可以用普通的GPIO口来模拟I2C的时序非常灵活。软件I2C的设备ID从5开始即5~9。2. 主设备模式编程详解大部分时候我们的K230都是作为“主设备”Master去控制外部的“从设备”Slave比如读取温湿度传感器数据。machine.I2C类就是干这个的。2.1 初始化I2C主设备首先得把I2C通道初始化起来。这里分硬件I2C和软件I2C两种初始化方法。硬件I2C初始化 这是最常用、性能也最好的方式。假设我们要使用第一个硬件I2C控制器I2C0通信速率设为标准的100kHz。from machine import I2C # 初始化硬件I2C0时钟频率100kHz i2c I2C(0, freq100000)id0指定使用硬件I2C0。freq100000设置通信频率为100kHz即100,000 Hz。软件I2C初始化 当硬件通道不够用时我们可以指定两个普通的GPIO引脚来模拟I2C。比如我们使用ID为5的软件I2C设备并指定引脚10为SCL引脚11为SDA。from machine import I2C # 初始化软件I2C (ID5)指定SCL和SDA引脚频率100kHz超时时间1000ms i2c I2C(5, scl10, sda11, freq100000, timeout1000)id5指定使用软件I2C设备5。scl和sda必须指定用于模拟时钟线和数据线的GPIO引脚编号。timeout软件模拟时通信超时时间单位毫秒。这个参数对硬件I2C无效。2.2 扫描总线上的从设备新接上一个传感器第一步就是看看它有没有“上线”地址是多少。scan()方法就是干这个的。# 扫描I2C总线寻找所有从设备 device_list i2c.scan() print(Found I2C devices at addresses:, device_list)这个方法会返回一个列表里面是所有响应了扫描的从设备的7位地址注意I2C地址通常是7位不带读写位。如果返回空列表[]那就要检查一下接线、电源和从设备是否正常了。2.3 基础数据读写readfrom和writeto找到设备后就可以跟它“聊天”了。最基本的操作就是发送数据和接收数据。向从设备发送数据 比如我们要向地址为0x68的从设备发送一串数据。data_to_send bytearray([0x01, 0x02, 0x03]) # 要发送的数据 bytes_sent i2c.writeto(0x68, data_to_send, True) print(fSent {bytes_sent} bytes.)addr0x68目标从设备的地址。buf要发送的数据必须是bytes或bytearray类型。stopTrue发送完成后产生一个停止信号。目前API仅支持True。返回值成功发送的字节数。从从设备读取数据 比如从地址0x68的设备读取5个字节。# 方法一直接返回读取的数据 received_data i2c.readfrom(0x68, 5, True) print(Received data (method 1):, received_data) # 方法二读取到预先分配好的缓冲区更高效避免重复分配内存 buf bytearray(5) # 预先创建一个5字节的缓冲区 i2c.readfrom_into(0x68, buf, True) print(Received data (method 2):, buf)readfrom直接返回读取到的bytes对象。readfrom_into将数据读入一个已有的bytearray缓冲区buf。这在需要反复读取数据时性能更好。2.4 操作寄存器设备readfrom_mem和writeto_mem很多I2C设备如传感器、EEPROM内部有寄存器或存储单元你需要先指定一个“内存地址”memaddr然后再读写这个地址的数据。这需要两个步骤的复合操作。读取寄存器值 假设一个温度传感器的设备地址是0x48它的当前温度值存放在寄存器地址0x00我们需要读取2个字节。# 方法一直接读取 temp_data i2c.readfrom_mem(0x48, 0x00, 2, mem_size8) print(Temperature raw data:, temp_data) # 方法二读取到缓冲区 temp_buf bytearray(2) i2c.readfrom_mem_into(0x48, 0x00, temp_buf, mem_size8)memaddr0x00要读取的寄存器起始地址。nbytes2要读取的字节数。mem_size8寄存器地址的宽度默认为8位即1字节地址。有些设备是16位地址就需要设为mem_size16。向寄存器写入数据 向地址0x48设备的配置寄存器地址0x01写入一个字节的配置值0x60。config_value bytearray([0x60]) i2c.writeto_mem(0x48, 0x01, config_value, mem_size8)2.5 释放资源当不再使用I2C设备时最好显式地释放资源。虽然Python有垃圾回收但主动释放是个好习惯。i2c.deinit()3. 从设备模式编程实战K230的I2C控制器默认是主模式但它也能“扮演”从设备这个功能非常有用比如你可以让一块K230模拟成一个EEPROM存储器供另一块主控板比如另一块K230、树莓派、STM32等来读写。要实现这个功能需要定制固件。3.1 开启从机模式支持进入K230 SDK的编译配置菜单make rtsmart-menuconfig导航到路径Drivers Configuration-Enable-I2C-Enable I2Cx。找到并勾选Enable I2Cx SLAVE mode选项x代表你要启用从模式的I2C编号比如I2C0。保存配置退出并重新编译固件、烧录。只有编译了支持从机模式的固件下面的代码才能运行。3.2 模拟EEPROM从机完整示例咱们来看一个实战场景用K230从机模拟一个20字节的EEPROM用另一块开发板K210主机来读写它。同时K230会用一根GPIOPin5来通知主机“数据有更新快来读”K230端代码作为从机from machine import Pin, FPIOA, I2C_Slave import time import os # 初始化一个GPIO用于给主机发中断信号 def gpio_int_init(): fpioa FPIOA() # 实例化FPIOA用于引脚功能复用配置 fpioa.set_function(5, FPIOA.GPIO5) # 将物理引脚5的功能设置为GPIO5 # 实例化Pin5为输出模式无上下拉驱动能力设为7最强 pin Pin(5, Pin.OUT, pullPin.PULL_NONE, drive7) pin.value(1) # 初始化为高电平 return pin # 主程序开始 pin gpio_int_init() # 1. 获取系统中可用的I2C从机设备ID device_id_list I2C_Slave.list() print(找到的I2C从机设备ID:, device_id_list) # 通常只有一个我们取第一个 if not device_id_list: print(错误未找到可用的I2C从机设备请检查固件配置。) # 这里应该退出或处理错误 # 2. 创建I2C从机对象 # 参数设备ID从机地址设为0x10模拟20字节的EEPROM内存 i2c_slave I2C_Slave(device_id_list[0], addr0x10, mem_size20) print(I2C从机已启动地址0x10等待主机写入数据...) # 3. 循环等待主机写入数据 last_data i2c_slave.readfrom_mem(0, 20) # 首次读取内存初始值可能全0 current_data last_data while current_data last_data: # 如果数据没变就继续等 current_data i2c_slave.readfrom_mem(0, 20) # 从内存地址0开始读20字节 time.sleep_ms(100) # 休眠100ms避免CPU占用率过高 os.exitpoint() # 检查退出点允许程序被中断 print(f收到主机写入的数据: {current_data}) # 4. 处理数据并写回模拟EEPROM操作 # 这里我们简单地把收到的每个字节加1实际应用可能是处理传感器数据等 for i in range(len(current_data)): current_data[i] (current_data[i] 1) % 256 # 防止溢出 # 将处理后的数据写回模拟EEPROM的内存 i2c_slave.writeto_mem(0, current_data) # 5. 拉低再拉高GPIO5通知主机数据已更新可以读取了 pin.value(0) # 产生一个下降沿脉冲 time.sleep_ms(1) # 保持低电平1ms确保主机能检测到 pin.value(1) # 恢复高电平 print(数据已更新并已通知主机。)K210端代码作为主机from machine import I2C from fpioa_manager import fm # K210的引脚管理模块 from maix import GPIO import time # 配置K210的GPIO2连接K230的GPIO5为输入用于接收中断 fm.register(8, fm.fpioa.GPIO2) # 将物理引脚8映射为功能GPIO2 int_io GPIO(GPIO.GPIO2, GPIO.IN, GPIO.PULL_UP) # 上拉输入 # 初始化K210的I2C3作为主机 i2c_master I2C(I2C.I2C3, freq100000, scl6, sda7) # 1. 主机先向从机地址0x10的“EEPROM”写入一串数据 data_to_write bytearray(babcdefghijklnmopqrst) # 正好20字节 print(主机正在写入数据...) i2c_master.writeto_mem(0x10, 0, data_to_write, mem_size8) print(写入完成等待从机中断信号...) # 2. 等待从机的GPIO中断信号低电平 while int_io.value() 1: # 循环检测直到引脚变低 time.sleep_ms(10) # 短暂休眠降低CPU占用 pass print(收到中断信号开始读取从机数据...) # 3. 从机已更新数据主机去读取 received_buf i2c_master.readfrom_mem(0x10, 0, 20, mem_size8) print(从从机读取到的数据:, received_buf) # 预期输出应该是原始字符串每个字符的ASCII码加1即bcdefghijklmnopqrstu3.3 从机API关键点解析I2C_Slave.list()这个函数很重要必须先调用它来获取当前系统支持的从机设备ID。这个ID列表取决于你编译固件时使能了哪个I2C控制器作为从机。构造函数I2C_Slave(id, addr, mem_size)id必须使用list()方法返回的ID之一。addr这个从机在I2C总线上的7位地址主机会用这个地址来访问它。mem_size模拟的EEPROM内存大小。主机会通过readfrom_mem/writeto_mem来读写这片内存。内存映射读写从机的readfrom_mem和writeto_mem方法操作的就是mem_size定义的那片内存区域。主机的readfrom_mem/writeto_mem操作会映射到这里。4. 调试技巧与常见问题扫描不到设备检查接线SCL、SDA、GND是否接好电源是否稳定检查上拉电阻I2C总线必须要有上拉电阻通常4.7kΩ或10kΩ接到总线的电源如3.3V。很多开发板已集成如果自己接线别忘记。地址确认确认从设备地址是否正确注意是7位地址有的数据手册给的是8位带读写位的地址需要右移一位。通信失败或数据错误降低频率先尝试用最低的100kHz频率排除时序问题。检查电平确保主机和从机是相同的电压电平如都是3.3V。逻辑分析仪如果有条件用逻辑分析仪抓一下I2C波形是最直接的调试手段。从机模式无法使用确认固件这是最常见的问题务必按照3.1节的步骤重新编译并烧录支持I2C SLAVE模式的固件。检查ID确保I2C_Slave.list()返回了有效的ID并且初始化时使用了正确的ID。软件I2C不稳定软件I2C靠CPU延时模拟时序容易被其他中断打断。如果通信要求高优先使用硬件I2C。可以适当增加timeout参数的值。好了关于庐山派K230的I2C编程从主设备到从设备从基础API到实战项目核心内容就是这些了。实际项目中大部分时间你都是在做主设备去操作各种传感器。从设备模式则在一些需要板间通信或者设备模拟的场景下非常有用。多动手试试上面的代码遇到问题对照着排查很快就能掌握。

相关文章:

2.7 庐山派K230芯片I2C模块API手册:主从模式配置与Python编程实战

庐山派K230芯片I2C模块API手册:主从模式配置与Python编程实战 最近在玩庐山派K230开发板,发现它内置了5个硬件I2C模块,用起来挺方便的。I2C这个通信协议在嵌入式里太常用了,各种传感器、EEPROM存储器、触摸芯片都靠它。但很多朋友…...

避开这5个坑!用HyperMesh做轮毂网格划分时90%新手会犯的错误

避开这5个坑!用HyperMesh做轮毂网格划分时90%新手会犯的错误 轮毂的有限元分析,是汽车底盘部件研发中一个既经典又充满挑战的环节。很多工程师,尤其是那些已经掌握了HyperWorks基础操作的中级用户,常常会陷入一个怪圈:…...

让老旧Mac重获新生:OpenCore Legacy Patcher零成本升级实践

让老旧Mac重获新生:OpenCore Legacy Patcher零成本升级实践 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 当我的2015款 MacBook Pro 弹出"无法更新至最…...

Chandra OCR功能体验:布局感知OCR实测,表格公式手写识别效果惊艳

Chandra OCR功能体验:布局感知OCR实测,表格公式手写识别效果惊艳 1. 从“识字”到“懂你”:Chandra带来的OCR新体验 我们每天都在和文档打交道。一份PDF合同,你想快速提取关键条款;一张手写的数学试卷,你…...

Web前端集成李慕婉-仙逆-造相Z-Turbo图像生成

Web前端集成李慕婉-仙逆-造相Z-Turbo图像生成 让每个Web开发者都能轻松打造专属的仙侠角色生成器 1. 为什么要在Web前端集成图像生成? 想象一下,你的网站上有一个输入框,用户输入"白衣仙子站在云雾缭绕的山巅",点击按钮…...

AIVideo一站式AI长视频工具:5分钟从主题到成片,新手也能做专业视频

AIVideo一站式AI长视频工具:5分钟从主题到成片,新手也能做专业视频 1. 引言:你的视频创作革命,从输入一个想法开始 想象一下这个场景:你脑子里突然蹦出一个绝妙的视频点子,可能是想介绍一款新产品&#x…...

**发散创新:基于领域驱动设计的API接口优雅重构实践**在现代微服务架构中,API设

发散创新:基于领域驱动设计的API接口优雅重构实践 在现代微服务架构中,API设计早已不是简单的HTTP路由映射,而是承载业务语义、体现系统结构的关键一环。本文将围绕领域驱动设计(DDD)思想与API设计原则的融合实践&…...

SWAT模型实战:从零到一的数据准备与处理全攻略

1. SWAT模型数据准备入门指南 第一次接触SWAT模型时,我被各种数据需求搞得晕头转向。DEM、土地利用、土壤、气象四大数据就像四座大山,每座山都有不同的攀登路线。经过三个项目的实战,我总结出这套适合新手的通关攻略,帮你避开我当…...

红米Note9 4G版刷机指南:从MIUI14到澎湃OS安卓15的完整升级路线

红米Note9 4G版系统升级全攻略:从MIUI 14到澎湃OS安卓15的深度实践 手里还握着那台红米Note9 4G版的朋友,这几年看着新系统一个接一个地发布,心里多少有点痒痒吧?官方更新早就停在了MIUI 14,但社区里关于澎湃OS、安卓1…...

Typst公式编写避坑指南:从行内公式到复杂数学符号排版

Typst公式编写避坑指南:从行内公式到复杂数学符号排版 如果你曾经在LaTeX里为了一行数学公式的括号对齐、符号转义或者编号引用而反复调试,或者被Word里公式编辑器的笨拙和格式错乱折磨过,那么Typst的出现,很可能为你打开一扇新的…...

iLabPower BIMS V2.6开启实验室动物管理「全维可视化」时代

实验动物管理迎来新突破!iLabPower BIMS V2.6 全新版本正式发布,此次重点升级动物管理模块,覆盖猴、犬、猪等非啮齿类动物,实现从入笼、管理到实验的全流程数字化与可视化,为科研团队带来更直观、更高效的管理体验&…...

notebooklm-py:把 NotebookLM 放到你的程序中

技能说明 NotebookLM自动化工具,把 NotebookLM 放到你的程序中 一句话生成思维导图、生成音频播客、生成PPT,全都OK。 可以把NotebookLM把当最牛逼的知识库用了。 项目地址 ​​​​​​https://github.com/teng-lin/notebooklm-py 这个 skill 可以做…...

Swin2SR镜像优化建议:处理速度慢?试试这些技巧

Swin2SR镜像优化建议:处理速度慢?试试这些技巧 1. 问题诊断:为什么我的Swin2SR处理速度不够快? 当你兴致勃勃地部署好Swin2SR镜像,准备将一堆模糊的老照片或AI小图变成高清大作时,却发现处理一张图片要等…...

ANIMATEDIFF PRO精彩案例:胶片颗粒感+暗角+色偏电影LUT风格渲染

ANIMATEDIFF PRO精彩案例:胶片颗粒感暗角色偏电影LUT风格渲染 1. 引言:电影级渲染新体验 你是否曾经想过,用AI生成视频也能达到专业电影级别的视觉效果?今天我要分享的ANIMATEDIFF PRO,正是这样一个能让普通用户也能…...

基于RVC和微信公众号的互动游戏:语音猜角色小程序

基于RVC和微信公众号的互动游戏:语音猜角色小程序 最近在刷短视频时,经常看到一些用AI变声模仿明星唱歌或说经典台词的视频,评论区里大家玩得不亦乐乎。这让我想到,能不能把这种趣味性和互动性结合起来,做成一个可以让…...

老旧电视智能化改造:MyTV-Android开源方案的技术实现与性能优化

老旧电视智能化改造:MyTV-Android开源方案的技术实现与性能优化 【免费下载链接】mytv-android 使用Android原生开发的电视直播软件 项目地址: https://gitcode.com/gh_mirrors/my/mytv-android 随着智能电视技术的快速迭代,大量2015年前后生产的…...

抖音批量下载效率提升10倍:从机械操作到智能管理的完整解决方案

抖音批量下载效率提升10倍:从机械操作到智能管理的完整解决方案 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 副标题:如何让你的内容收集工作从耗时几小时缩短到几分钟?…...

UnrealPakViewer:虚幻引擎Pak文件故障诊断与资源优化全方案

UnrealPakViewer:虚幻引擎Pak文件故障诊断与资源优化全方案 【免费下载链接】UnrealPakViewer 查看 UE4 Pak 文件的图形化工具,支持 UE4 pak/ucas 文件 项目地址: https://gitcode.com/gh_mirrors/un/UnrealPakViewer 在虚幻引擎开发过程中&#…...

如何用M9A智能助手节省90%《重返未来:1999》游戏时间

如何用M9A智能助手节省90%《重返未来:1999》游戏时间 【免费下载链接】M9A 重返未来:1999 小助手 项目地址: https://gitcode.com/gh_mirrors/m9a/M9A M9A智能助手是一款专为《重返未来:1999》玩家设计的自动化工具,通过图…...

3D Face HRN快速部署指南:小白也能一键搭建的人脸重建系统

3D Face HRN快速部署指南:小白也能一键搭建的人脸重建系统 1. 从零开始:为什么选择3D Face HRN? 如果你对3D建模感兴趣,或者工作中需要处理人脸相关的数字内容,那么“从一张照片生成3D人脸”这个需求,你一…...

Mirage Flow在STM32嵌入式开发中的应用:边缘AI解决方案

Mirage Flow在STM32嵌入式开发中的应用:边缘AI解决方案 在嵌入式设备上实现AI推理一直是开发者面临的挑战,尤其是像STM32这样的资源受限平台。传统方案要么性能不足,要么功耗太高,很难在边缘设备上实现实用的AI功能。 Mirage Fl…...

空地协同智能消防系统:多智能体嵌入式工程实践

1. 项目概述2023年全国大学生电子设计竞赛G题“空地协同智能消防系统”是一项面向复杂动态环境的多智能体协同控制工程实践任务。该系统由四旋翼无人机与地面消防车构成闭环协作单元,需在40dm48dm矩形场域内完成全覆盖路径规划、火源识别定位、空地信息同步、自主灭…...

DeerFlow灾备方案:服务中断应急处理流程设计

DeerFlow灾备方案:服务中断应急处理流程设计 1. 引言:为什么需要灾备方案 在实际生产环境中,任何服务都可能面临意外中断的风险。DeerFlow作为深度研究助理平台,集成了语言模型、网络搜索、Python代码执行等多个关键组件&#x…...

Phi-3-Mini-128K部署案例:国产昇腾910B平台适配Phi-3-Mini的迁移实践

Phi-3-Mini-128K部署案例:国产昇腾910B平台适配Phi-3-Mini的迁移实践 1. 项目背景与技术选型 Phi-3-Mini-128K是微软推出的轻量级对话模型,以其高效的推理性能和128K超长上下文支持能力著称。在国产昇腾910B平台上部署该模型,不仅能够验证国…...

Stable Yogi Leather-Dress-Collection前沿实践:LoRA融合+动态CFG Scale调节

Stable Yogi Leather-Dress-Collection前沿实践:LoRA融合动态CFG Scale调节 今天要跟大家分享一个特别有意思的项目——Stable Yogi Leather-Dress-Collection。简单来说,这是一个能让你在本地电脑上,轻松生成各种动漫风格皮衣穿搭图片的工具…...

通义千问1.5-1.8B-Chat-GPTQ-Int4 Anaconda安装与环境管理:为模型部署创建独立Python空间

通义千问1.5-1.8B-Chat-GPTQ-Int4 Anaconda安装与环境管理:为模型部署创建独立Python空间 你是不是刚拿到通义千问这类大模型的代码,准备跑起来试试,结果第一步就被各种Python包冲突、版本不兼容搞得头大?我刚开始接触模型部署的…...

抖音直播数据采集全攻略:从技术实现到商业价值挖掘

抖音直播数据采集全攻略:从技术实现到商业价值挖掘 【免费下载链接】DouyinLiveWebFetcher 抖音直播间网页版的弹幕数据抓取(2024最新版本) 项目地址: https://gitcode.com/gh_mirrors/do/DouyinLiveWebFetcher 问题象限:直…...

7倍效率提升:抖音内容批量获取与管理全流程解决方案

7倍效率提升:抖音内容批量获取与管理全流程解决方案 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 问题剖析:抖音内容获取的三大核心痛点 在数字内容爆炸的时代,抖音作为…...

Qwen-Image-2512像素艺术生成实操手册:触发词机制与风格控制详解

Qwen-Image-2512像素艺术生成实操手册:触发词机制与风格控制详解 1. 引言:从零开始,玩转像素艺术 你是不是也曾经被那些复古又充满魅力的像素画所吸引?无论是经典游戏里的角色,还是社交媒体上流行的像素风头像&#…...

Docker环境部署Qwen3-VL-WEBUI:图文AI快速启动,小白友好教程

Docker环境部署Qwen3-VL-WEBUI:图文AI快速启动,小白友好教程 1. 为什么你需要试试Qwen3-VL? 如果你对AI的印象还停留在“只会聊天”,那Qwen3-VL可能会颠覆你的认知。想象一下,你拍一张产品设计图,AI不仅能…...