From owner-freebsd-hackers@freebsd.org Sun Feb 25 17:23:17 2018 Return-Path: Delivered-To: freebsd-hackers@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id C672FF02425 for ; Sun, 25 Feb 2018 17:23:16 +0000 (UTC) (envelope-from ian@freebsd.org) Received: from outbound1b.ore.mailhop.org (outbound1b.ore.mailhop.org [54.200.247.200]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 53A08680CD for ; Sun, 25 Feb 2018 17:23:16 +0000 (UTC) (envelope-from ian@freebsd.org) X-MHO-User: 7fc9e6f3-1a50-11e8-bb8e-b35b57339d60 X-Report-Abuse-To: https://support.duocircle.com/support/solutions/articles/5000540958-duocircle-standard-smtp-abuse-information X-Originating-IP: 67.177.211.60 X-Mail-Handler: DuoCircle Outbound SMTP Received: from ilsoft.org (unknown [67.177.211.60]) by outbound1.ore.mailhop.org (Halon) with ESMTPSA id 7fc9e6f3-1a50-11e8-bb8e-b35b57339d60; Sun, 25 Feb 2018 17:22:48 +0000 (UTC) Received: from rev (rev [172.22.42.240]) by ilsoft.org (8.15.2/8.15.2) with ESMTP id w1PHN78a072827; Sun, 25 Feb 2018 10:23:07 -0700 (MST) (envelope-from ian@freebsd.org) Message-ID: <1519579387.91697.252.camel@freebsd.org> Subject: Re: Help, please, with getting a custom I2C real time clock module to load From: Ian Lepore To: Lee D , freebsd-hackers@freebsd.org Date: Sun, 25 Feb 2018 10:23:07 -0700 In-Reply-To: References: Content-Type: text/plain; charset="ISO-8859-1" X-Mailer: Evolution 3.18.5.1 FreeBSD GNOME Team Port Mime-Version: 1.0 Content-Transfer-Encoding: 8bit X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.25 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 25 Feb 2018 17:23:17 -0000 On Sun, 2018-02-25 at 09:48 -0500, Lee D wrote: > Hi Everyone, > > I have written a new I2C driver (for the Xilinx Zynq) and a new real > time clock chip driver (for the ST M41T82) to use with hardware on my > custom board.  This is for 11.0.1. > > The I2C driver works fine, but I can't seem to get my RTC driver to > load.  The m41t82_probe() function is never even called. > > Both are loaded with kldload at the moment. > > I think the problem is something in DRIVER_MODULE macro that is > preventing the kernel from even trying to let it probe.  One clue is > that if I change "iicbus" to "simplebus" in the DRIVER_MODULE macro > of the RTC, it will then at least call m41t82_probe(). > > It's like the kernel thinks that I have no iicbus driver and thus > won't even try to load the RTC module. > > I have turned on "device iic" and "device iicbus" in my kernel config > file. > > No messages are given when I try to load the m41t82 module.  It just > silently loads and does nothing. > > Here is a code snippet from my I2C driver: > ------------------------------------------ > > static driver_t i2c_driver = { >   "i2c", >   i2c_methods, >   sizeof(struct i2c_softc), > }; > static devclass_t  i2c_devclass; > > DRIVER_MODULE(iicbus, i2c, iicbus_driver, iicbus_devclass, 0, 0); > DRIVER_MODULE(i2c, simplebus, i2c_driver, i2c_devclass, 0, 0); > Right here is where the disconnect is happening.  It's the ofw_iicbus driver that needs to declared in the first DRIVER_MODULE() instead of iicbus, because ofw_iicbus is the one that knows to look in the fdt data for slave devices and add them as children of the bus.  But, the extern declarations needed to do that didn't exist until I added them last week in r329526. What i2c drivers have been doing in the past, and the way to work around it in the 11.x code you're dealing with, is to leverage one of the DRIVER_MODULE() declarations that already exists in ofw_iicbus, by naming your driver "iichb" instead of "i2c".  Like this: static driver_t i2c_driver = {   "iichb",   i2c_methods,   sizeof(struct i2c_softc), }; Or you could import r329526 into the kernel source you're using and rebuild the kernel.  I do intend to MFC that change to 11-stable (in fact, I should probably do that today). When you've got these new drivers working, please consider putting them up for review at https://reviews.freebsd.org and we'll get them committed to freebsd. -- Ian