From owner-freebsd-arm@freebsd.org Thu Jan 26 06:27:44 2017 Return-Path: Delivered-To: freebsd-arm@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id C0C86CC2E65 for ; Thu, 26 Jan 2017 06:27:44 +0000 (UTC) (envelope-from tony@tndh.net) Received: from express.tndh.net (express.tndh.net [IPv6:2001:470:e930:1240:20d:56ff:fe04:4c0a]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 9CF78A1C; Thu, 26 Jan 2017 06:27:44 +0000 (UTC) (envelope-from tony@tndh.net) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=tndh.net; s=dkim; h=Subject:Content-Transfer-Encoding:Content-Type:MIME-Version:Message-ID:Date:In-Reply-To:References:To:From; bh=mDdjJHCcHkbv/dyEx6I85Yz5Qsr5nsJxGzg4JszLx+I=; b=AwxbGX+BYKHL//oM2fnrh3BUtBWGpusUUr5mWO0P57evnbJ06EiivBapoRxpJ/EMOHElnJMdz0Eg0DWr/8dCrmNS5zVcseQ/Po0jAbKSXlcLdK9MCxgZjjTZdHPi9Xj0rOm9z2pCLpBqNSlzITTfrPYrLjLWDy0OYtqK7ib0FfvlrpOG; Received: from express.tndh.net ([2001:470:e930:1240:20d:56ff:fe04:4c0a] helo=eaglet) by express.tndh.net with esmtp (Exim 4.72 (FreeBSD)) (envelope-from ) id 1cWdWq-000L71-Dx; Wed, 25 Jan 2017 22:27:43 -0800 From: "Tony Hain" To: "'Ian Lepore'" , References: <03a801d2776e$cae997e0$60bcc7a0$@tndh.net> <1485400906.30533.54.camel@freebsd.org> In-Reply-To: <1485400906.30533.54.camel@freebsd.org> Date: Wed, 25 Jan 2017 22:27:30 -0800 Message-ID: <03bb01d2779d$45d6edd0$d184c970$@tndh.net> MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable X-Mailer: Microsoft Outlook 14.0 Thread-Index: AQEImxvIZ6VEPYS1CTeMHuF4SjTdHgFGeuiPotPEM5A= Content-Language: en-us X-SA-Exim-Connect-IP: 2001:470:e930:1240:20d:56ff:fe04:4c0a X-SA-Exim-Mail-From: tony@tndh.net X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on express.tndh.net X-Spam-Level: X-Spam-Status: No, score=-4.2 required=4.5 tests=ALL_TRUSTED,RP_MATCHES_RCVD autolearn=unavailable version=3.3.1 Subject: RE: BBB uarts & pps dts definitions X-SA-Exim-Version: 4.2 X-SA-Exim-Scanned: Yes (on express.tndh.net) X-BeenThere: freebsd-arm@freebsd.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: "Porting FreeBSD to ARM processors." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 26 Jan 2017 06:27:44 -0000 Ian Lepore wrote: Thanks for the quick reply. Sorry I should have been clear about which build. FreeBSD 11.0-STABLE #0 r310359: Wed Dec 21 16:47:56 UTC 2016 I commented out the phandle lines, and uart1 is working. >=20 > When I first read this I figured some change over the past few months = must > have broken the driver. =A0But I just built a fresh world and kernel = for > beaglebone and fired up my BB and hooked a PPS signal to P8-7 and it = all still > works fine. >=20 > You don't need to do anything with the dts, the dmtpps driver will > reconfigure the pin to be a PPS input, overriding whatever the FDT = data > might have set up. =A0All you need to do is set a couple lines in > /boot/loader.conf: >=20 > =A0 hw.am335x_dmtpps.input=3D"P8-7" > =A0 am335x_dmtpps_load=3DYES I had done that: # cat /boot/loader.conf am335x_dmtpps_load=3D"YES" hw.am335x_dmtpps.input=3D"P8-7" does order matter? The device showed up: # ls -l /dev|grep dmtpps crw------- 1 root wheel 0x35 Jan 25 20:13 dmtpps lrwxr-xr-x 1 root wheel 6 Jan 25 20:13 pps0 -> dmtpps # dmesg|grep pps am335x_dmtpps0: mem 0x48044000-0x480443ff = irq 30 on simplebus0 =20 >=20 > You can even do it all interactively without any config, even just = booting from > a downloaded weekly snapshot, then do this: >=20 > =A0=A0kenv hw.am335x_dmtpps.input=3D"p8-7" > =A0 kldload am335x_dmtpps >=20 > You should see something like this (some of this is extra bootverbose output, > so you may not see all these lines)... >=20 > =A0=A0root@bb:~ # kldload am335x_dmtpps > =A0 ti_pinmux0: setting internal 2a for timer4 > =A0 am335x_dmtpps: configured pin p8-7 as input for timer4 > =A0 am335x_dmtpps0: mem 0x48044000- > 0x480443ff irq 30 on simplebus0 > =A0 Timecounter "DMTimer4" frequency 24000000 Hz quality 1000 > =A0 am335x_dmtpps0: Using DMTimer4 for PPS device /dev/dmtpps >=20 > If you have full source code on the BB, do: Didn't really want to put full source on the BBB.=20 >=20 > =A0=A0cd /usr/src/tools/test/ppsapi > =A0 make ppsapitest I had full source on a 10.1 system, so I copied the files in that = directory and tried to make, but it is complaining about the last line needing an operator. make: "src/ppsapitest/Makefile" line 13: Need an operator make: Fatal errors encountered -- cannot continue make: stopped in src/ppsapitest # $FreeBSD: releng/10.1/tools/test/ppsapi/Makefile 264485 2014-04-15 02:17:46Z gnn $ PROG=3D ppsapitest MK_MAN=3Dno WARNS?=3D 5 .include CFLAGS+=3D-Wno-format-security test: ${PROG} ./${PROG} /dev/cuau0 Even when it gets built though, the scope shows that the signal is being pulled to ground as soon as the wire is connected to P8-7, so I don't = expect it to work. Is there a way to check the state of the gpio? I would = expect something like # gpioctl -N gpio_66 Can't find pin named "gpio_66" # gpioctl -l pin 00: 0 gpio_0<> pin 01: 0 gpio_1<> ... pin 30: 1 gpio_30 pin 31: 1 gpio_31 # How do the 3 additional pinmux controllers get enabled? > =A0 ./ppsapitest /dev/dmtpps >=20 > You should get something like: >=20 > =A0 1485400775 .009578536 204 0 .000000000 0 > =A0 1485400776 .009621995 205 0 .000000000 0 > =A0 1485400777 .009665453 206 0 .000000000 0 > =A0 1485400778 .009708869 207 0 .000000000 0 >=20 > -- Ian