diff options
author | sos <sos@FreeBSD.org> | 1998-09-17 19:40:30 +0000 |
---|---|---|
committer | sos <sos@FreeBSD.org> | 1998-09-17 19:40:30 +0000 |
commit | 34a7bb526b09dfefeddd135bf9bd0fbf45b73f83 (patch) | |
tree | 6e8a84dc1ce02d9a19af2b93c3b396b21a8dd106 /sys/dev/syscons/snake | |
parent | 890cb330a4916be73a5adfc951810888402c4f04 (diff) | |
download | FreeBSD-src-34a7bb526b09dfefeddd135bf9bd0fbf45b73f83.zip FreeBSD-src-34a7bb526b09dfefeddd135bf9bd0fbf45b73f83.tar.gz |
Fix the sreensavers so the work again with the new syscons & friends.
Submitted by: Kazutaka YOKOTA <yokota@zodiac.mech.utsunomiya-u.ac.jp>
Diffstat (limited to 'sys/dev/syscons/snake')
-rw-r--r-- | sys/dev/syscons/snake/snake_saver.c | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/sys/dev/syscons/snake/snake_saver.c b/sys/dev/syscons/snake/snake_saver.c index c5011d0..efb76d5 100644 --- a/sys/dev/syscons/snake/snake_saver.c +++ b/sys/dev/syscons/snake/snake_saver.c @@ -25,7 +25,7 @@ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * - * $Id$ + * $Id: snake_saver.c,v 1.18 1998/09/15 18:16:39 sos Exp $ */ #include <sys/param.h> @@ -47,6 +47,7 @@ MOD_MISC(snake_saver); static char *message; static u_char **messagep; static int messagelen; +static u_short *window; static void snake_saver(int blank) @@ -60,15 +61,19 @@ snake_saver(int blank) #define savs messagep if (blank) { + if (!ISTEXTSC(scp)) + return; if (scrn_blanked <= 0) { + scp->status |= SAVER_RUNNING; + window = (u_short *)(*biosvidsw.adapter)(scp->adp)->va_window; fillw((FG_LIGHTGREY|BG_BLACK)<<8 | scr_map[0x20], - Crtat, scp->xsize * scp->ysize); + window, scp->xsize * scp->ysize); set_border(scp, 0); dirx = (scp->xpos ? 1 : -1); diry = (scp->ypos ? scp->xsize : -scp->xsize); for (f=0; f< messagelen; f++) - savs[f] = (u_char *)Crtat + 2 * + savs[f] = (u_char *)window + 2 * (scp->xpos+scp->ypos*scp->xsize); *(savs[0]) = scr_map[*save]; f = scp->ysize * scp->xsize + 5; @@ -84,7 +89,7 @@ snake_saver(int blank) *(savs[messagelen-1]) = scr_map[0x20]; for (f=messagelen-1; f > 0; f--) savs[f] = savs[f-1]; - f = (savs[0] - (u_char *)Crtat) / 2; + f = (savs[0] - (u_char *)window) / 2; if ((f % scp->xsize) == 0 || (f % scp->xsize) == scp->xsize - 1 || (random() % 50) == 0) @@ -101,6 +106,7 @@ snake_saver(int blank) if (scrn_blanked > 0) { set_border(scp, scp->border); scrn_blanked = 0; + scp->status &= ~SAVER_RUNNING; } } } @@ -110,9 +116,6 @@ snake_saver_load(struct lkm_table *lkmtp, int cmd) { int err; - if (cur_console->mode >= M_VESA_BASE) - return ENODEV; - messagelen = strlen(ostype) + 1 + strlen(osrelease); message = malloc(messagelen + 1, M_DEVBUF, M_WAITOK); sprintf(message, "%s %s", ostype, osrelease); |