From nobody Tue Jan 24 12:53:44 2023 X-Original-To: freebsd-arm@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4P1Rjn1NP7z3bP7m for ; Tue, 24 Jan 2023 12:53:49 +0000 (UTC) (envelope-from fred@thegalacticzoo.com) Received: from nmtao201.oxsus-vadesecure.net (mta-231a.oxsus-vadesecure.net [15.204.3.4]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 4P1Rjl6LkVz48ls for ; Tue, 24 Jan 2023 12:53:47 +0000 (UTC) (envelope-from fred@thegalacticzoo.com) Authentication-Results: mx1.freebsd.org; dkim=pass header.d=webcom.xion.oxcs.net header.s=mail1 header.b=o+9UYFeD; spf=pass (mx1.freebsd.org: domain of fred@thegalacticzoo.com designates 15.204.3.4 as permitted sender) smtp.mailfrom=fred@thegalacticzoo.com; dmarc=pass (policy=quarantine) header.from=thegalacticzoo.com DKIM-Signature: v=1; a=rsa-sha256; bh=b1LFqUXebn9ZD3BYvTY+oQRi0qXnMu6eYP61+g d5uVQ=; c=relaxed/relaxed; d=webcom.xion.oxcs.net; h=from:reply-to: subject:date:to:cc:resent-date:resent-from:resent-to:resent-cc: in-reply-to:references:list-id:list-help:list-unsubscribe: list-subscribe:list-post:list-owner:list-archive; q=dns/txt; s=mail1; t=1674564826; x=1675169626; b=o+9UYFeDA2PEgXs/fVHT5mCngn8ACwf6bfG7YtSuv Y94WS98x6x/ORr+4o63uJWTC8SB/oLs85tsJA0gYyDY5BEvL3IksSmf5XqfaDY2D/aehewQ D70npI15ZnhPWnxy0PcsFZSVs8vtw2WJiw3wPm6+QMu2Qvoa/Vo39WyPJ1JAEbacJEFP7SP S8N8zAI1YBtnq4gONNMlT6V+g8eUmn3MEkMqhs92cXDcPzRUclD4gGGqiygvxcG14BJd+Ds Wp7XzYO0/Ao0I8AZvhKjMfQWQzXQdcEevHEoeLqrvS4ksTEF4U3Fj0dI/pN64wKfLY4VejR Y6VkxPqkSsQC5jjQg== Received: from proxy-12.proxy.cloudus.ewr.xion.oxcs.net ([76.14.221.149]) by oxsus2nmtao01p.internal.vadesecure.com with ngmta id 8e36903e-173d3fd631941e55; Tue, 24 Jan 2023 12:53:46 +0000 Message-ID: <97c23a36-a98e-f83c-e0e2-02bbeee0fdfe@thegalacticzoo.com> Date: Tue, 24 Jan 2023 04:53:44 -0800 List-Id: Porting FreeBSD to ARM processors List-Archive: https://lists.freebsd.org/archives/freebsd-arm List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-freebsd-arm@freebsd.org MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:102.0) Gecko/20100101 Thunderbird/102.6.1 Content-Language: en-US To: freebsd-arm@freebsd.org From: Fred Finster Subject: Testing All 5 Uarts on Raspberry Pi 4B Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spamd-Result: default: False [-4.00 / 15.00]; NEURAL_HAM_LONG(-1.00)[-1.000]; NEURAL_HAM_MEDIUM(-1.00)[-1.000]; NEURAL_HAM_SHORT(-1.00)[-0.999]; DMARC_POLICY_ALLOW(-0.50)[thegalacticzoo.com,quarantine]; R_DKIM_ALLOW(-0.20)[webcom.xion.oxcs.net:s=mail1]; R_SPF_ALLOW(-0.20)[+ip4:15.204.3.4]; MIME_GOOD(-0.10)[text/plain]; MIME_TRACE(0.00)[0:+]; MLMMJ_DEST(0.00)[freebsd-arm@freebsd.org]; RCVD_TLS_LAST(0.00)[]; FROM_EQ_ENVFROM(0.00)[]; ASN(0.00)[asn:16276, ipnet:15.204.0.0/17, country:FR]; ARC_NA(0.00)[]; DKIM_TRACE(0.00)[webcom.xion.oxcs.net:+]; RCVD_COUNT_TWO(0.00)[2]; FROM_HAS_DN(0.00)[]; RCVD_IN_DNSWL_NONE(0.00)[15.204.3.4:from]; TO_MATCH_ENVRCPT_ALL(0.00)[]; RCPT_COUNT_ONE(0.00)[1]; TO_DN_NONE(0.00)[]; MID_RHS_MATCH_FROM(0.00)[] X-Rspamd-Queue-Id: 4P1Rjl6LkVz48ls X-Spamd-Bar: --- X-ThisMailContainsUnwantedMimeParts: N TOP POST answer : https://forums.raspberrypi.com/viewtopic.php?t=244827  Testing of all 5 UARTS near bottom of this URL link https://forums.raspberrypi.com/viewtopic.php?t=244827&sid=9955627b0e7844c752f46b5ae55ef684&start=75 Page 4 URL link *I copied and pasted below.  I /apologize in advance for troubles I am inflicting on text only email viewers.  I have set my Thunderbird/* */email to send out only text email.   Fred/* FreeBSD creates /dev/ttyu1 Sounds like  you need to disable bt???? Adding "dtoverlay=disable-bt" switches the UART roles so that UART0 is mapped to 14 & 15 (Alt0), leaving UART1 unmapped. https://forums.raspberrypi.com/viewtopic.php?t=244827&sid=f4a784a3c40ed0940e6fbb9f81af5015&start=25#p1590882 Re: Pi-4 Activating additional UART ports Mon Jan 06, 2020 10:36 am On all Pis, UART0 is a PL011 that appear to Linux as ttyAMA, and UART1 is an 8250 clone that appears as ttyS0. On a Pi4, UART2-5 are additional PL011s that also appear as ttyAMA. The number starts at 0 for the first enabled PL011 and counts up through all the enabled interfaces. The numbering is stable for any given combination of UARTs, but enabling or disabling one can change the number assignments of others. Adding "enable_uart=1" to config.txt on a Pi4 enables ttyS0 (UART1) on GPIOs 14 & 15 (Alt5), leaving UART0 driving the Bluetooth interface on 30-33 (Alt3). Adding "dtoverlay=disable-bt" switches the UART roles so that UART0 is mapped to 14 & 15 (Alt0), leaving UART1 unmapped. As rpdom says, you can only enable one function on any pin at once, and enabling the same alternate function (e.g. RXD0) on multiple pins usually results in failure (outputs tend to work, inputs don't, but it is essentially undefined behaviour). *//* */ /* */From:/*John Rushford */Date:/*Sun, 22 Jan 2023 03:27:38 UTC Mark, Thanks for the reply. I only have “dtoverlay=uart3” in the config.txt and with that entry, FreeBSD creates /dev/ttyu1 and /dev/cuau1 along with the .init and .lock files. So, I tried with this entry in /etc/ttys and it was of no help, still no data: ttyu1 "none" vt100 on secure thanks John jjrushford@gmail.com > On Jan 21, 2023, at 8:18 PM, Mark Millard wrote: > > On Jan 21, 2023, at 18:34, John Rushford wrote: > >> I have installed FreeBSD 13.1 on a raspberry PI 4b rev 1.4 and I am trying to use the additional serial ports that are available with the PI 4 with an Adafruit ultimate GPS card. >> I found that it was problematic using the first serial port ttyu0 on GPIO pins 14 and 15 as data on the line from the GPS would interrupt the boot process and I verified that I was in fact able see data time stamps from the GPS card on the first uart port once I got FreeBSD to boot. >> >> Now since I do not wish to use the first serial port, I’ve built the rpi-firmware port and copied all the uart dtb’s to /boot/msdos/overlays and I’ve tried enabling the uart’s in /boot/msdos/config.txt with “dtoverlay=uart3” for example. >> Enabling them does in fact result in device entries created for them in /dev but, I am unable to see any data on the corresponding ttyuX or cuauX ports. >> >> Just to eliminate a wiring error, I installed another SD card with Raspberry PI OS, enabled uart3 and I am able to see data on uart3 without any issue confirming I have everything wired up properly. >> >> With FreeBSD, I have set the proper baud rate on the ports and I’ve tried disabling flow control on them, using stty, but no matter what I do, I never see any data on them. Unless I’m missing something, I can only conclude there is some bug in FreeBSD preventing me from using these additional serial ports. Has anyone here on this mailing list been able to use them? If so, what does it take? > > You did not mention /etc/ttys editing. So I wonder if you > changed any of the lines like, say, > > # Serial terminals > # The 'dialup' keyword identifies dialin lines to login, fingerd etc. > ttyu0 "/usr/libexec/getty 3wire" vt100 onifconsole secure > ttyu1 "/usr/libexec/getty 3wire" vt100 onifconsole secure > ttyu2 "/usr/libexec/getty 3wire" vt100 onifconsole secure > ttyu3 "/usr/libexec/getty 3wire" vt100 onifconsole secure > > to use, say, none instead of "/usr/libexec/getty 3wire", and other > related edits. > > But I've not tried to get any extra serial ports going on > an RPi4B. So the above is just guess work about something > to experiment with. > > === > Mark Millard > marklmi at yahoo.com https://forums.raspberrypi.com/viewtopic.php?t=244827 Testing All 5 Uarts on Raspberry Pi 4B near bottom of this URL link. Question has anybody here on FreeBSD arm mailing list group made some or all of the Raspbian Linux Tools operational on FreeBSD? Maybe this is a simple recompile with a couple modifications? I should just try myself first.  Just checking that NO ONE ELSE has already completed a Tool and is willing to share. raspi-gpio,  rasp-imager,  rasp-config, dtoverlay I suggest you start by running the following to establish whether the configuration has been successful: $ raspi-gpio get 0-15 $ ls /dev/ttyAMA* raspi-gpio get 0-15 GPIO 0: level=1 fsel=3 alt=4 func=TXD2 pull=NONE GPIO 1: level=1 fsel=3 alt=4 func=RXD2 pull=UP GPIO 2: level=1 fsel=4 alt=0 func=SDA1 pull=UP GPIO 3: level=1 fsel=4 alt=0 func=SCL1 pull=UP GPIO 4: level=1 fsel=3 alt=4 func=TXD3 pull=NONE GPIO 5: level=1 fsel=3 alt=4 func=RXD3 pull=UP GPIO 6: level=1 fsel=0 func=INPUT pull=UP GPIO 7: level=1 fsel=0 func=INPUT pull=UP GPIO 8: level=1 fsel=3 alt=4 func=TXD4 pull=NONE GPIO 9: level=1 fsel=3 alt=4 func=RXD4 pull=UP GPIO 10: level=0 fsel=0 func=INPUT pull=DOWN GPIO 11: level=0 fsel=0 func=INPUT pull=DOWN GPIO 12: level=1 fsel=3 alt=4 func=TXD5 pull=NONE GPIO 13: level=1 fsel=3 alt=4 func=RXD5 pull=UP GPIO 14: level=0 fsel=4 alt=0 func=TXD0 pull=NONE GPIO 15: level=1 fsel=4 alt=0 func=RXD0 pull=UP pi@raspberrypi:~$ ls /dev/ttyAMA* /dev/ttyAMA0 /dev/ttyAMA1 /dev/ttyAMA2 /dev/ttyAMA3 /dev/ttyAMA4 config.txt   file contains enable_uart=1 dtoverlay=pi3-miniuart-bt dtoverlay=uart5 dtoverlay=uart4 dtoverlay=uart3 dtoverlay=uart2 (The miniuart overlay uses ttyS0 for Bluetooth, freeing /dev/ttyAMA0). The help info shows the GPIOs used by each new UART - 0-3 for UART 2, 4-7 for 3, 8-11 for 4 and 12-15 for 5. This does mean that UART 5 overlaps with the standard UARTs on 14 & 15, but UART 5 has its flow control signals there - TXD5 and RXD5 appear on 12 & 13. I wonder, as GPIO 14 and 15 already used for uart0, how could Uart5 flow control use GPIO 14 & 15 ? By not enabling UART0. I deliberately reversed the order of the UART overlays to demonstrate that ordering here makes no difference to the ttyAMA numbering. Using this script: Code:Select all |#!/bin/sh sudo stty -F /dev/ttyAMA0 115200 sudo stty -F /dev/ttyAMA1 115200 sudo stty -F /dev/ttyAMA2 115200 sudo stty -F /dev/ttyAMA3 115200 sudo stty -F /dev/ttyAMA4 115200 while true; do sudo sh -c "echo 0 > /dev/ttyAMA0" sudo sh -c "echo 1 > /dev/ttyAMA1" sudo sh -c "echo 2 > /dev/ttyAMA2" sudo sh -c "echo 3 > /dev/ttyAMA3" sudo sh -c "echo 4 > /dev/ttyAMA4" sleep 1 done | and moving my PC serial cable around the pins I found the following mapping: Code:Select all |GPIO14 = TXD0 -> ttyAMA0 GPIO0 = TXD2 -> ttyAMA1 GPIO4 = TXD3 -> ttyAMA2 GPIO8 = TXD4 -> ttyAMA3 GPIO12 = TXD5 -> ttyAMA4 | In other words, transmitting works on all 5 PL011/ttyAMA UARTs. Running "cat /dev/ttyAMA" on each of the different UARTs in turn and moving the TX pin of the PC serial port around the various RXD pins produced the RX mapping: Anyone know of Top Hats for a Raspberry Pi 4 that brings all 5 uarts to a 3.3V TTL level and drive some LEDs to see TX and RX activity, plus MAX232 style drivers to shift from 3.3 Volt level to + - ~10V RS-232 drive level to a DB-9 IBM compatible D shell Connector?  With possibly a RS-485 driver style connection for long wiring runs? Does this exist?  or  Should one fire up KiCAD and design such a board specifically for Raspberry Pi 4B 5 uarts?  Probably a market size of 10 - 50 boards world wide, not much? Hope this works for you John R. -- Fred Finster fred@thegalacticzoo.com +1 971-718-9144 https://GhostBSD-ARM64.blogspot.com https://ghostbsd.org