Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/rasops Well, masks do not have to be updated every t...
details: https://anonhg.NetBSD.org/src/rev/9e69843f3c8c
branches: trunk
changeset: 962556:9e69843f3c8c
user: rin <rin%NetBSD.org@localhost>
date: Wed Jul 24 19:31:12 2019 +0000
description:
Well, masks do not have to be updated every time in loop.
Calculate them in advance even if it may be bogus.
diffstat:
sys/dev/rasops/rasops.c | 47 ++++++++++++++++++++++++++++++++++++++---------
1 files changed, 38 insertions(+), 9 deletions(-)
diffs (104 lines):
diff -r 1ad255dc2435 -r 9e69843f3c8c sys/dev/rasops/rasops.c
--- a/sys/dev/rasops/rasops.c Wed Jul 24 18:49:37 2019 +0000
+++ b/sys/dev/rasops/rasops.c Wed Jul 24 19:31:12 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rasops.c,v 1.84 2019/07/24 18:49:37 rin Exp $ */
+/* $NetBSD: rasops.c,v 1.85 2019/07/24 19:31:12 rin Exp $ */
/*-
* Copyright (c) 1999 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rasops.c,v 1.84 2019/07/24 18:49:37 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rasops.c,v 1.85 2019/07/24 19:31:12 rin Exp $");
#include "opt_rasops.h"
#include "rasops_glue.h"
@@ -134,6 +134,28 @@
0, 0, 0, 1
};
+#ifdef GENFB_MAC68K
+static const uint8_t apple_devcmap[16] = {
+ 0xff, /* black 0x00, 0x00, 0x00 */
+ 0x6b, /* red 0x99, 0x00, 0x00 */
+ 0xc5, /* green 0x00, 0x99, 0x00 */
+ 0x59, /* yellow 0x99, 0x99, 0x00 */
+ 0xd4, /* blue 0x00, 0x00, 0x99 */
+ 0x68, /* magenta 0x99, 0x00, 0x99 */
+ 0xc2, /* cyan 0x00, 0x99, 0x99 */
+ 0x2b, /* white 0xcc, 0xcc, 0xcc */
+
+ 0x56, /* black 0x99, 0x99, 0x99 */
+ 0x23, /* red 0xff, 0x00, 0x00 */
+ 0xb9, /* green 0x00, 0xff, 0x00 */
+ 0x05, /* yellow 0xff, 0xff, 0x00 */
+ 0xd2, /* blue 0x00, 0x00, 0xff */
+ 0x1e, /* magenta 0xff, 0x00, 0xff */
+ 0xb4, /* cyan 0x00, 0xff, 0xff */
+ 0x00, /* white 0xff, 0xff, 0xff */
+};
+#endif
+
/* Generic functions */
static void rasops_copyrows(void *, int, int, int);
static int rasops_mapchar(void *, int, u_int *);
@@ -844,9 +866,15 @@
case 8:
if ((ri->ri_flg & RI_8BIT_IS_RGB) == 0) {
- for (i = 0; i < 16; i++)
+ for (i = 0; i < 16; i++) {
+#ifdef GENFB_MAC68K
+ c = apple_devcmap[i];
+#else
+ c = i;
+#endif
ri->ri_devcmap[i] =
- i | (i<<8) | (i<<16) | (i<<24);
+ c | (c<<8) | (c<<16) | (c<<24);
+ }
return;
}
}
@@ -995,7 +1023,7 @@
rasops_do_cursor(struct rasops_info *ri)
{
int full, height, cnt, slop1, slop2, row, col;
- uint32_t tmp32, msk;
+ uint32_t tmp32, msk1, msk2;
uint8_t tmp8;
uint8_t *dp, *rp, *hrp, *hp;
@@ -1062,6 +1090,9 @@
rp = (uint8_t *)((uintptr_t)rp & ~3);
hrp = (uint8_t *)((uintptr_t)hrp & ~3);
+ msk1 = be32toh(0xffffffffU >> (32 - (8 * slop1)));
+ msk2 = be32toh(0xffffffffU << (32 - (8 * slop2)));
+
while (height--) {
dp = rp;
rp += ri->ri_stride;
@@ -1071,8 +1102,7 @@
}
if (slop1) {
- msk = be32toh(0xffffffffU >> (32 - (8 * slop1)));
- tmp32 = *(uint32_t *)dp ^ msk;
+ tmp32 = *(uint32_t *)dp ^ msk1;
*(uint32_t *)dp = tmp32;
dp += 4;
if (ri->ri_hwbits) {
@@ -1092,8 +1122,7 @@
}
if (slop2) {
- msk = be32toh(0xffffffffU << (32 - (8 * slop2)));
- tmp32 = *(uint32_t *)dp ^ msk;
+ tmp32 = *(uint32_t *)dp ^ msk2;
*(uint32_t *)dp = tmp32;
if (ri->ri_hwbits)
*(uint32_t *)hp = tmp32;
Home |
Main Index |
Thread Index |
Old Index