19c576acfStsutsui/* $NetBSD: x68kText.c,v 1.6 2021/03/11 12:08:57 tsutsui Exp $ */ 2ba64b02eStsutsui/*------------------------------------------------------------------------- 3ba64b02eStsutsui * Copyright (c) 1996 Yasushi Yamasaki 4ba64b02eStsutsui * All rights reserved. 5ba64b02eStsutsui * 6ba64b02eStsutsui * Redistribution and use in source and binary forms, with or without 7ba64b02eStsutsui * modification, are permitted provided that the following conditions 8ba64b02eStsutsui * are met: 9ba64b02eStsutsui * 1. Redistributions of source code must retain the above copyright 10ba64b02eStsutsui * notice, this list of conditions and the following disclaimer. 11ba64b02eStsutsui * 2. Redistributions in binary form must reproduce the above copyright 12ba64b02eStsutsui * notice, this list of conditions and the following disclaimer in the 13ba64b02eStsutsui * documentation and/or other materials provided with the distribution. 14ba64b02eStsutsui * 15ba64b02eStsutsui * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 16ba64b02eStsutsui * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 17ba64b02eStsutsui * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 18ba64b02eStsutsui * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 19ba64b02eStsutsui * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 20ba64b02eStsutsui * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 21ba64b02eStsutsui * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 22ba64b02eStsutsui * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 23ba64b02eStsutsui * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 24ba64b02eStsutsui * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25ba64b02eStsutsui *-----------------------------------------------------------------------*/ 26ba64b02eStsutsui 27ba64b02eStsutsui#include "x68k.h" 28ba64b02eStsutsui#include "mi.h" 29ba64b02eStsutsui#include "micmap.h" 30ba64b02eStsutsui#include "fb.h" 31909daefdSmrg#include "os.h" 32ba64b02eStsutsui 33ba64b02eStsutsui/*------------------------------------------------------------------------- 34ba64b02eStsutsui * function "x68kTextOpen" [ X68kFBProc function ] 35ba64b02eStsutsui * 36ba64b02eStsutsui * purpose: call common frame buffer opening procedure 37ba64b02eStsutsui * and enable TVRAM simultaneous access mode 38ba64b02eStsutsui * argument: (X68kScreenRec *)pPriv : X68k private screen record 39ba64b02eStsutsui * returns: (Bool): TRUE if succeeded 40ba64b02eStsutsui * FALSE otherwise 41ba64b02eStsutsui *-----------------------------------------------------------------------*/ 429b65525fStsutsuistatic uint16_t r21; 439b65525fStsutsuistatic uint16_t tpal0; 449b65525fStsutsuistatic uint16_t tpal15; 45ba64b02eStsutsui 46ba64b02eStsutsuiBool 47ba64b02eStsutsuix68kTextOpen(X68kScreenRec *pPriv) 48ba64b02eStsutsui{ 49ba64b02eStsutsui if( !x68kFbCommonOpen(pPriv, "/dev/grf0") ) 50ba64b02eStsutsui return FALSE; 51ba64b02eStsutsui 52ba64b02eStsutsui /* enable TVRAM simultaneous access mode */ 53ba64b02eStsutsui r21 = pPriv->reg->crtc.r21; 54ba64b02eStsutsui pPriv->reg->crtc.r21 = 0x01f0; 55ba64b02eStsutsui 56ba64b02eStsutsui /* initialize scroll registers */ 57ba64b02eStsutsui pPriv->reg->crtc.r10 = pPriv->reg->crtc.r11 = 0; 58ba64b02eStsutsui 59ba64b02eStsutsui tpal0 = pPriv->reg->tpal[0]; 60ba64b02eStsutsui tpal15 = pPriv->reg->tpal[15]; 61ab290810Stsutsui 62ba64b02eStsutsui pPriv->reg->tpal[0] = 0; 63ba64b02eStsutsui pPriv->reg->tpal[15] = 0xFFFE; 64ba64b02eStsutsui 65ba64b02eStsutsui return TRUE; 66ba64b02eStsutsui} 67ba64b02eStsutsui 68ba64b02eStsutsui/*------------------------------------------------------------------------- 69ba64b02eStsutsui * function "x68kTextClose" [ X68kFBProc function ] 70ba64b02eStsutsui * 71ba64b02eStsutsui * purpose: close text frame buffer 72ba64b02eStsutsui * argument: nothing 73ba64b02eStsutsui * returns: nothing 74ba64b02eStsutsui *-----------------------------------------------------------------------*/ 75ba64b02eStsutsuivoid 76ba64b02eStsutsuix68kTextClose(X68kScreenRec *pPriv) 77ba64b02eStsutsui{ 78ba64b02eStsutsui pPriv->reg->crtc.r21 = r21; /* recover TVRAM mode */ 79ba64b02eStsutsui pPriv->reg->tpal[0] = tpal0; 80ba64b02eStsutsui pPriv->reg->tpal[15] = tpal15; 81ba64b02eStsutsui x68kFbCommonClose(pPriv); 82ba64b02eStsutsui} 83ba64b02eStsutsui 84ba64b02eStsutsui/*------------------------------------------------------------------------- 85ba64b02eStsutsui * function "x68kTextInit" [ called by DIX AddScreen ] 86ba64b02eStsutsui * 87ba64b02eStsutsui * purpose: initialize text frame buffer 88909daefdSmrg * argument: (ScreenPtr)pScreen : DIX screen record 89ba64b02eStsutsui * (int)argc, (char **)argv : standard C arguments 90ba64b02eStsutsui * returns: (Bool) TRUE if succeeded 91ba64b02eStsutsui * FALSE otherwise 92ba64b02eStsutsui *-----------------------------------------------------------------------*/ 93ba64b02eStsutsuiBool 94909daefdSmrgx68kTextInit(ScreenPtr pScreen, int argc, char *argv[]) 95ba64b02eStsutsui{ 96ba64b02eStsutsui X68kScreenRec *pPriv; 97ba64b02eStsutsui 98ba64b02eStsutsui /* get private screen record set by X68KConfig */ 99ba64b02eStsutsui pPriv = x68kGetScreenRecByType(X68K_FB_TEXT); 100ba64b02eStsutsui 101ba64b02eStsutsui if ( !dixRegisterPrivateKey(&x68kScreenPrivateKeyRec, PRIVATE_SCREEN, 0) ) { 1029c576acfStsutsui ErrorF("dixRegisterPrivateKey failed\n"); 103ba64b02eStsutsui return FALSE; 104ba64b02eStsutsui } 105ba64b02eStsutsui x68kSetScreenPrivate(pScreen, pPriv); 106ba64b02eStsutsui 107ba64b02eStsutsui if ( !fbScreenInit(pScreen, pPriv->fb, 108ba64b02eStsutsui pPriv->scr_width, pPriv->scr_height, 109ba64b02eStsutsui pPriv->dpi, pPriv->dpi, pPriv->fb_width, 1) ) 110ba64b02eStsutsui return FALSE; 111ba64b02eStsutsui pScreen->whitePixel = 1; 112ba64b02eStsutsui pScreen->blackPixel = 0; 113ba64b02eStsutsui if ( !miDCInitialize(pScreen, &x68kPointerScreenFuncs) ) 114ba64b02eStsutsui return FALSE; 115ba64b02eStsutsui if ( !miCreateDefColormap(pScreen) ) 116ba64b02eStsutsui return FALSE; 117ba64b02eStsutsui pScreen->SaveScreen = x68kSaveScreen; 118ab290810Stsutsui 119ba64b02eStsutsui return TRUE; 120ba64b02eStsutsui} 121ba64b02eStsutsui 122ba64b02eStsutsui/* EOF x68kText.c */ 123