用户模式访问 GPIO、I2C 和 SPI
Windows 10 包含的新 API 可用于直接通过用户模式访问 GPIO、I2C、SPI 和 UART。 开发板(如 Raspberry Pi 2)将公开这些连接的子集,这些连接支持用户使用自定义电路扩展基本计算模块来处理特定应用程序。 通常,只需使用部分 GPIO 引脚和标头上公开的总线,即可与其他关键板载功能共享这些低级别总线。 若要保持系统稳定性,必须通过用户模式应用程序指定可供安全修改的引脚和总线。
Windows 上低级别总线的用户模式访问通过现有 GpioClx
和 SpbCx
框架实现。 称为 RhProxy、在 Windows IoT 核心版和 Windows 企业版上可用的新驱动程序会向用户模式公开 GpioClx
和 SpbCx
资源。 若要启用这些 API,必须在 ACPI 表(内含应向用户模式公开的每个 GPIO 和 SPB 资源)中声明用于 RhProxy 的设备节点。
有关通过 RhProxy 进行用户模式访问的其他深度文档,可查看此处。
总线提供程序
从 Windows 10 开始,Windows 具有内置的 UWP API,可提供对 soc 上的 Gpio、Spi 或 I2c 总线的直接访问。这样就可从高级 API 轻松访问此硬件。 但是在许多情况下,设备制造商希望使用 soc 外的控制器来访问总线。 它可以很简单,就像一个添加 16 个 GPIO 引脚的便宜芯片一样,也可以像完整 MCU(如 Arduino)一样功能丰富,不仅添加 Gpio、SPI 和 I2C 引脚,还支持 PWM 和 ADC。 借助“总线提供程序”模型,开发人员能够使用可缩小这一差距的用户模式提供程序,通过内置 API 访问这些 soc 外的总线。
构建提供程序的用户在 UWP 类库中实现了一组接口,然后需要与该硬件通信的任何开发人员都只需包含该组件,并将其告知内置 API 即可。 如果查看 Remote Arduino 提供程序的示例代码,可以看到配置提供程序是多么容易,并且一旦设置为该应用的默认提供程序,客户端应用中的其余代码就会与访问 soc 上的总线所需的代码相同。
ArduinoProviders.ArduinoProvider.Configuration =
new ArduinoProviders.ArduinoConnectionConfiguration("VID_2341", "PID_0043", 57600);
Windows.Devices.LowLevelDevicesController.DefaultProvider = new ArduinoProviders.ArduinoProvider();
gpioController = await GpioController.GetDefaultAsync();
i2cController = await I2cController.GetDefaultAsync();
adcController = await AdcController.GetDefaultAsync();
pwmController = await PwmController.GetDefaultAsync();
GpioPin pin = gpioController.OpenPin(LED_PIN, GpioSharingMode.Exclusive);`
可用提供程序
目前,总线提供程序 GitHub 存储库上提供了许多提供程序。 除了提供程序的代码外,每个提供程序都有一个示例 VS 解决方案,它演示了客户端如何使用该提供程序。
ADC
- Ads1x15
- Mcp3008
- Remote Arduino
PWM
- PCA9685
- 使用 Gpio 模拟
- Remote Arduino
Gpio、SPI、I2C
- Remote Arduino
除了提供真实硬件访问权限的提供程序外,我们还构建了一个模拟提供程序,它将充当功能无限的提供程序,旨在让你在无需先将应用程序部署到工作设备的情况下编写和调试这些应用。 若要获得更丰富的体验,可对其进行自定义来模拟实际硬件。 例如:更新 I2c 提供程序,以便在向其发送命令,要求其在具有指定次要地址的设备上读取温度时,返回结果“75”。
其他资源
可在此处找到 I2C、SPI、GPIO、MINCOMM/UART 上的其他总线工具、示例代码以及生成和测试。
请参阅 Windows 运行时 (WinRT) API,此处介绍了如何使用 Win32 应用程序中的 API。