diff options
author | Jonathan Gray <jsg@cvs.openbsd.org> | 2013-09-02 10:18:27 +0000 |
---|---|---|
committer | Jonathan Gray <jsg@cvs.openbsd.org> | 2013-09-02 10:18:27 +0000 |
commit | 65a6596e435430ccd88f5ed70ce512c27b5e9864 (patch) | |
tree | b43440702e4908b40f094b8e4f1368876866b020 | |
parent | ab47c4f0ff0ef624e800355c86e1fe50aa493899 (diff) |
fb refcount must be initialised to 1 not 0 to match the behaviour
of the linux kref functions.
Switch to using the FreeBSD refcount api for the fb refcount while here.
-rw-r--r-- | sys/dev/pci/drm/drm_crtc.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/sys/dev/pci/drm/drm_crtc.c b/sys/dev/pci/drm/drm_crtc.c index 74b81a36414..b0146c38864 100644 --- a/sys/dev/pci/drm/drm_crtc.c +++ b/sys/dev/pci/drm/drm_crtc.c @@ -1,4 +1,4 @@ -/* $OpenBSD: drm_crtc.c,v 1.2 2013/09/02 06:25:27 jsg Exp $ */ +/* $OpenBSD: drm_crtc.c,v 1.3 2013/09/02 10:18:26 jsg Exp $ */ /* * Copyright (c) 2006-2008 Intel Corporation * Copyright (c) 2007 Dave Airlie <airlied@linux.ie> @@ -34,6 +34,7 @@ #include "drm_crtc.h" #include "drm_edid.h" #include "drm_fourcc.h" +#include "refcount.h" /* Avoid boilerplate. I'm tired of typing. */ #define DRM_ENUM_NAME_FN(fnname, list) \ @@ -313,7 +314,7 @@ int drm_framebuffer_init(struct drm_device *dev, struct drm_framebuffer *fb, { int ret; - fb->refcount = 0; + refcount_init(&fb->refcount, 1); ret = drm_mode_object_get(dev, &fb->base, DRM_MODE_OBJECT_FB); if (ret) @@ -346,7 +347,7 @@ void drm_framebuffer_unreference(struct drm_framebuffer *fb) #ifdef notyet WARN_ON(!mutex_is_locked(&dev->mode_config.mutex)); #endif - if (--fb->refcount == 0) + if (refcount_release(&fb->refcount)) drm_framebuffer_free(fb); } EXPORT_SYMBOL(drm_framebuffer_unreference); @@ -357,7 +358,7 @@ EXPORT_SYMBOL(drm_framebuffer_unreference); void drm_framebuffer_reference(struct drm_framebuffer *fb) { DRM_DEBUG("FB ID: %d\n", fb->base.id); - fb->refcount++; + refcount_acquire(&fb->refcount); } EXPORT_SYMBOL(drm_framebuffer_reference); |