From owner-freebsd-usb@freebsd.org Wed Nov 18 19:02:19 2015 Return-Path: Delivered-To: freebsd-usb@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 2CCCAA32662 for ; Wed, 18 Nov 2015 19:02:19 +0000 (UTC) (envelope-from bsmply@gmail.com) Received: from mail-ob0-x234.google.com (mail-ob0-x234.google.com [IPv6:2607:f8b0:4003:c01::234]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G2" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id DF79A1F8F; Wed, 18 Nov 2015 19:02:18 +0000 (UTC) (envelope-from bsmply@gmail.com) Received: by obbnk6 with SMTP id nk6so41168943obb.2; Wed, 18 Nov 2015 11:02:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; bh=Xn4FmQ5Cu628qDUSQde35xIolvpgEbnA629fY9WLlU0=; b=rHaG4DoBILOpHTBo9iYiuJFsGMR3OahXqM3h6EjpGLdNigzw0PpX56WpV9E5BBHv01 0bF8I6Vwd6MKWs0Oriy4kI8nVF1jISNiW5JPFdx/0iedjb0vK3X+N/eTRBZ0CVwSRHDJ pnY5NQScyfwEMVF8YWMJDd6gQ8rwuIMksvkvzGhdvNKTBnxk+hbc62QU2eW7VFD8VTcS RyKcri++IUQS5INuDWllwXbF1vE0GtKH7L1tpYNoXOq8eUQ3gsyFrzRBi1wKasHH63GK yAkC3ZO6TnV0GDS8+n/Z6bFQppIDs+FtzPnQnUqY/CsDEWHsHpXLKk6mqExcQF7gA3L3 Gmfg== MIME-Version: 1.0 X-Received: by 10.60.67.234 with SMTP id q10mr2080487oet.73.1447873338174; Wed, 18 Nov 2015 11:02:18 -0800 (PST) Received: by 10.76.44.145 with HTTP; Wed, 18 Nov 2015 11:02:17 -0800 (PST) In-Reply-To: <1447279455.91061.24.camel@freebsd.org> References: <56421DFD.6070503@selasky.org> <564222D8.6020900@selasky.org> <56422764.4040307@selasky.org> <1447277889.91061.22.camel@freebsd.org> <1447279455.91061.24.camel@freebsd.org> Date: Wed, 18 Nov 2015 14:02:17 -0500 Message-ID: Subject: Re: How to access a FTDI usb device with a custom vendor and product id's From: Burton Sampley To: Ian Lepore Cc: Hans Petter Selasky , freebsd-usb@freebsd.org Content-Type: text/plain; charset=UTF-8 X-Content-Filtered-By: Mailman/MimeDel 2.1.20 X-BeenThere: freebsd-usb@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: FreeBSD support for USB List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 18 Nov 2015 19:02:19 -0000 To All, A quick update: I really have no update. I have been attempting to get to the point where I can test the newly built module, but I can not get my system to the point where I can try the new module. I was able to compile it, but when I attempted to load the new module, I get the following error: # /usr/bin/grep uftdi /var/log/messages Nov 12 08:14:39 gentoo kernel: KLD uftdi.ko: depends on kernel - not available or version mismatch # I then updated my system and source code, now the kernel will not compile. I searched and found a few posts on one of the FreeBSD forums, which stated the problems might be resolved by "buildworld" first, then "buildkernel", "install kernel", reboot single-user and "installworld". After the latest update and reboot, "buildworld" fails. I don't want to move on to "buildkernel" until I can resolve the "buildworld" failure first. # /usr/sbin/freebsd-update fetch Looking up update.FreeBSD.org mirrors... none found. Fetching metadata signature for 10.2-RELEASE from update.FreeBSD.org... done. Fetching metadata index... done. Inspecting system... done. Preparing to download files... done. No updates needed to update system to 10.2-RELEASE-p7. # Made sure my source code is proper and up to date: # /usr/local/bin/svn info Path: . Working Copy Root Path: /usr/src URL: https://svn.freebsd.org/base/stable/10 Relative URL: ^/stable/10 Repository Root: https://svn.freebsd.org/base Repository UUID: ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f Revision: 291024 Node Kind: directory Schedule: normal Last Changed Author: gjb Last Changed Rev: 290995 Last Changed Date: 2015-11-17 13:22:56 -0500 (Tue, 17 Nov 2015) # /usr/local/bin/svn update /usr/src Updating '.': At revision 291024. # In between each failed "buildworld" attempt, I have followed the instructions for resetting /usr/obj in the handbook in the "buildworld" ( https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html) section. Here's where "buildworld" fails: --------------------------- ===> usr.sbin/pw (all) cc -O2 -pipe -std=gnu99 -Qunused-arguments -fstack-protector -Wsystem-headers -Werror -Wall -Wno-format-y2k -W -Wno-unused-parameter -Wstrict-prototypes -Wmissing-prototypes -Wpointer-arith -Wno-uninitialized -Wno-pointer-sign -Wno-empty-body -Wno-string-plus-int -Wno-unused-const-variable -Wno-tautological-compare -Wno-unused-value -Wno-parentheses-equality -Wno-unused-function -Wno-enum-conversion -c /usr/src/usr.sbin/pw/pw.c -o pw.o /usr/src/usr.sbin/pw/pw.c:90:21: error: tentative definition of variable with internal linkage has incomplete non-array type 'struct cargs' [-Werror,-Wtentative-definition-incomplete-type] static struct cargs arglist; ^ --------------------------- I assume my issues are outside of the scope of this specific list, but I can not test the simple changes to the uftdi.ko module if I can't get the module to build and load into the running kernel. Here's my current kernel (don't be deceived by the hostname, it's FreeBSD... the hardware used to run Gentoo and I was too lazy to change the hostname/IP on my internal DNS server - which is also running FreeBSD): # /usr/bin/uname -a FreeBSD gentoo.chicken.fish 10.2-RELEASE-p7 FreeBSD 10.2-RELEASE-p7 #0: Mon Nov 2 14:19:39 UTC 2015 root@amd64-builder.daemonology.net:/usr/obj/usr/src/sys/GENERIC amd64 # What am I missing, or can someone please point me in the right direction of how to successfully "buildworld" so I can then, build a GENERIC kernel and install everything? BTW, I for the kernel build file, I simply made a copy of GENERIC, with a new name and no other modifications. Regards, -Burton On Wed, Nov 11, 2015 at 5:04 PM, Ian Lepore wrote: > On Wed, 2015-11-11 at 16:57 -0500, Burton Sampley wrote: > > Ian, > > > > Thank you for your prompt reply. > > > > Looking at the usbdevs file, I found 0x2100, but there is no entry > > for > > 0x9e56, which is my device. So, I'm assuming that changing uftdi.c > > to the > > correct name for the VID will only solve part of my problem. I will > > further assume that I need to find the correct/proper entry for > > usbdevs as > > well. Is this a correct assumption? If so, then how/where can I > > find the > > proper entry for usbdevs? > > > > Here's the 2 closest entries: > > > > /* RT system products */ > > product RTSYSTEMS CT29B 0x9e54 FTDI compatible adapter > > product RTSYSTEMS SERIAL_VX7 0x9e52 FTDI compatible > > adapter > > > > For me, what appears to be the last piece of the puzzle is to find > > the > > correct name to place in the 3rd field. Based on the following: > > > > $ /usr/local/bin/sudo /usr/sbin/usbconfig -d ugen2.3 dump_device_desc > > ugen2.3: at usbus2, cfg=0 md=HOST > > spd=FULL > > (12Mbps) pwr=ON (90mA) > > > > bLength = 0x0012 > > bDescriptorType = 0x0001 > > bcdUSB = 0x0200 > > bDeviceClass = 0x0000 > > bDeviceSubClass = 0x0000 > > bDeviceProtocol = 0x0000 > > bMaxPacketSize0 = 0x0008 > > idVendor = 0x2100 > > idProduct = 0x9e56 > > bcdDevice = 0x0600 > > iManufacturer = 0x0001 > > iProduct = 0x0002 > > iSerialNumber = 0x0003 > > bNumConfigurations = 0x0001 > > > > $ > > > > does "CT-62B" look reasonable? > > > > Yep, you'll have to add a new entry to usbdevs for the the 0x9e56 > device. CT62B seems like a good name (can't put the dash in the name > for C syntax reasons). > > -- Ian > > > > > Regards, > > > > -Burton > > > > On Wed, Nov 11, 2015 at 4:38 PM, Ian Lepore wrote: > > > > > On Wed, 2015-11-11 at 16:28 -0500, Burton Sampley wrote: > > > > I added a line to the table, but it seems to have failed since I > > > > used > > > > the > > > > VID# instead of the VID# name. Where are the VID names mapped to > > > > the > > > > VID#'s? Apparently, I know enough about coding to be dangerous. > > > > I'll do > > > > some more digging to try to fix my own error. > > > > > > > > Here's a diff of the original source and my modified source: > > > > > > > > [/usr/src/sys/dev/usb/serial]$ /usr/bin/diff ./uftdi.c > > > > ./uftdi.c.ORIG > > > > 914d913 > > > > < UFTDI_DEV(2100, 9e56, 0), > > > > [/usr/src/sys/dev/usb/serial]$ > > > > > > > > Here's the compile splattage: > > > > > > The VID and PID names are in the file src/sys/dev/usb/usbdevs. > > > > > > -- Ian > > > > > > > > > > -- Your mind is like a parachute, it works much better when it is open.