首页 > 解决方案 > 我可以仅使用数据线通过 Raspberry pi 0 w 的 USB 端口传输串行数据吗?

问题描述

我最近一直在尝试找出一种方法,是否只能使用 ttyGS0 通过 Rpi w 0 的微型 USB 端口发送串行数据(像图像数据这样的大文件)。但是当我在网上搜索时,我只找到了通过串行和其他东西设置无头的方法,这不是我想要的。但我确实按照教程做了一半

以为我可以在 Rpi 上的串行程序中使用 /dev/ttyGS0 并发送正在发送的数据,但是在我的 PC 上,当我尝试访问位于 comport 12 上的 Rpi 时,它说找不到端口并且不能打开它。但它在设备管理器中显示为“PI USB 转串口(COM12)”

然后我想知道是否有可能以这种方式访问​​ Rpi 的 com 端口。

如果是这种情况,我想知道是否有任何其他方法可以仅使用 USB 电缆访问 Rpi 的 USB 端口

笔记

我在测试时发现的东西和东西:-

pi@aloypi:~ $ dmesg | grep tty
[    0.000000] Kernel command line: coherent_pool=1M 8250.nr_uarts=1 snd_bcm2835.enable_compat_alsa=0 snd_bcm2835.enable_hdmi=1 bcm2708_fb.fbwidth=1366 bcm2708_fb.fbheight=768 bcm2708_fb.fbswap=1 smsc95xx.macaddr=B8:27:EB:6D:50:77 vc_mem.mem_base=0x1ec00000 vc_mem.mem_size=0x20000000  console=tty1 root=PARTUUID=4ab8bcad-02 rootfstype=ext4 elevator=deadline fsck.repair=yes rootwait modules-load=dwc2,g_serial
[    0.001496] printk: console [tty1] enabled
[    2.543414] 20201000.serial: ttyAMA0 at MMIO 0x20201000 (irq = 81, base_baud = 0) is a PL011 rev2
[    2.561791] 20215040.serial: ttyS0 at MMIO 0x20215040 (irq = 53, base_baud = 50000000) is a 16550
[    6.716694] systemd[1]: Created slice system-getty.slice.

pi@aloypi:~ $ dmesg | grep dwc2
[    0.000000] Kernel command line: coherent_pool=1M 8250.nr_uarts=1 snd_bcm2835.enable_compat_alsa=0 snd_bcm2835.enable_hdmi=1 bcm2708_fb.fbwidth=1366 bcm2708_fb.fbheight=768 bcm2708_fb.fbswap=1 smsc95xx.macaddr=B8:27:EB:6D:50:77 vc_mem.mem_base=0x1ec00000 vc_mem.mem_size=0x20000000  console=tty1 root=PARTUUID=4ab8bcad-02 rootfstype=ext4 elevator=deadline fsck.repair=yes rootwait modules-load=dwc2,g_serial
[    2.379190] dwc_otg: version 3.00a 10-AUG-2012 (platform bus)
[    2.386185] dwc_otg: FIQ enabled
[    2.386205] dwc_otg: NAK holdoff enabled
[    2.386219] dwc_otg: FIQ split-transaction FSM enabled
[    2.386245] Module dwc_common_port init
[    2.968203]     modules-load=dwc2,g_serial
[    8.344134] dwc2 20980000.usb: supply vusb_d not found, using dummy regulator
[    8.367130] dwc2 20980000.usb: supply vusb_a not found, using dummy regulator
[    8.626751] dwc2 20980000.usb: EPs: 8, dedicated fifos, 4080 entries in SPRAM
[    8.647109] dwc2 20980000.usb: DWC OTG Controller
[    8.653810] dwc2 20980000.usb: new USB bus registered, assigned bus number 1
[    8.726672] dwc2 20980000.usb: irq 33, io mem 0x20980000
[    8.787097] usb usb1: Manufacturer: Linux 5.10.17+ dwc2_hsotg
[    9.371395] dwc2 20980000.usb: bound driver g_serial
[  194.158373] dwc2 20980000.usb: new device is high-speed
[  194.189677] dwc2 20980000.usb: new device is high-speed
[  194.225164] dwc2 20980000.usb: new address 3

标签: raspberry-piserial-portpyserialttyusbserial

解决方案


好的,看起来我取得了一些进展,直到现在我做到了

  • 我去了'/boot/config.txt'并在离开一行后在文件末尾设置'dtoverlay=dwc2'

  • 我去了'/boot/cmdline.txt'并在'rootwait'之后放了'modules-load = dwc2,g_serial'留下了一个空格

  • 我做了这个'sudo nano /etc/rc.local'并将'modeprobe g_serial use_acm = 0'放在'exit 0'之前

  • 然后我执行了这个命令'sudo systemctl stop getty@ttyGS0.service'然后这个'sudo systemctl disable getty@ttyGS0.service'(我认为禁用getty@ttyGS0.service并将'modeprobe g_serial use_acm = 0'放在提到的文件夹中以上允许 rpi 和 pc 进行通信,但我又可能错了)

  • 然后执行“sudo reboot”

这似乎解决了我的问题

但是我现在还有一个问题,无论从 rpi 发送什么,我都只能在coolterm串行端口读取软件中接收到我似乎无法使用从处理中读取端口(我使用处理来稍后读取正在发送的图像文件)这是我目前正在处理的串行阅读程序

import processing.serial.*;
Serial myPort;  // Create object from Serial class
String val;     // Data received from the serial port
void setup()
{
  myPort = new Serial(this, "COM13", 115200);
}
void draw()
{
  if ( myPort.available() > 0) 
  {  // If data is available,
    val = myPort.readStringUntil('\n');         // read it and store it in val
  } 
  if (val!=null)
  {
    println(val); //print it out in the console
  }
}

我有点卡在这里:P

编辑 welp 没关系我解决了它我终于让它工作了 yaaaaaaaayyy 好的现在记住所有在使用 /dev/ttyGS0 时寻求答案的人它使用 CTS 和 RTS protocall(现在 idk 如果它可以被禁用但请让我知道你们)

  • 就像 pi 询问您的 pc 是否可以发送数据,当 pc 说可以发送数据时,pi 会发送数据,所以每当您使用此方法时,请启用 rts 或 cts 这就是我在处理中用来接收数据
import processing.serial.*;
Serial myPort;
void setup()
{
  //remember to set the COM port to which your pi is set
  size(200, 200);
  myPort = new Serial(this, "COM13", 115200);
  
}
void draw()
{
  
  if ( myPort.available() > 0)
  {
    if(myPort.getCTS()==true){
      myPort.setRTS(true);
      print(myPort.read());
    }
  } 
}

我希望这对你们有帮助,但如果需要更正,请让我知道你们:D 谢谢


推荐阅读