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