From owner-freebsd-stable@FreeBSD.ORG Wed Aug 6 09:34:45 2008 Return-Path: Delivered-To: stable@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 90B4C1065680 for ; Wed, 6 Aug 2008 09:34:45 +0000 (UTC) (envelope-from gavin@FreeBSD.org) Received: from mail-gw1.york.ac.uk (mail-gw1.york.ac.uk [144.32.128.246]) by mx1.freebsd.org (Postfix) with ESMTP id 415548FC15 for ; Wed, 6 Aug 2008 09:34:45 +0000 (UTC) (envelope-from gavin@FreeBSD.org) Received: from mail-gw7.york.ac.uk (mail-gw7.york.ac.uk [144.32.129.30]) by mail-gw1.york.ac.uk (8.13.6/8.13.6) with ESMTP id m769Yfh4012456; Wed, 6 Aug 2008 10:34:42 +0100 (BST) Received: from buffy-128.york.ac.uk ([144.32.128.160] helo=buffy.york.ac.uk) by mail-gw7.york.ac.uk with esmtps (TLSv1:AES256-SHA:256) (Exim 4.68) (envelope-from ) id 1KQfPl-000269-OS; Wed, 06 Aug 2008 10:34:41 +0100 Received: from buffy.york.ac.uk (localhost [127.0.0.1]) by buffy.york.ac.uk (8.14.2/8.14.2) with ESMTP id m769YfPk017551; Wed, 6 Aug 2008 10:34:41 +0100 (BST) (envelope-from gavin@FreeBSD.org) Received: (from ga9@localhost) by buffy.york.ac.uk (8.14.2/8.14.2/Submit) id m769YeBs017550; Wed, 6 Aug 2008 10:34:40 +0100 (BST) (envelope-from gavin@FreeBSD.org) X-Authentication-Warning: buffy.york.ac.uk: ga9 set sender to gavin@FreeBSD.org using -f From: Gavin Atkinson To: Alexandre Biancalana In-Reply-To: <8e10486b0808040949ka12edf0o38e3a790d620992e@mail.gmail.com> References: <8e10486b0807030908i4c6f70bbp3f8e8907c7443259@mail.gmail.com> <1215105220.32135.18.camel@buffy.york.ac.uk> <8e10486b0807031041o54349836i31c5da84ebda70f6@mail.gmail.com> <1215176991.36376.24.camel@buffy.york.ac.uk> <8e10486b0807040834m27a38254k5261535d93d70ce6@mail.gmail.com> <8e10486b0808040949ka12edf0o38e3a790d620992e@mail.gmail.com> Content-Type: text/plain Content-Transfer-Encoding: 7bit Date: Wed, 06 Aug 2008 10:34:40 +0100 Message-Id: <1218015280.17311.11.camel@buffy.york.ac.uk> Mime-Version: 1.0 X-Mailer: Evolution 2.22.2 FreeBSD GNOME Team Port X-York-MailScanner: Found to be clean X-York-MailScanner-From: gavin@freebsd.org Cc: stable@FreeBSD.org, brian@FreeBSD.org Subject: Re: DigiBoard Xem with 2 extenal modules X-BeenThere: freebsd-stable@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Production branch of FreeBSD source code List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 06 Aug 2008 09:34:45 -0000 On Mon, 2008-08-04 at 13:49 -0300, Alexandre Biancalana wrote: > On 7/4/08, Alexandre Biancalana wrote: > > On 7/4/08, Gavin Atkinson wrote: > > > It's not a solution, but it may well be a great help in diagnosing where > > > the problem lies: it would be useful to know if the driver is simply > > > failing to detect the correct number of ports, or if the driver > > > physically cannot use them. > > > > > > In /usr/src/sys/dev/digi/digi.c, line 510, you'll see the following > > > code: > > > > > > if (sc->numports == 0) { > > > device_printf(sc->dev, "%s, 0 ports found\n", sc->name); > > > sc->hidewin(sc); > > > return (0); > > > } > > > > > > Just before that section, can you add a line "sc->numports = 32;", > > > recompile, and see if the missing 16 ports are usable? If they are, I > > > suspect fixing the driver will be trivial. > > > > > > Wow !! Now the 32 ports are detected and devices created. > > > > # digictl -d 1 -r /dev/digi0.ctl > > > > digi0: Got init reset after 0 us > > digi0: BIOS uploaded > > digi0: BIOS started after 0 us > > > > digi0: BIOS booted after 1619 iterations > > > > digi0: Loading FEP/OS > > digi0: FEP/OS loaded > > digi0: FEP/OS started after 28 iterations > > > > digi0: Digiboard PCI PC/Xem ASIC, 32 ports found > > > > # ls /dev/cuaD?? | wc -l > > 32 > > > > I will connect some modems to that ports to test and let you know. > > Modems connected but they only work on ports of the first module, any > decice connected on ports of second module does not work. > > Any other idea ? Sadly, I'm all out of ideas. If, with the change above, the ports were usable then it would have meant that the problem was around the code that configures the card and detects the number of ports. As the ports don't work even after forcing the number, it is possible that the driver simply does not support more than 16 ports at the moment. Unless you can get hold of a developer who knows the hardware (I've cc'd Brian as a possible person who fits this category), or are able to obtain the datasheets yourself, I think the only solution may be to compare the Linux driver to ours and see if it does anything differently during initialisation (especially before the code to detect the number of ports). Gavin