From owner-p4-projects@FreeBSD.ORG Wed Jul 18 17:28:18 2007 Return-Path: X-Original-To: p4-projects@freebsd.org Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id 5A97E16A405; Wed, 18 Jul 2007 17:28:18 +0000 (UTC) X-Original-To: perforce@FreeBSD.org Delivered-To: perforce@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id 243F616A402 for ; Wed, 18 Jul 2007 17:28:18 +0000 (UTC) (envelope-from thioretic@FreeBSD.org) Received: from repoman.freebsd.org (repoman.freebsd.org [69.147.83.41]) by mx1.freebsd.org (Postfix) with ESMTP id 0770E13C494 for ; Wed, 18 Jul 2007 17:28:18 +0000 (UTC) (envelope-from thioretic@FreeBSD.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.14.1/8.14.1) with ESMTP id l6IHSH7C048861 for ; Wed, 18 Jul 2007 17:28:17 GMT (envelope-from thioretic@FreeBSD.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.14.1/8.14.1/Submit) id l6IHSHCa048858 for perforce@freebsd.org; Wed, 18 Jul 2007 17:28:17 GMT (envelope-from thioretic@FreeBSD.org) Date: Wed, 18 Jul 2007 17:28:17 GMT Message-Id: <200707181728.l6IHSHCa048858@repoman.freebsd.org> X-Authentication-Warning: repoman.freebsd.org: perforce set sender to thioretic@FreeBSD.org using -f From: Maxim Zhuravlev To: Perforce Change Reviews Cc: Subject: PERFORCE change 123699 for review X-BeenThere: p4-projects@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: p4 projects tree changes List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 18 Jul 2007 17:28:18 -0000 http://perforce.freebsd.org/chv.cgi?CH=123699 Change 123699 by thioretic@thioretic on 2007/07/18 17:27:28 Just some load code for DR_REQDEV drivers. Affected files ... .. //depot/projects/soc2007/thioretic_gidl/kern/subr_bus.c#17 edit Differences ... ==== //depot/projects/soc2007/thioretic_gidl/kern/subr_bus.c#17 (text+ko) ==== @@ -4662,8 +4662,8 @@ drv_internal_t drv_intnl; kobj_class_t driver; char* parents[]; - int count=0, isfilter; - device_t dev; + int count=0, isfilter, devcount; + device_t dev, *devices; dmd = (struct driver_module_data *)arg; drv_intnl = dmd->dmd_driver; @@ -4702,14 +4702,14 @@ parentname = driver->baseclasses[0]->name; *dmd->dmd_devclass = devclass_find_internal(driver->name, - parentname, TRUE); + parentname, TRUE, FALSE); } else { *dmd->dmd_devclass = - devclass_find_internal(driver->name, 0, TRUE); + devclass_find_internal(driver->name, 0, TRUE, FALSR); } if(drv_intnl->flags & DR_REQDEV){ /*restrict to DR_LOWEST? */ - dev = make_device (root_bus, DRIVERNAME(driver), -1/*, driver*/); + dev = make_device (root_bus, DRIVERNAME(driver), -1); device_set_driver(dev, driver); /*if (!hasclass)*/ device_set_devclass(dev, driver->name); @@ -4718,12 +4718,21 @@ resource_int_value(dl->driver->name, child->unit, "flags", &child->devflags); */ + count = 0; + while (parents[count]){ + if (!(parent_devclass = devclass_find(parents[count++]))) + continue; + devclass_get_devices(parent_devclass, &devices, &devcount); + for (i=0, i