Subversion Repositories HelenOS-historic

Rev

Rev 1551 | Rev 1564 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1551 Rev 1562
Line 23... Line 23...
23
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
 */
27
 */
28
 
-
 
-
 
28
#include <stdlib.h>
-
 
29
#include <unistd.h>
29
#include <align.h>
30
#include <align.h>
30
#include <async.h>
31
#include <async.h>
31
#include <ipc/ipc.h>
32
#include <ipc/ipc.h>
32
#include <errno.h>
33
#include <errno.h>
33
#include <stdio.h>
34
#include <stdio.h>
Line 41... Line 42...
41
 
42
 
42
#include "ega.h"
43
#include "ega.h"
43
#include "../console/screenbuffer.h"
44
#include "../console/screenbuffer.h"
44
#include "main.h"
45
#include "main.h"
45
 
46
 
-
 
47
#define MAX_SAVED_SCREENS 256
-
 
48
typedef struct saved_screen {
-
 
49
    short *data;
-
 
50
} saved_screen;
-
 
51
 
-
 
52
saved_screen saved_screens[MAX_SAVED_SCREENS];
-
 
53
 
46
 
54
 
47
#define EGA_IO_ADDRESS 0x3d4
55
#define EGA_IO_ADDRESS 0x3d4
48
#define EGA_IO_SIZE 2
56
#define EGA_IO_SIZE 2
49
 
57
 
50
typedef unsigned char u8;
58
typedef unsigned char u8;
Line 57... Line 65...
57
 
65
 
58
static unsigned int scr_width;
66
static unsigned int scr_width;
59
static unsigned int scr_height;
67
static unsigned int scr_height;
60
static char *scr_addr;
68
static char *scr_addr;
61
 
69
 
62
static unsigned int style = 0x0f;
70
static unsigned int style = 0x1e;
63
 
71
 
64
static inline void outb(u16 port, u8 b)
72
static inline void outb(u16 port, u8 b)
65
{
73
{
66
    asm volatile ("outb %0, %1\n" :: "a" (b), "d" (port));
74
    asm volatile ("outb %0, %1\n" :: "a" (b), "d" (port));
67
}
75
}
Line 111... Line 119...
111
        scr_addr[i*2] = ' ';
119
        scr_addr[i*2] = ' ';
112
        scr_addr[i*2+1] = style;
120
        scr_addr[i*2+1] = style;
113
    }
121
    }
114
}
122
}
115
 
123
 
116
void cursor_goto(unsigned int row, unsigned int col)
124
static void cursor_goto(unsigned int row, unsigned int col)
117
{
125
{
118
    int ega_cursor;
126
    int ega_cursor;
119
 
127
 
120
    ega_cursor=col+scr_width*row;
128
    ega_cursor=col+scr_width*row;
121
   
129
   
Line 123... Line 131...
123
    outb(EGA_IO_ADDRESS + 1, (ega_cursor >>8) & 0xff);
131
    outb(EGA_IO_ADDRESS + 1, (ega_cursor >>8) & 0xff);
124
    outb(EGA_IO_ADDRESS    , 0xf);
132
    outb(EGA_IO_ADDRESS    , 0xf);
125
    outb(EGA_IO_ADDRESS + 1, ega_cursor & 0xff);
133
    outb(EGA_IO_ADDRESS + 1, ega_cursor & 0xff);
126
}
134
}
127
 
135
 
128
void cursor_disable(void)
136
static void cursor_disable(void)
129
{
137
{
130
    u8 stat;
138
    u8 stat;
131
    outb(EGA_IO_ADDRESS , 0xa);
139
    outb(EGA_IO_ADDRESS , 0xa);
132
    stat=inb(EGA_IO_ADDRESS + 1);
140
    stat=inb(EGA_IO_ADDRESS + 1);
133
    outb(EGA_IO_ADDRESS , 0xa);
141
    outb(EGA_IO_ADDRESS , 0xa);
134
    outb(EGA_IO_ADDRESS +1 ,stat | (1<<5) );
142
    outb(EGA_IO_ADDRESS +1 ,stat | (1<<5) );
135
}
143
}
136
 
144
 
