Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/external/bsd/drm2/dist/drm/radeon Forgot this file for r...
details: https://anonhg.NetBSD.org/src/rev/d33ec6f7f47c
branches: trunk
changeset: 330932:d33ec6f7f47c
user: riastradh <riastradh%NetBSD.org@localhost>
date: Fri Jul 25 12:48:34 2014 +0000
description:
Forgot this file for radeondrmkmsfb.
diffstat:
sys/external/bsd/drm2/dist/drm/radeon/radeon_fb.c | 34 +++++++++++++++++-----
1 files changed, 26 insertions(+), 8 deletions(-)
diffs (62 lines):
diff -r d159247cc529 -r d33ec6f7f47c sys/external/bsd/drm2/dist/drm/radeon/radeon_fb.c
--- a/sys/external/bsd/drm2/dist/drm/radeon/radeon_fb.c Fri Jul 25 12:47:18 2014 +0000
+++ b/sys/external/bsd/drm2/dist/drm/radeon/radeon_fb.c Fri Jul 25 12:48:34 2014 +0000
@@ -37,6 +37,10 @@
#include <linux/vga_switcheroo.h>
+#ifdef __NetBSD__
+#include "radeondrmkmsfb.h"
+#endif
+
/* object hierarchy -
this contains a helper + a radeon fb
the helper contains a pointer to radeon framebuffer baseclass.
@@ -243,12 +247,22 @@
}
(void)memset(rbo->kptr, 0, radeon_bo_size(rbo));
- ret = radeon_genfb_attach(rdev->ddev, helper, sizes, rbo);
- if (ret) {
- DRM_ERROR("failed to attach genfb: %d\n", ret);
+
+ {
+ static const struct radeonfb_attach_args zero_rfa;
+ struct radeonfb_attach_args rfa = zero_rfa;
+
+ rfa.rfa_fb_helper = helper;
+ rfa.rfa_fb_sizes = *sizes;
+ rfa.rfa_fb_ptr = rbo->kptr;
+
+ helper->fbdev = config_found_ia(rdev->ddev->dev, "radeonfbbus", &rfa,
+ NULL);
+ if (helper->fbdev == NULL) {
+ DRM_ERROR("failed to attach genfb\n");
goto out_unref;
}
- helper->genfb_attached = true;
+ }
fb = &rfbdev->rfb.base;
rfbdev->helper.fb = fb;
#else
@@ -346,12 +360,16 @@
struct fb_info *info;
#endif
struct radeon_framebuffer *rfb = &rfbdev->rfb;
+#ifdef __NetBSD__
+ int ret;
+#endif
#ifdef __NetBSD__
- if (rfbdev->helper.genfb_attached) {
- /* XXX detach genfb for real... */
- (void)config_detach_children(dev->dev, DETACH_FORCE);
- }
+ /* XXX errno NetBSD->Linux */
+ ret = -config_detach(rfbdev->helper.fbdev, DETACH_FORCE);
+ if (ret)
+ DRM_ERROR("failed to detach radeonfb: %d\n", ret);
+ rfbdev->helper.fbdev = NULL;
#else
if (rfbdev->helper.fbdev) {
info = rfbdev->helper.fbdev;
Home |
Main Index |
Thread Index |
Old Index