svn commit: r326054 - stable/10/sys/ofed/include/linux
Hans Petter Selasky
hselasky at FreeBSD.org
Tue Nov 21 10:19:34 UTC 2017
Author: hselasky
Date: Tue Nov 21 10:19:33 2017
New Revision: 326054
URL: https://svnweb.freebsd.org/changeset/base/326054
Log:
MFC r299674 and r299931:
Handle case of class being set, but not parent when calling
device_register() in the LinuxKPI.
Requested by: Chelsio
Sponsored by: Mellanox Technologies
Modified:
stable/10/sys/ofed/include/linux/device.h
Directory Properties:
stable/10/ (props changed)
Modified: stable/10/sys/ofed/include/linux/device.h
==============================================================================
--- stable/10/sys/ofed/include/linux/device.h Tue Nov 21 09:08:27 2017 (r326053)
+++ stable/10/sys/ofed/include/linux/device.h Tue Nov 21 10:19:33 2017 (r326054)
@@ -2,7 +2,7 @@
* Copyright (c) 2010 Isilon Systems, Inc.
* Copyright (c) 2010 iX Systems, Inc.
* Copyright (c) 2010 Panasas, Inc.
- * Copyright (c) 2013, 2014 Mellanox Technologies, Ltd.
+ * Copyright (c) 2013-2016 Mellanox Technologies, Ltd.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
@@ -294,15 +294,19 @@ device_register(struct device *dev)
int unit;
bsddev = NULL;
+ unit = -1;
+
if (dev->devt) {
unit = MINOR(dev->devt);
bsddev = devclass_get_device(dev->class->bsdclass, unit);
- } else
- unit = -1;
- if (bsddev == NULL)
+ } else if (dev->parent == NULL) {
+ bsddev = devclass_get_device(dev->class->bsdclass, 0);
+ }
+ if (bsddev == NULL && dev->parent != NULL) {
bsddev = device_add_child(dev->parent->bsddev,
dev->class->kobj.name, unit);
- if (bsddev) {
+ }
+ if (bsddev != NULL) {
if (dev->devt == 0)
dev->devt = makedev(0, device_get_unit(bsddev));
device_set_softc(bsddev, dev);
More information about the svn-src-all
mailing list