137
void cursor_enable(void)
145
static void cursor_enable(void)
138
{
146
{
139
    u8 stat;
147
    u8 stat;
140
    outb(EGA_IO_ADDRESS , 0xa);
148
    outb(EGA_IO_ADDRESS , 0xa);
141
    stat=inb(EGA_IO_ADDRESS + 1);
149
    stat=inb(EGA_IO_ADDRESS + 1);
142
    outb(EGA_IO_ADDRESS , 0xa);
150
    outb(EGA_IO_ADDRESS , 0xa);
143
    outb(EGA_IO_ADDRESS +1 ,stat & (~(1<<5)) );
151
    outb(EGA_IO_ADDRESS +1 ,stat & (~(1<<5)) );
144
}
152
}
145
 
153
 
-
 
154
static void scroll(int rows)
-
 
155
{
-
 
156
    int i;
-
 
157
    if (rows > 0) {
-
 
158
        memcpy(scr_addr,((char *)scr_addr)+rows*scr_width*2,scr_width*scr_height*2-rows*scr_width*2);
-
 
159
        for(i=0;i<rows*scr_width;i++)
-
 
160
            (((short *)scr_addr)+scr_width*scr_height-rows*scr_width)[i]=((style<<8)+' ');
-
 
161
    } else if (rows < 0) {
-
 
162
 
-
 
163
        memcpy(((char *)scr_addr)-rows*scr_width*2,scr_addr,scr_width*scr_height*2+rows*scr_width*2);
-
 
164
        for(i=0;i<-rows*scr_width;i++)
-
 
165
            ((short *)scr_addr)[i]=((style<<8)+' ');
-
 
166
    }
-
 
167
}
-
 
168
 
146
static void printchar(char c, unsigned int row, unsigned int col)
169
static void printchar(char c, unsigned int row, unsigned int col)
147
{
170
{
148
    scr_addr[(row*scr_width + col)*2] = c;
171
    scr_addr[(row*scr_width + col)*2] = c;
149
    scr_addr[(row*scr_width + col)*2+1] = style;
172
    scr_addr[(row*scr_width + col)*2+1] = style;
150
   
173
   
Line 156... Line 179...
156
    int i;
179
    int i;
157
 
180
 
158
    for (i=0; i < scr_width*scr_height; i++) {
181
    for (i=0; i < scr_width*scr_height; i++) {
159
        scr_addr[i*2] = data[i].character;
182
        scr_addr[i*2] = data[i].character;
160
        if (data[i].style.fg_color > data[i].style.bg_color)
183
        if (data[i].style.fg_color > data[i].style.bg_color)
161
            scr_addr[i*2+1] = 0x0f;
184
            scr_addr[i*2+1] = 0x1e;
162
        else
185
        else
163
            scr_addr[i*2+1] = 0xf0;
186
            scr_addr[i*2+1] = 0xe1;
164
    }
187
    }
165
}
188
}
166
 
189
 
-
 
190
static int save_screen(void)
-
 
191
{
-
 
192
    int i;
-
 
193
    short *mem;
-
 
194
    for(i=0;(i<MAX_SAVED_SCREENS)&&(saved_screens[i].data);i++);
-
 
195
    if(i==MAX_SAVED_SCREENS) return EINVAL;
-
 
196
    if(!(saved_screens[i].data=malloc(2*scr_width*scr_height))) return ENOMEM;
-
 
197
    memcpy(saved_screens[i].data,scr_addr,2*scr_width*scr_height);
-
 
198
    return i;
-
 
199
}
-
 
200
 
-
 
201
static int print_screen(int i)
-
 
202
{
-
 
203
    if(saved_screens[i].data)
-
 
204
            memcpy(scr_addr,saved_screens[i].data,2*scr_width*scr_height);
-
 
205
    else return EINVAL;
-
 
206
    return i;
-
 
207
}
-
 
208
 
-
 
209
 
