Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/evbppc/explora/dev Configure fb(4) appropriately al...
details: https://anonhg.NetBSD.org/src/rev/f9f04d77f634
branches: trunk
changeset: 981235:f9f04d77f634
user: rin <rin%NetBSD.org@localhost>
date: Fri Mar 05 06:48:20 2021 +0000
description:
Configure fb(4) appropriately also when it is not console.
Now, wsdisplay(4) can be used with serial console.
diffstat:
sys/arch/evbppc/explora/dev/fb_elb.c | 34 +++++++++++++++-------------------
1 files changed, 15 insertions(+), 19 deletions(-)
diffs (80 lines):
diff -r dadbb6f93b59 -r f9f04d77f634 sys/arch/evbppc/explora/dev/fb_elb.c
--- a/sys/arch/evbppc/explora/dev/fb_elb.c Fri Mar 05 06:45:12 2021 +0000
+++ b/sys/arch/evbppc/explora/dev/fb_elb.c Fri Mar 05 06:48:20 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: fb_elb.c,v 1.14 2020/11/21 15:42:20 thorpej Exp $ */
+/* $NetBSD: fb_elb.c,v 1.15 2021/03/05 06:48:20 rin Exp $ */
/*-
* Copyright (c) 2003 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: fb_elb.c,v 1.14 2020/11/21 15:42:20 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: fb_elb.c,v 1.15 2021/03/05 06:48:20 rin Exp $");
#include <sys/param.h>
#include <sys/conf.h>
@@ -66,7 +66,7 @@
static int fb_elb_probe(device_t, cfdata_t, void *);
static void fb_elb_attach(device_t, device_t, void *);
void fb_cnattach(bus_space_tag_t, bus_addr_t, void *);
-static void fb_init(struct fb_dev *, int);
+static void fb_init(struct fb_dev *);
static int fb_ioctl(void *, void *, u_long, void *, int, struct lwp *);
static paddr_t fb_mmap(void *, void *, off_t, int);
static int fb_alloc_screen(void *, const struct wsscreen_descr *, void **,
@@ -153,7 +153,8 @@
bus_space_map(sc->sc_fb->fb_iot, eaa->elb_base2, FB_NPORTS,
0, &sc->sc_fb->fb_ioh);
- fb_init(sc->sc_fb, !is_console);
+ if (!is_console)
+ fb_init(sc->sc_fb);
ri = &sc->sc_fb->fb_ri;
@@ -168,24 +169,19 @@
}
static void
-fb_init(struct fb_dev *fb, int full)
+fb_init(struct fb_dev *fb)
{
struct rasops_info *ri = &fb->fb_ri;
- if (full) {
- s3_init(fb, &ri->ri_width, &ri->ri_height);
- ri->ri_depth = 8;
- ri->ri_stride = ri->ri_width;
- ri->ri_bits = fb->fb_vram;
- ri->ri_flg = RI_CENTER;
- if (ri == &console_dev.fb_ri)
- ri->ri_flg |= RI_NO_AUTO;
+ s3_init(fb, &ri->ri_width, &ri->ri_height);
+ ri->ri_depth = 8;
+ ri->ri_stride = ri->ri_width;
+ ri->ri_bits = fb->fb_vram;
+ ri->ri_flg = RI_CENTER | RI_CLEAR;
+ if (ri == &console_dev.fb_ri)
+ ri->ri_flg |= RI_NO_AUTO;
- rasops_init(ri, 500, 500);
- } else {
- ri->ri_origbits = fb->fb_vram; /*XXX*/
- rasops_reconfig(ri, 500, 500);
- }
+ rasops_init(ri, 500, 500);
/* Replace the copy/erase ops. */
ri->ri_hw = fb;
@@ -287,7 +283,7 @@
console_dev.fb_ioh = iobase;
console_dev.fb_vram = vram;
- fb_init(&console_dev, 1);
+ fb_init(&console_dev);
(*ri->ri_ops.allocattr)(ri, 0, 0, 0, &defattr);
Home |
Main Index |
Thread Index |
Old Index