Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/tpctl Try to use standard wsdisplay ioctls when HPC...
details: https://anonhg.NetBSD.org/src/rev/d2f433f32bb5
branches: trunk
changeset: 355993:d2f433f32bb5
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sun Aug 27 02:19:08 2017 +0000
description:
Try to use standard wsdisplay ioctls when HPCFBIO_GCONF is not available.
diffstat:
usr.sbin/tpctl/fb.c | 24 ++++++++++++++++++++----
1 files changed, 20 insertions(+), 4 deletions(-)
diffs (52 lines):
diff -r de23e5b6ee98 -r d2f433f32bb5 usr.sbin/tpctl/fb.c
--- a/usr.sbin/tpctl/fb.c Sun Aug 27 00:29:57 2017 +0000
+++ b/usr.sbin/tpctl/fb.c Sun Aug 27 02:19:08 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: fb.c,v 1.4 2008/05/10 15:31:05 martin Exp $ */
+/* $NetBSD: fb.c,v 1.5 2017/08/27 02:19:08 jmcneill Exp $ */
/*-
* Copyright (c) 2002 TAKEMRUA Shin
@@ -41,7 +41,7 @@
#ifndef lint
#include <sys/cdefs.h>
-__RCSID("$NetBSD: fb.c,v 1.4 2008/05/10 15:31:05 martin Exp $");
+__RCSID("$NetBSD: fb.c,v 1.5 2017/08/27 02:19:08 jmcneill Exp $");
#endif /* not lint */
#define INVALID_CACHE -1
@@ -69,6 +69,8 @@
int
fb_init(struct fb *fb, int fd)
{
+ struct wsdisplay_fbinfo fbinfo;
+ u_int linebytes;
int y;
size_t size;
@@ -77,8 +79,22 @@
fb->conf.hf_conf_index = HPCFB_CURRENT_CONFIG;
if (ioctl(fb->fd, WSDISPLAYIO_GMODE, &fb->dispmode) < 0)
return (-1);
- if (ioctl(fb->fd, HPCFBIO_GCONF, &fb->conf) < 0)
- return (-1);
+ if (ioctl(fb->fd, HPCFBIO_GCONF, &fb->conf) < 0) {
+ if (ioctl(fb->fd, WSDISPLAYIO_GINFO, &fbinfo) < 0 ||
+ ioctl(fb->fd, WSDISPLAYIO_LINEBYTES, &linebytes) < 0)
+ return (-1);
+ memset(&fb->conf, 0, sizeof(fb->conf));
+ fb->conf.hf_width = fbinfo.width;
+ fb->conf.hf_height = fbinfo.height;
+ fb->conf.hf_bytes_per_line = linebytes;
+ fb->conf.hf_nplanes = 1;
+ fb->conf.hf_bytes_per_plane = fbinfo.height * linebytes;
+ fb->conf.hf_pack_width = fbinfo.depth;
+ fb->conf.hf_pixels_per_pack = 1;
+ fb->conf.hf_pixel_width = 1;
+ fb->conf.hf_access_flags = HPCFB_ACCESS_STATIC |
+ HPCFB_ACCESS_BYTE | HPCFB_ACCESS_WORD | HPCFB_ACCESS_DWORD;
+ }
if (fb_dispmode(fb, WSDISPLAYIO_MODE_MAPPED) < 0)
return (-1);
Home |
Main Index |
Thread Index |
Old Index