167
static void ega_client_connection(ipc_callid_t iid, ipc_call_t *icall)
210
static void ega_client_connection(ipc_callid_t iid, ipc_call_t *icall)
168
{
211
{
169
    int retval;
212
    int retval;
170
    ipc_callid_t callid;
213
    ipc_callid_t callid;
171
    ipc_call_t call;
214
    ipc_call_t call;
172
    char c;
215
    char c;
173
    unsigned int row, col;
216
    unsigned int row, col;
174
    int bgcolor,fgcolor;
217
    int bgcolor,fgcolor;
175
    keyfield_t *interbuf = NULL;
218
    keyfield_t *interbuf = NULL;
176
    size_t intersize = 0;
219
    size_t intersize = 0;
-
 
220
    int i;
177
 
221
 
178
    if (client_connected) {
222
    if (client_connected) {
179
        ipc_answer_fast(iid, ELIMIT, 0,0);
223
        ipc_answer_fast(iid, ELIMIT, 0,0);
180
        return;
224
        return;
181
    }
225
    }
Line 232... Line 276...
232
                break;
276
                break;
233
            }
277
            }
234
            cursor_goto(row,col);
278
            cursor_goto(row,col);
235
            retval = 0;
279
            retval = 0;
236
            break;
280
            break;
-
 
281
        case FB_SCROLL:
-
 
282
            i = IPC_GET_ARG1(call);
-
 
283
            if (i > scr_height || i < (- (int)scr_height)) {
-
 
284
                retval = EINVAL;
-
 
285
                break;
-
 
286
            }
-
 
287
            scroll(i);
-
 
288
            retval = 0;
-
 
289
            break;
237
        case FB_CURSOR_VISIBILITY:
290
        case FB_CURSOR_VISIBILITY:
238
            if(IPC_GET_ARG1(call))
291
            if(IPC_GET_ARG1(call))
239
                cursor_enable();
292
                cursor_enable();
240
            else
293
            else
241
                cursor_disable();
294
                cursor_disable();
Line 243... Line 296...
243
            break;
296
            break;
244
        case FB_SET_STYLE:
297
        case FB_SET_STYLE:
245
            fgcolor = IPC_GET_ARG1(call);
298
            fgcolor = IPC_GET_ARG1(call);
246
            bgcolor = IPC_GET_ARG2(call);
299
            bgcolor = IPC_GET_ARG2(call);
247
            if (fgcolor > bgcolor)
300
            if (fgcolor > bgcolor)
248
                style = 0x0f;
301
                style = 0x1e;
249
            else
302
            else
250
                style = 0xf0;
303
                style = 0xe1;
-
 
304
 
-
 
305
        case FB_VP_DRAW_PIXMAP:
-
 
306
            i = IPC_GET_ARG2(call);
-
 
307
            retval = print_screen(i);
-
 
308
            break;
-
 
309
        case FB_VP2PIXMAP:
-
 
310
            retval = save_screen();
-
 
311
            break;
-
 
312
        case FB_DROP_PIXMAP:
-
 
313
            i = IPC_GET_ARG1(call);
-
 
314
            if (i >= MAX_SAVED_SCREENS) {
-
 
315
                retval = EINVAL;
-
 
316
                break;
-
 
317
            }
-
 
318
            if (saved_screens[i].data) {
-
 
319
                free(saved_screens[i].data);
-
 
320
                saved_screens[i].data = NULL;
-
 
321
            }
-
 
322
            break;
-
 
323
 
251
        default:
324
        default:
252
            retval = ENOENT;
325
            retval = ENOENT;
253
        }
326
        }
254
        ipc_answer_fast(callid,retval,0,0);
327
        ipc_answer_fast(callid,retval,0,0);
255
    }
328
    }
Line 272... Line 345...
272
    map_physmem(ega_ph_addr, scr_addr, ALIGN_UP(sz,PAGE_SIZE)>>PAGE_WIDTH,
345
    map_physmem(ega_ph_addr, scr_addr, ALIGN_UP(sz,PAGE_SIZE)>>PAGE_WIDTH,
273
            AS_AREA_READ | AS_AREA_WRITE);
346
            AS_AREA_READ | AS_AREA_WRITE);
274
 
347
 
275
    async_set_client_connection(ega_client_connection);
348
    async_set_client_connection(ega_client_connection);
276
 
349
 
277
    clrscr();
-
 
278
 
-
 
279
    return 0;
350
    return 0;
280
}
351
}
281
 
352