2018-09-28 20:35:51 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* COS2000 - Compatible Operating System - LGPL v3 - Hord<72> Nicolas */
|
|
|
|
|
/* */
|
2018-10-13 11:25:55 +02:00
|
|
|
|
#include "asm.h"
|
2007-04-02 15:21:28 +02:00
|
|
|
|
#include "video.h"
|
2007-04-02 16:14:21 +02:00
|
|
|
|
#include "stdarg.h"
|
2018-10-13 11:25:55 +02:00
|
|
|
|
#include "VGA/8x8fnt.c"
|
|
|
|
|
#include "VGA/8x16fnt.c"
|
2007-04-02 15:21:28 +02:00
|
|
|
|
|
2018-10-13 13:23:00 +02:00
|
|
|
|
static drivers registred[MAXDRIVERS];
|
2018-10-13 05:35:08 +02:00
|
|
|
|
|
|
|
|
|
static videoinfos *vinfo;
|
|
|
|
|
|
2018-10-13 13:23:00 +02:00
|
|
|
|
static width,height;
|
|
|
|
|
|
2018-10-13 05:35:08 +02:00
|
|
|
|
static console vc[8] = {
|
2018-10-13 11:25:55 +02:00
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true} ,
|
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true} ,
|
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true} ,
|
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true} ,
|
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true} ,
|
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true} ,
|
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true} ,
|
|
|
|
|
{0x07, 0, 0, 0, 0, 0, 0, 0, true}
|
2018-08-17 16:46:56 +02:00
|
|
|
|
};
|
2007-04-02 16:14:21 +02:00
|
|
|
|
|
2018-10-13 05:35:08 +02:00
|
|
|
|
static u8 usedvc = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Fixe l'attribut courant */
|
|
|
|
|
|
|
|
|
|
void setattrib(u8 att)
|
|
|
|
|
{
|
2018-08-17 16:46:56 +02:00
|
|
|
|
static const u8 ansitovga[] = {
|
2007-04-02 15:44:12 +02:00
|
|
|
|
0, 4, 2, 6, 1, 5, 3, 7
|
|
|
|
|
};
|
|
|
|
|
u8 tempattr;
|
|
|
|
|
|
2007-04-02 16:14:21 +02:00
|
|
|
|
tempattr = vc[usedvc].attrib;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
if (att == 0)
|
|
|
|
|
tempattr = 0x07; /* Couleur Grise sur fond noir */
|
2007-04-02 16:14:21 +02:00
|
|
|
|
else if (att == 5)
|
2018-08-17 16:46:56 +02:00
|
|
|
|
tempattr |= 0x80;
|
2007-04-02 16:14:21 +02:00
|
|
|
|
else if (att == 7)
|
2018-08-17 16:46:56 +02:00
|
|
|
|
tempattr = ((tempattr & 0x0F) << 4) + ((tempattr & 0xF0) >> 4);
|
2007-04-02 16:14:21 +02:00
|
|
|
|
else if (att == 8)
|
2018-08-17 16:46:56 +02:00
|
|
|
|
tempattr = 0;
|
2007-04-02 16:14:21 +02:00
|
|
|
|
else if (att == 1)
|
2018-08-17 16:46:56 +02:00
|
|
|
|
tempattr |= 0x08; /* Forte intensit<69> */
|
|
|
|
|
else if (att >= 30 && att <= 37) {
|
2007-04-02 15:44:12 +02:00
|
|
|
|
att = ansitovga[att - 30];
|
2018-08-17 16:46:56 +02:00
|
|
|
|
tempattr = (tempattr & ~0x07) | att; /* couleur de premier plan */
|
|
|
|
|
} else if (att >= 40 && att <= 47) {
|
2007-04-02 15:44:12 +02:00
|
|
|
|
att = ansitovga[att - 40] << 4;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
tempattr = (tempattr & ~0x70) | att; /* couleur de fond */
|
2007-04-02 15:44:12 +02:00
|
|
|
|
}
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].attrib = tempattr;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* gere l'ansi */
|
|
|
|
|
|
|
|
|
|
bool makeansi(u8 c)
|
|
|
|
|
{
|
|
|
|
|
/* state machine to handle the escape sequences */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
switch (vc[usedvc].ansi) {
|
2007-04-02 15:44:12 +02:00
|
|
|
|
case 0:
|
|
|
|
|
/* ESC -- next state */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
if (c == 0x1B) {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi++;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
return 1; /* "I handled it" */
|
2007-04-02 15:44:12 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
/* ESC */
|
|
|
|
|
case 1:
|
2018-08-17 16:46:56 +02:00
|
|
|
|
if (c == '[') {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi++;
|
|
|
|
|
vc[usedvc].param1 = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
/* ESC[ */
|
|
|
|
|
case 2:
|
2018-08-17 16:46:56 +02:00
|
|
|
|
if (isdigit(c)) {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].param1 = vc[usedvc].param1 * 10 + c - '0';
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
} else if (c == ';') {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi++;
|
|
|
|
|
vc[usedvc].param2 = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
/* ESC[2J -- efface l'ecran */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'J') {
|
|
|
|
|
if (vc[usedvc].param1 == 2) {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
fill(vc[usedvc].attrib);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
vc[usedvc].cursX = 0;
|
|
|
|
|
vc[usedvc].cursY = 0;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(0, 0);
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/* ESC[num1m -- met l'attribut num1 */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'm') {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
setattrib(vc[usedvc].param1);
|
|
|
|
|
vc[usedvc].ansi = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
/* ESC[num1A -- bouge le curseur de num1 vers le haut */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'A') {
|
|
|
|
|
vc[usedvc].cursY -= vc[usedvc].param1;
|
|
|
|
|
if (vc[usedvc].cursY < 0)
|
|
|
|
|
vc[usedvc].cursY = 0;
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(vc[usedvc].cursX, vc[usedvc].cursY);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
2007-04-02 15:44:12 +02:00
|
|
|
|
/* ESC[num1B -- bouge le curseur de num1 vers le bas */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'B') {
|
|
|
|
|
vc[usedvc].cursY += vc[usedvc].param1;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
if (vc[usedvc].cursY >= getheight() - 1)
|
|
|
|
|
vc[usedvc].cursY = getheight() ;
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(vc[usedvc].cursX, vc[usedvc].cursY);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
2007-04-02 16:14:21 +02:00
|
|
|
|
/* ESC[num1D -- bouge le curseur de num1 vers la gauche */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'D') {
|
|
|
|
|
vc[usedvc].cursX -= vc[usedvc].param1;
|
|
|
|
|
if (vc[usedvc].cursX < 0)
|
|
|
|
|
vc[usedvc].cursX = 0;
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(vc[usedvc].cursX, vc[usedvc].cursY);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
2007-04-02 16:14:21 +02:00
|
|
|
|
/* ESC[num1C -- bouge le curseur de num1 vers la droite */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'C') {
|
|
|
|
|
vc[usedvc].cursX += vc[usedvc].param1;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
if (vc[usedvc].cursX >= getwidth() - 1)
|
|
|
|
|
vc[usedvc].cursX = getwidth();
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(vc[usedvc].cursX, vc[usedvc].cursY);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
2007-04-02 15:44:12 +02:00
|
|
|
|
break;
|
|
|
|
|
/* ESC[num1; */
|
|
|
|
|
case 3:
|
2018-08-17 16:46:56 +02:00
|
|
|
|
if (isdigit(c)) {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].param2 = vc[usedvc].param2 * 10 + c - '0';
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
} else if (c == ';') {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi++;
|
|
|
|
|
vc[usedvc].param3 = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
/* ESC[num1;num2H ou ESC[num1;num2f-- bouge le curseur en num1,num2 */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if ((c == 'H') || (c == 'f')) {
|
|
|
|
|
/* Remet la position du curseur mat<61>riel a num1,num2 */
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(vc[usedvc].param2, vc[usedvc].param1);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
/* Remet la position du curseur logiciel a num1,num2 */
|
|
|
|
|
vc[usedvc].cursX = vc[usedvc].param2;
|
|
|
|
|
vc[usedvc].cursY = vc[usedvc].param1;
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
/* ESC[num1;num2m -- met les attributs num1,num2 */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'm') {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
setattrib(vc[usedvc].param1);
|
|
|
|
|
setattrib(vc[usedvc].param2);
|
|
|
|
|
vc[usedvc].ansi = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
/* ESC[num1;num2;num3 */
|
|
|
|
|
case 4:
|
2018-08-17 16:46:56 +02:00
|
|
|
|
if (isdigit(c)) {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].param3 = vc[usedvc].param3 * 10 + c - '0';
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
/* ESC[num1;num2;num3m -- met les attributs num1,num2,num3 */
|
2018-08-17 16:46:56 +02:00
|
|
|
|
else if (c == 'm') {
|
2007-04-02 16:14:21 +02:00
|
|
|
|
setattrib(vc[usedvc].param1);
|
|
|
|
|
setattrib(vc[usedvc].param2);
|
|
|
|
|
setattrib(vc[usedvc].param3);
|
|
|
|
|
vc[usedvc].ansi = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
/* Mauvais etat >> reset */
|
|
|
|
|
default:
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
break;
|
|
|
|
|
}
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].ansi = 0;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
return 0; /* Ansi fini ;) */
|
2007-04-02 15:44:12 +02:00
|
|
|
|
}
|
2018-10-12 22:31:34 +02:00
|
|
|
|
|
2018-10-13 13:23:00 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Change de mode video */
|
2018-10-12 22:31:34 +02:00
|
|
|
|
void changemode(u8 mode)
|
|
|
|
|
{
|
|
|
|
|
setvideo_mode(mode);
|
|
|
|
|
vinfo=getvideo_info();
|
2018-10-13 11:25:55 +02:00
|
|
|
|
if (!vinfo->isgraphic) {
|
|
|
|
|
font_load(font8x8, 8, 1);
|
|
|
|
|
font_load(font8x16, 16, 0);
|
2018-10-13 13:23:00 +02:00
|
|
|
|
width=vinfo->currentwidth;
|
|
|
|
|
height=vinfo->currentheight;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
width=(vinfo->currentwidth>>3);
|
|
|
|
|
height=(vinfo->currentheight>>3);
|
2018-10-13 11:25:55 +02:00
|
|
|
|
}
|
2018-10-13 13:42:13 +02:00
|
|
|
|
clearscreen();
|
2018-10-12 22:31:34 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-13 13:23:00 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Renvoie la taille horizontale */
|
|
|
|
|
u16 getwidth(void)
|
|
|
|
|
{
|
|
|
|
|
return width;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Renvoie la taille verticale */
|
|
|
|
|
u16 getheight(void)
|
|
|
|
|
{
|
|
|
|
|
return height;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2018-10-07 14:53:48 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Efface la console en cours d'utilisation */
|
|
|
|
|
void clearscreen(void)
|
|
|
|
|
{
|
2018-10-13 05:35:08 +02:00
|
|
|
|
fill(vc[usedvc].attrib);
|
2018-10-07 14:53:48 +02:00
|
|
|
|
vc[usedvc].cursX=0;
|
|
|
|
|
vc[usedvc].cursY=0;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(0,0);
|
2018-10-07 14:53:48 +02:00
|
|
|
|
}
|
2007-04-02 15:44:12 +02:00
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
2007-04-02 16:14:21 +02:00
|
|
|
|
/* Change la console en cours d'utilisation */
|
|
|
|
|
|
|
|
|
|
void changevc(u8 avc)
|
|
|
|
|
{
|
2018-08-17 16:46:56 +02:00
|
|
|
|
usedvc = avc;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
page_show(usedvc);
|
|
|
|
|
page_set(usedvc);
|
|
|
|
|
cursor_set(vc[usedvc].cursX, vc[usedvc].cursY);
|
2007-04-02 16:14:21 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
2007-04-02 15:44:12 +02:00
|
|
|
|
/* affiche un caract<63>re a l'<27>cran */
|
|
|
|
|
|
|
|
|
|
void putchar(u8 thechar)
|
|
|
|
|
{
|
2018-10-12 22:31:34 +02:00
|
|
|
|
page_show(usedvc);
|
|
|
|
|
page_set(usedvc);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
if (makeansi(thechar))
|
|
|
|
|
return;
|
|
|
|
|
switch (thechar) {
|
|
|
|
|
case 0x11:
|
|
|
|
|
if (vc[usedvc].cursY > 0)
|
|
|
|
|
vc[usedvc].cursY--;
|
|
|
|
|
break;
|
|
|
|
|
case 0x12:
|
2018-10-13 13:23:00 +02:00
|
|
|
|
if (vc[usedvc].cursY < getheight() - 1)
|
2018-08-17 16:46:56 +02:00
|
|
|
|
vc[usedvc].cursY++;
|
|
|
|
|
break;
|
|
|
|
|
case 0x13:
|
|
|
|
|
if (vc[usedvc].cursX > 0)
|
|
|
|
|
vc[usedvc].cursX--;
|
|
|
|
|
break;
|
|
|
|
|
case 0x14:
|
2018-10-13 13:23:00 +02:00
|
|
|
|
if (vc[usedvc].cursX < getwidth() - 1)
|
2018-08-17 16:46:56 +02:00
|
|
|
|
vc[usedvc].cursX++;
|
|
|
|
|
break;
|
|
|
|
|
case 0x2:
|
|
|
|
|
vc[usedvc].cursX = 0;
|
|
|
|
|
vc[usedvc].cursY = 0;
|
|
|
|
|
break;
|
|
|
|
|
case 0x3:
|
|
|
|
|
vc[usedvc].cursX = 0;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
vc[usedvc].cursY = getheight() - 1;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
|
|
|
|
case 0x19:
|
2018-10-13 13:23:00 +02:00
|
|
|
|
vc[usedvc].cursX = getwidth() - 1;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
|
|
|
|
case '\b':
|
|
|
|
|
if (vc[usedvc].cursX == 0) {
|
|
|
|
|
if (vc[usedvc].cursY > 0) {
|
2018-10-13 13:23:00 +02:00
|
|
|
|
vc[usedvc].cursX = getwidth() - 1;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
vc[usedvc].cursY--;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
vc[usedvc].cursX--;
|
|
|
|
|
}
|
|
|
|
|
showchar(vc[usedvc].cursX, vc[usedvc].cursY, ' ',
|
|
|
|
|
vc[usedvc].attrib);
|
|
|
|
|
break;
|
|
|
|
|
case '\t':
|
|
|
|
|
vc[usedvc].cursX = (vc[usedvc].cursX + 8) & ~(8 - 1);
|
|
|
|
|
break;
|
|
|
|
|
case '\n':
|
|
|
|
|
vc[usedvc].cursX = 0;
|
|
|
|
|
break;
|
|
|
|
|
case '\r':
|
|
|
|
|
vc[usedvc].cursX = 0;
|
2007-04-02 16:14:21 +02:00
|
|
|
|
vc[usedvc].cursY++;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
if (thechar >= ' ') {
|
2018-10-13 05:35:08 +02:00
|
|
|
|
showchar(vc[usedvc].cursX, vc[usedvc].cursY, thechar, vc[usedvc].attrib);
|
2018-08-17 16:46:56 +02:00
|
|
|
|
vc[usedvc].cursX++;
|
2007-04-02 15:44:12 +02:00
|
|
|
|
}
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
|
|
|
|
}
|
2018-10-13 13:23:00 +02:00
|
|
|
|
if (vc[usedvc].cursX >= getwidth()) {
|
2018-08-17 16:46:56 +02:00
|
|
|
|
vc[usedvc].cursX = 0;
|
|
|
|
|
vc[usedvc].cursY++;
|
|
|
|
|
}
|
2018-10-13 13:23:00 +02:00
|
|
|
|
if (vc[usedvc].cursY >= getheight() ) {
|
2018-08-17 16:46:56 +02:00
|
|
|
|
scroll(1, vc[usedvc].attrib);
|
2018-10-13 13:23:00 +02:00
|
|
|
|
vc[usedvc].cursY = getheight() - 1;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
}
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cursor_set(vc[usedvc].cursX, vc[usedvc].cursY);
|
2007-04-02 15:44:12 +02:00
|
|
|
|
}
|
|
|
|
|
|
2007-04-02 15:21:28 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* affiche une chaine de caract<63>re a l'<27>cran */
|
|
|
|
|
|
2018-08-29 10:12:00 +02:00
|
|
|
|
u32 print(u8 * string)
|
2007-04-02 15:21:28 +02:00
|
|
|
|
{
|
2018-08-17 16:46:56 +02:00
|
|
|
|
u8 *source;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
u32 i = 0;
|
2007-04-02 15:21:28 +02:00
|
|
|
|
source = string;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
while (*source != 0) {
|
|
|
|
|
putchar(*source++);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
i++;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
}
|
2018-09-27 17:47:27 +02:00
|
|
|
|
return i;
|
2007-04-02 15:21:28 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
2018-10-07 12:57:38 +02:00
|
|
|
|
/* Fonction d'affichage (pour printf) */
|
|
|
|
|
|
|
|
|
|
u32 printstr(u8* src, u8** dest, u32 len) {
|
2018-10-07 13:11:16 +02:00
|
|
|
|
if (*(src)=='\000') return;
|
2018-10-07 12:57:38 +02:00
|
|
|
|
for(u32 i=0;i<len;i++)
|
|
|
|
|
putchar(*(src++));
|
|
|
|
|
return len;
|
|
|
|
|
}
|
2007-04-02 15:21:28 +02:00
|
|
|
|
|
2018-10-07 12:57:38 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Fonction d'enregistrement dans une variable (pour sprintf) */
|
|
|
|
|
|
|
|
|
|
u32 storestr(u8* src, u8** dest, u32 len) {
|
|
|
|
|
memcpy(src, *dest, len, 1);
|
|
|
|
|
*dest=*dest+len;
|
|
|
|
|
return len;
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-09 18:13:04 +02:00
|
|
|
|
#define maxbuffersize 4096
|
2018-10-08 21:50:40 +02:00
|
|
|
|
|
2018-10-07 12:57:38 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* affiche une chaine de caract<63>re format<61> a l'ecran */
|
2018-08-29 10:12:00 +02:00
|
|
|
|
|
2018-09-27 17:47:27 +02:00
|
|
|
|
u32 printf(const u8 * string, ...)
|
2007-04-02 15:21:28 +02:00
|
|
|
|
{
|
2018-10-07 12:57:38 +02:00
|
|
|
|
va_list args;
|
|
|
|
|
va_start(args, string);
|
2018-10-08 21:50:40 +02:00
|
|
|
|
vprintf(string, args);
|
2018-10-07 12:57:38 +02:00
|
|
|
|
va_end(args);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* met une chaine de caract<63>re format<61> dans une variable */
|
|
|
|
|
|
|
|
|
|
u32 sprintf(u8 *variable, const u8 *string, ...)
|
|
|
|
|
{
|
|
|
|
|
va_list args;
|
|
|
|
|
va_start(args, string);
|
2018-10-08 21:50:40 +02:00
|
|
|
|
vsprintf(variable, string, args);
|
|
|
|
|
va_end(args);
|
|
|
|
|
}
|
2018-10-07 12:57:38 +02:00
|
|
|
|
|
2018-10-08 21:50:40 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* met une chaine de caract<63>re format<61> dans une variable de taille fix<69>e */
|
|
|
|
|
|
|
|
|
|
u32 snprintf(u8 *variable, u32 maxsize, const u8 *string, ...)
|
|
|
|
|
{
|
|
|
|
|
va_list args;
|
|
|
|
|
va_start(args, string);
|
|
|
|
|
vsnprintf(variable, maxsize, string, args);
|
2018-10-07 12:57:38 +02:00
|
|
|
|
va_end(args);
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-08 21:50:40 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* affiche une chaine de caract<63>re format<61> a l'ecran depuis vararg */
|
|
|
|
|
|
|
|
|
|
u32 vprintf(const u8 * string, va_list args)
|
|
|
|
|
{
|
|
|
|
|
format(string, args, maxbuffersize, &printstr, NULL);
|
|
|
|
|
}
|
2018-10-07 12:57:38 +02:00
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
2018-10-08 21:50:40 +02:00
|
|
|
|
/* met une chaine de caract<63>re format<61> dans une variable depuis vararg */
|
|
|
|
|
|
|
|
|
|
u32 vsprintf(u8 *variable, const u8 *string, va_list args)
|
|
|
|
|
{
|
|
|
|
|
format(string, args, maxbuffersize, &storestr, variable);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* met une chaine de caract<63>re format<61> dans une variable de taille fix<69>e depuis vararg */
|
2018-10-07 12:57:38 +02:00
|
|
|
|
|
2018-10-08 21:50:40 +02:00
|
|
|
|
u32 vsnprintf(u8 *variable, u32 maxsize, const u8 *string, va_list args)
|
|
|
|
|
{
|
|
|
|
|
format(string, args, maxsize, &storestr, variable);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* affiche une chaine de caract<63>re format<61> a l'ecran */
|
2018-10-07 12:57:38 +02:00
|
|
|
|
|
2018-10-08 21:50:40 +02:00
|
|
|
|
u32 format(const u8 * string, va_list args, u32 maxsize, u32 (*fonction)(u8* src, u8** dest, u32 len), u8* dest)
|
2018-10-07 12:57:38 +02:00
|
|
|
|
{
|
2018-09-27 21:01:02 +02:00
|
|
|
|
u64 sizes[] = { 0xFF, 0xFFFF, 0xFFFFFFFF, 0xFFFFFFFFFFFFFFFF };
|
2018-09-28 00:03:45 +02:00
|
|
|
|
u8 units[][4] = { "o\000\000", "kio", "mio", "gio", "tio", "pio" };
|
2018-09-27 21:01:02 +02:00
|
|
|
|
u8 strbase2[] = "0xb\000";
|
|
|
|
|
u8 strbase8[] = "0xo\000";
|
|
|
|
|
u8 strbase16[] = "0x\000";
|
2018-09-27 17:47:27 +02:00
|
|
|
|
u8 hexadecimal[] = "*0x\000";
|
|
|
|
|
u8 achar, temp;
|
2018-10-05 22:56:58 +02:00
|
|
|
|
u8 asize, charadd, unit, precisioni, precisionf;
|
2018-10-08 21:50:40 +02:00
|
|
|
|
u8 buffer[maxbuffersize];
|
2018-10-07 12:57:38 +02:00
|
|
|
|
u8* bufferend;
|
|
|
|
|
u32 buffersize;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
u8 *str = string;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
u8 *strtemp;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
u32 i = 0, counter = 0;
|
2018-09-27 21:01:02 +02:00
|
|
|
|
u64 num;
|
2018-10-05 22:56:58 +02:00
|
|
|
|
bool flag = false, intok = false, decok = false;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
|
2018-09-27 17:47:27 +02:00
|
|
|
|
for (achar = *str; achar != '\000'; i++, achar = *(str + i)) {
|
|
|
|
|
if (achar != '%' && !flag) {
|
2018-10-07 12:57:38 +02:00
|
|
|
|
fonction((str + i),&dest,1);
|
2018-08-29 10:12:00 +02:00
|
|
|
|
counter++;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
asize = 2;
|
2018-10-05 22:56:58 +02:00
|
|
|
|
precisioni = 0;
|
|
|
|
|
precisionf = 0;
|
|
|
|
|
intok = false;
|
|
|
|
|
decok = false;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
charadd = 0xFF;
|
|
|
|
|
} else if (achar == '%' || flag) {
|
|
|
|
|
if (!flag)
|
|
|
|
|
++i;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
achar = *(str + i);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
switch (achar) {
|
2018-10-05 22:56:58 +02:00
|
|
|
|
case 'z':
|
|
|
|
|
charadd = achar;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = true;
|
|
|
|
|
break;
|
|
|
|
|
case ' ':
|
2018-10-05 22:56:58 +02:00
|
|
|
|
charadd = achar;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = true;
|
|
|
|
|
break;
|
|
|
|
|
case 'h':
|
|
|
|
|
asize--;
|
2018-09-27 21:01:02 +02:00
|
|
|
|
if (asize<0) asize=0;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = true;
|
|
|
|
|
break;
|
|
|
|
|
case 'l':
|
|
|
|
|
asize++;
|
2018-09-27 21:01:02 +02:00
|
|
|
|
if (asize>3) asize=3;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = true;
|
|
|
|
|
break;
|
2018-10-05 22:56:58 +02:00
|
|
|
|
case '.':
|
|
|
|
|
intok=true;
|
|
|
|
|
decok=false;
|
|
|
|
|
flag = true;
|
|
|
|
|
break;
|
|
|
|
|
case '0':
|
2018-09-28 00:03:45 +02:00
|
|
|
|
case '1':
|
|
|
|
|
case '2':
|
|
|
|
|
case '3':
|
|
|
|
|
case '4':
|
|
|
|
|
case '5':
|
|
|
|
|
case '6':
|
|
|
|
|
case '7':
|
|
|
|
|
case '8':
|
|
|
|
|
case '9':
|
2018-10-05 22:56:58 +02:00
|
|
|
|
if (!intok)
|
|
|
|
|
{
|
|
|
|
|
if (!decok)
|
|
|
|
|
{
|
|
|
|
|
precisioni=achar-'0';
|
|
|
|
|
decok=true;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
precisioni*=10;
|
|
|
|
|
precisioni+=achar-'0';
|
|
|
|
|
decok=false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
if (!decok)
|
|
|
|
|
{
|
|
|
|
|
precisionf=achar-'0';
|
|
|
|
|
decok=true;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
precisionf*=10;
|
|
|
|
|
precisionf+=achar-'0';
|
|
|
|
|
decok=false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
flag = true;
|
2018-09-28 00:03:45 +02:00
|
|
|
|
break;
|
2018-10-04 21:49:06 +02:00
|
|
|
|
case 'f':
|
2018-10-05 22:56:58 +02:00
|
|
|
|
case 'e':
|
|
|
|
|
if (achar=='e') {
|
|
|
|
|
precisioni=1;
|
|
|
|
|
precisionf=8;
|
|
|
|
|
}
|
2018-10-04 21:49:06 +02:00
|
|
|
|
if (asize==0) {
|
|
|
|
|
num = (u64) va_arg(args, u8);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if (asize==1) {
|
|
|
|
|
num = (u64) va_arg(args, u16);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if (asize==2)
|
2018-10-07 12:57:38 +02:00
|
|
|
|
bufferend=rtoasingle((float)va_arg(args, double), &buffer, precisioni, precisionf);
|
2018-10-04 21:49:06 +02:00
|
|
|
|
else
|
2018-10-07 12:57:38 +02:00
|
|
|
|
bufferend=rtoadouble((double)va_arg(args, double), &buffer, precisioni, precisionf);
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
2018-10-04 21:49:06 +02:00
|
|
|
|
flag = false;
|
|
|
|
|
break;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
case 'u':
|
2018-09-27 21:01:02 +02:00
|
|
|
|
if (asize==0)
|
|
|
|
|
num = (u64) va_arg(args, u8);
|
|
|
|
|
else if (asize==1)
|
|
|
|
|
num = (u64) va_arg(args, u16);
|
|
|
|
|
else if (asize==2)
|
|
|
|
|
num = (u64) va_arg(args, u32);
|
|
|
|
|
else
|
|
|
|
|
num = (u64) va_arg(args, u64);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
if (charadd == 0xFF)
|
|
|
|
|
charadd = '0';
|
2018-10-07 12:57:38 +02:00
|
|
|
|
bufferend=itoa(num, &buffer, 10, sizes[asize], charadd);
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
|
|
|
|
break;
|
|
|
|
|
case 'o':
|
2018-09-27 21:01:02 +02:00
|
|
|
|
if (asize==0)
|
|
|
|
|
num = (u64) va_arg(args, u8);
|
|
|
|
|
else if (asize==1)
|
|
|
|
|
num = (u64) va_arg(args, u16);
|
|
|
|
|
else if (asize==2)
|
|
|
|
|
num = (u64) va_arg(args, u32);
|
|
|
|
|
else
|
|
|
|
|
num = (u64) va_arg(args, u64);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
if (charadd == 0xFF)
|
|
|
|
|
charadd = '0';
|
2018-10-07 12:57:38 +02:00
|
|
|
|
counter += fonction(&strbase8,&dest,1);
|
|
|
|
|
bufferend=itoa(num, &buffer, 8, sizes[asize], charadd);
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
case 'c':
|
2018-10-07 12:57:38 +02:00
|
|
|
|
temp = (u8) va_arg(args, u8);
|
|
|
|
|
fonction(&temp,string,1);
|
2018-08-29 10:12:00 +02:00
|
|
|
|
counter++;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
2018-09-28 00:03:45 +02:00
|
|
|
|
case 'H':
|
|
|
|
|
if (asize==0)
|
|
|
|
|
num = (u64) va_arg(args, u8);
|
|
|
|
|
else if (asize==1)
|
|
|
|
|
num = (u64) va_arg(args, u16);
|
|
|
|
|
else if (asize==2)
|
|
|
|
|
num = (u64) va_arg(args, u32);
|
|
|
|
|
else
|
|
|
|
|
num = (u64) va_arg(args, u64);
|
|
|
|
|
if (charadd == 0xFF)
|
|
|
|
|
charadd = ' ';
|
|
|
|
|
unit=0;
|
|
|
|
|
while(num>1024*10)
|
|
|
|
|
{
|
|
|
|
|
num=num>>10;
|
|
|
|
|
unit++;
|
|
|
|
|
}
|
2018-10-07 12:57:38 +02:00
|
|
|
|
bufferend=sitoa(num, &buffer, sizes[asize]);
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
|
|
|
|
counter += fonction(units[unit],&dest,3);
|
2018-09-28 00:03:45 +02:00
|
|
|
|
flag = false;
|
|
|
|
|
break;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
case 'd':
|
2018-09-27 17:47:27 +02:00
|
|
|
|
case 'i':
|
2018-09-27 21:01:02 +02:00
|
|
|
|
if (asize==0)
|
|
|
|
|
num = (u64) va_arg(args, u8);
|
|
|
|
|
else if (asize==1)
|
|
|
|
|
num = (u64) va_arg(args, u16);
|
|
|
|
|
else if (asize==2)
|
|
|
|
|
num = (u64) va_arg(args, u32);
|
|
|
|
|
else
|
|
|
|
|
num = (u64) va_arg(args, u64);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
if (charadd == 0xFF)
|
|
|
|
|
charadd = ' ';
|
2018-10-07 12:57:38 +02:00
|
|
|
|
bufferend=sitoa(num, &buffer, sizes[asize]);
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
break;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
case 's':
|
2018-09-27 17:47:27 +02:00
|
|
|
|
strtemp = (u8 *) va_arg(args, u8 *);
|
2018-10-07 12:57:38 +02:00
|
|
|
|
counter += fonction(strtemp,&dest,strlen(strtemp));
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
case 'p':
|
2018-09-27 17:47:27 +02:00
|
|
|
|
num = (u32) va_arg(args, int);
|
|
|
|
|
if (charadd == 0xFF)
|
|
|
|
|
charadd = '0';
|
2018-10-07 12:57:38 +02:00
|
|
|
|
counter += fonction(&hexadecimal,&dest,3);
|
|
|
|
|
bufferend=itoa(num, &buffer, 16, sizes[asize], '0');
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
break;
|
|
|
|
|
case 'x':
|
|
|
|
|
case 'X':
|
2018-10-03 22:50:54 +02:00
|
|
|
|
case 'y':
|
|
|
|
|
case 'Y':
|
2018-09-27 21:01:02 +02:00
|
|
|
|
if (asize==0)
|
|
|
|
|
num = (u64) va_arg(args, u8);
|
|
|
|
|
else if (asize==1)
|
|
|
|
|
num = (u64) va_arg(args, u16);
|
|
|
|
|
else if (asize==2)
|
|
|
|
|
num = (u64) va_arg(args, u32);
|
|
|
|
|
else
|
|
|
|
|
num = (u64) va_arg(args, u64);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
if (charadd == 0xFF)
|
|
|
|
|
charadd = '0';
|
2018-10-07 12:57:38 +02:00
|
|
|
|
if (achar == 'X') counter += fonction(&strbase16,&dest,2);
|
|
|
|
|
bufferend=itoa(num, &buffer, 16, sizes[asize], charadd);
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
2018-10-03 22:50:54 +02:00
|
|
|
|
if (achar == 'X'||achar == 'Y')
|
2018-09-27 17:47:27 +02:00
|
|
|
|
strtoupper(&buffer);
|
2018-10-07 12:57:38 +02:00
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
break;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
case 'b':
|
2018-09-27 21:01:02 +02:00
|
|
|
|
if (asize==0)
|
|
|
|
|
num = (u64) va_arg(args, u8);
|
|
|
|
|
else if (asize==1)
|
|
|
|
|
num = (u64) va_arg(args, u16);
|
|
|
|
|
else if (asize==2)
|
|
|
|
|
num = (u64) va_arg(args, u32);
|
|
|
|
|
else
|
|
|
|
|
num = (u64) va_arg(args, u64);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
if (charadd == 0xFF)
|
|
|
|
|
charadd = '0';
|
2018-10-07 12:57:38 +02:00
|
|
|
|
counter += fonction(&strbase2,&dest,2);
|
|
|
|
|
bufferend=itoa(num, &buffer, 2, sizes[asize], charadd);
|
|
|
|
|
buffersize=bufferend-&buffer[0];
|
|
|
|
|
counter += fonction(&buffer,&dest,buffersize);
|
2018-09-27 17:47:27 +02:00
|
|
|
|
flag = false;
|
|
|
|
|
break;
|
2018-08-17 16:46:56 +02:00
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-10-07 13:11:16 +02:00
|
|
|
|
buffer[0]='\000';
|
|
|
|
|
fonction(&buffer,&dest,1);
|
2018-08-29 10:12:00 +02:00
|
|
|
|
return counter;
|
2007-04-02 15:21:28 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-04 21:49:06 +02:00
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* converti un r<>el sign<67> en chaine de caract<63>re */
|
|
|
|
|
|
2018-10-05 22:56:58 +02:00
|
|
|
|
u8 *rtoadouble(double num, u8 * str, u8 precisioni , u8 precisionf) {
|
|
|
|
|
s8 power10;
|
|
|
|
|
u8 *pointer=str;
|
|
|
|
|
u8 i,j,integerpart,fracpart;
|
|
|
|
|
if (precisioni==0) precisioni=12;
|
|
|
|
|
if (precisionf==0) precisionf=8;
|
2018-10-07 12:57:38 +02:00
|
|
|
|
double round=0.5;
|
|
|
|
|
for (i=0;i<precisionf;i++) round/=10;
|
|
|
|
|
num+=round;
|
2018-10-05 22:56:58 +02:00
|
|
|
|
bool intok=false;
|
|
|
|
|
if (num<0) {
|
|
|
|
|
num=-num;
|
|
|
|
|
*(pointer++) = '-';
|
|
|
|
|
}
|
|
|
|
|
power10=0;
|
|
|
|
|
{
|
|
|
|
|
while (num>=10.0) {
|
|
|
|
|
num/=10;
|
|
|
|
|
power10++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (power10<precisioni)
|
|
|
|
|
{
|
|
|
|
|
fracpart=power10;
|
|
|
|
|
power10=0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
fracpart=precisioni;
|
|
|
|
|
power10=power10-precisioni+1;
|
|
|
|
|
}
|
|
|
|
|
if (power10==0)
|
|
|
|
|
{
|
|
|
|
|
if (num!=0.0)
|
|
|
|
|
{
|
|
|
|
|
while (num<1.0)
|
|
|
|
|
{
|
|
|
|
|
num*=10;
|
|
|
|
|
power10--;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i=j=0;
|
|
|
|
|
while(num>0)
|
|
|
|
|
{
|
|
|
|
|
if (!intok & (i>fracpart || i>=precisioni)) {
|
|
|
|
|
*(pointer++) = '.';
|
|
|
|
|
intok=true;
|
|
|
|
|
}
|
|
|
|
|
if (intok && j>=precisionf)
|
|
|
|
|
break;
|
|
|
|
|
num-= (integerpart=num);
|
|
|
|
|
*(pointer++) = integerpart+'0';
|
|
|
|
|
num*=10.0;
|
|
|
|
|
if (!intok)
|
|
|
|
|
i++;
|
|
|
|
|
else
|
|
|
|
|
j++;
|
|
|
|
|
}
|
|
|
|
|
while((*(pointer-1))=='0' && pointer>str+1)
|
|
|
|
|
pointer--;
|
|
|
|
|
if ((*(pointer-1))=='.') pointer--;
|
|
|
|
|
if (abs(power10)>0)
|
|
|
|
|
{
|
|
|
|
|
*(pointer++) = 'e';
|
|
|
|
|
if (power10<0) {
|
|
|
|
|
power10=-power10;
|
|
|
|
|
*(pointer++) = '-';
|
|
|
|
|
}
|
|
|
|
|
*(pointer++) = (power10/10+'0');
|
|
|
|
|
*(pointer++) = (power10%10+'0');
|
|
|
|
|
}
|
|
|
|
|
*(pointer++) = 0;
|
2018-10-04 21:49:06 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* converti un r<>el sign<67> en chaine de caract<63>re */
|
2018-10-05 22:56:58 +02:00
|
|
|
|
|
|
|
|
|
u8 *rtoasingle(float num, u8 * str, u8 precisioni , u8 precisionf) {
|
|
|
|
|
return rtoadouble((double)num, str, precisioni, precisionf);
|
2018-10-04 21:49:06 +02:00
|
|
|
|
}
|
|
|
|
|
|
2007-04-02 15:21:28 +02:00
|
|
|
|
/*******************************************************************************/
|
2018-08-29 10:12:00 +02:00
|
|
|
|
/* converti un entier non sign<67> en chaine de caract<63>re */
|
|
|
|
|
|
2018-09-27 21:01:02 +02:00
|
|
|
|
u8 *itoa(u64 orignum, u8 * str, u8 base, u64 dim, u8 achar)
|
2018-08-29 10:12:00 +02:00
|
|
|
|
{
|
2018-09-27 17:47:27 +02:00
|
|
|
|
u8 *pointer = str, i, size = 0;
|
2018-09-27 21:01:02 +02:00
|
|
|
|
u64 num = orignum;
|
2018-10-05 09:50:39 +02:00
|
|
|
|
if (dim>=0xFF)
|
|
|
|
|
{
|
|
|
|
|
num &= dim;
|
|
|
|
|
if ((num == 0) && (achar == 0)) {
|
|
|
|
|
*(pointer++) = '0';
|
|
|
|
|
*pointer = '\000';
|
|
|
|
|
return pointer;
|
|
|
|
|
}
|
|
|
|
|
switch (base) {
|
|
|
|
|
case 2:
|
|
|
|
|
size = log2(dim);
|
|
|
|
|
break;
|
|
|
|
|
case 8:
|
|
|
|
|
size = log2(dim) / 2;
|
|
|
|
|
break;
|
|
|
|
|
case 10:
|
|
|
|
|
size = log10(dim);
|
|
|
|
|
break;
|
|
|
|
|
case 16:
|
|
|
|
|
size = log2(dim) / 4;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
size=dim;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
for (i = 0; i < size; i++) {
|
2018-09-28 00:03:45 +02:00
|
|
|
|
if (num == 0) {
|
2018-10-05 09:50:39 +02:00
|
|
|
|
if (i==0)
|
|
|
|
|
*(pointer++) = '0';
|
|
|
|
|
else
|
|
|
|
|
*(pointer++) = achar;
|
2018-09-28 00:03:45 +02:00
|
|
|
|
if (achar == 0) break;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2018-09-27 21:01:02 +02:00
|
|
|
|
u64 result = num % (u32) base;
|
2018-09-28 00:03:45 +02:00
|
|
|
|
*(pointer++) = (result > 9) ? (result - 10) + 'a' : result + '0';
|
2018-09-27 17:47:27 +02:00
|
|
|
|
num = num / (u32) base;
|
2018-09-28 00:03:45 +02:00
|
|
|
|
}
|
2018-09-27 17:47:27 +02:00
|
|
|
|
}
|
|
|
|
|
*pointer = '\000';
|
|
|
|
|
strinvert(str);
|
2018-10-04 21:49:06 +02:00
|
|
|
|
return pointer;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* converti un entier en chaine de caract<63>re */
|
|
|
|
|
|
2018-09-28 00:03:45 +02:00
|
|
|
|
u8 *sitoa(u64 num, u8 * str, u64 dim)
|
2018-08-29 10:12:00 +02:00
|
|
|
|
{
|
2018-09-27 17:47:27 +02:00
|
|
|
|
u8 *pointer = str;
|
|
|
|
|
bool isNegative = false;
|
|
|
|
|
num &= dim;
|
|
|
|
|
if (num == 0) {
|
2018-10-04 21:49:06 +02:00
|
|
|
|
*(pointer++) = '0';
|
2018-09-27 17:47:27 +02:00
|
|
|
|
*pointer = '\000';
|
2018-10-04 21:49:06 +02:00
|
|
|
|
return pointer;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
}
|
2018-09-28 00:03:45 +02:00
|
|
|
|
if ((((dim+1)>>1)&num)>0) {
|
2018-09-27 17:47:27 +02:00
|
|
|
|
isNegative = true;
|
2018-09-28 00:03:45 +02:00
|
|
|
|
num = (~num&dim)+1;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
}
|
|
|
|
|
while (num != 0) {
|
2018-09-28 00:03:45 +02:00
|
|
|
|
u64 result = num % 10;
|
2018-09-27 17:47:27 +02:00
|
|
|
|
*(pointer++) =
|
|
|
|
|
(result > 9) ? (result - 10) + 'a' : result + '0';
|
|
|
|
|
num = num / 10;
|
|
|
|
|
}
|
|
|
|
|
if (isNegative)
|
|
|
|
|
*(pointer++) = '-';
|
|
|
|
|
*pointer = '\000';
|
|
|
|
|
strinvert(str);
|
2018-10-04 21:49:06 +02:00
|
|
|
|
return pointer;
|
2018-08-29 10:12:00 +02:00
|
|
|
|
}
|
2018-09-28 20:35:51 +02:00
|
|
|
|
/*******************************************************************************/
|
2018-10-12 20:37:26 +02:00
|
|
|
|
/* initialise le tableau des pilotes vid<69>o */
|
|
|
|
|
void initdriver() {
|
2018-10-13 13:23:00 +02:00
|
|
|
|
for(u32 i=0;i<MAXDRIVERS;i++)
|
2018-10-12 20:37:26 +02:00
|
|
|
|
registred[i].nom=NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Enregistre un pilote dans le tableau des pilotes vid<69>o */
|
2018-10-12 22:31:34 +02:00
|
|
|
|
void registerdriver(videofonction *pointer)
|
2018-10-12 20:37:26 +02:00
|
|
|
|
{
|
|
|
|
|
u32 i;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
for(i=0;i<MAXDRIVERS;i++)
|
2018-10-12 20:37:26 +02:00
|
|
|
|
if (registred[i].pointer==pointer)
|
|
|
|
|
return;
|
|
|
|
|
i=0;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
while (registred[i].nom!=NULL && i<MAXDRIVERS)
|
2018-10-12 20:37:26 +02:00
|
|
|
|
i++;
|
2018-10-13 17:17:40 +02:00
|
|
|
|
if (pointer->detect_hardware()!=NULL)
|
|
|
|
|
{
|
|
|
|
|
registred[i].pointer=pointer;
|
|
|
|
|
registred[i].nom=pointer->getvideo_drivername();
|
|
|
|
|
}
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Choisi le meilleur driver en terme d'affichage */
|
|
|
|
|
void apply_bestdriver(void) {
|
|
|
|
|
u32 i=0,j=0;
|
|
|
|
|
u8 bestdepth=0x0;
|
|
|
|
|
u8 bestresol=0x0;
|
|
|
|
|
u8 bestmode=0x0;
|
|
|
|
|
u8* bestdriver=NULL;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
capabilities *cap;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
while (registred[i].nom!=NULL && i<MAXDRIVERS) {
|
2018-10-12 22:31:34 +02:00
|
|
|
|
cap=registred[i].pointer->getvideo_capabilities();
|
2018-10-12 20:37:26 +02:00
|
|
|
|
while(cap[j].modenumber!=0xFF) {
|
|
|
|
|
if (cap[j].depth>bestdepth && (cap[j].width*cap[j].height)>=bestresol)
|
|
|
|
|
{
|
|
|
|
|
bestdepth=cap[j].depth;
|
|
|
|
|
bestresol=cap[j].width*cap[j].height;
|
|
|
|
|
bestmode=cap[j].modenumber;
|
2018-10-12 22:31:34 +02:00
|
|
|
|
bestdriver=registred[i].pointer->getvideo_drivername();
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
j++;
|
|
|
|
|
}
|
|
|
|
|
i++;
|
|
|
|
|
}
|
|
|
|
|
if (bestdriver!=NULL) apply_driver(bestdriver);
|
|
|
|
|
setvideo_mode(bestmode);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Choisi le meilleur driver sp<73>cifi<66> par le nom */
|
2018-10-12 22:31:34 +02:00
|
|
|
|
void apply_driver(u8* name)
|
2018-10-12 20:37:26 +02:00
|
|
|
|
{
|
|
|
|
|
u32 i=0;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
while (registred[i].nom!=NULL && i<MAXDRIVERS) {
|
2018-10-12 20:37:26 +02:00
|
|
|
|
if (strcmp(name,registred[i].nom)==0) {
|
2018-10-13 17:17:40 +02:00
|
|
|
|
detect_hardware=registred[i].pointer->detect_hardware;
|
|
|
|
|
setvideo_mode=registred[i].pointer->setvideo_mode;
|
|
|
|
|
getvideo_drivername=registred[i].pointer->getvideo_drivername;
|
|
|
|
|
getvideo_capabilities=registred[i].pointer->getvideo_capabilities;
|
|
|
|
|
getvideo_info=registred[i].pointer->getvideo_info;
|
|
|
|
|
mem_to_video=registred[i].pointer->mem_to_video;
|
|
|
|
|
video_to_mem=registred[i].pointer->video_to_mem;
|
|
|
|
|
video_to_video=registred[i].pointer->video_to_video;
|
|
|
|
|
wait_vretrace=registred[i].pointer->wait_vretrace;
|
|
|
|
|
wait_hretrace=registred[i].pointer->wait_hretrace;
|
|
|
|
|
page_set=registred[i].pointer->page_set;
|
|
|
|
|
page_show=registred[i].pointer->page_show;
|
|
|
|
|
page_split=registred[i].pointer->page_split;
|
|
|
|
|
cursor_enable=registred[i].pointer->cursor_enable;
|
|
|
|
|
cursor_disable=registred[i].pointer->cursor_disable;
|
|
|
|
|
cursor_set=registred[i].pointer->cursor_set;
|
|
|
|
|
font_load=registred[i].pointer->font_load;
|
|
|
|
|
font1_set=registred[i].pointer->font1_set;
|
|
|
|
|
font2_set=registred[i].pointer->font2_set;
|
|
|
|
|
blink_enable=registred[i].pointer->blink_enable;
|
|
|
|
|
blink_disable=registred[i].pointer->blink_disable;
|
|
|
|
|
changemode(0x0);
|
|
|
|
|
return;
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
i++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Applique le driver suivant */
|
|
|
|
|
|
|
|
|
|
void apply_nextdriver(void) {
|
|
|
|
|
u32 i=0;
|
2018-10-13 13:23:00 +02:00
|
|
|
|
while (registred[i].nom!=NULL && i<MAXDRIVERS)
|
2018-10-12 20:37:26 +02:00
|
|
|
|
if (strcmp(getvideo_drivername(),registred[i].nom)==0) {
|
|
|
|
|
i++;
|
|
|
|
|
if (registred[i].nom!=NULL) i=0;
|
|
|
|
|
apply_driver(registred[i].nom);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
i++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************/
|
|
|
|
|
/* Applique le mode suivant (le driver suivant si dernier mode) */
|
|
|
|
|
|
|
|
|
|
void apply_nextvideomode(void) {
|
2018-10-12 22:31:34 +02:00
|
|
|
|
capabilities *cap=getvideo_capabilities();
|
|
|
|
|
videoinfos *info=getvideo_info();
|
|
|
|
|
u32 mode=info->currentmode;
|
2018-10-12 20:37:26 +02:00
|
|
|
|
u8 index=0;
|
|
|
|
|
while(cap[index].modenumber!=0xFF) {
|
|
|
|
|
if (cap[index].modenumber==mode) {
|
|
|
|
|
index++;
|
|
|
|
|
if (cap[index].modenumber==0xFF)
|
|
|
|
|
apply_nextdriver();
|
|
|
|
|
else
|
2018-10-13 05:35:08 +02:00
|
|
|
|
changemode(cap[index].modenumber);
|
2018-10-12 20:37:26 +02:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
index++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Rempli l'<27>cran avec un attribut donn<6E> et des espaces vides */
|
|
|
|
|
|
2018-10-13 05:35:08 +02:00
|
|
|
|
static u8 space=' ';
|
2018-10-12 20:37:26 +02:00
|
|
|
|
|
|
|
|
|
void fill(u8 attrib)
|
|
|
|
|
{
|
2018-10-13 13:23:00 +02:00
|
|
|
|
if (!vinfo->isgraphic)
|
|
|
|
|
{
|
|
|
|
|
mem_to_video(space ,0,vinfo->pagesize>>1, false);
|
|
|
|
|
mem_to_video(attrib,1,vinfo->pagesize>>1, false);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
mem_to_video(0x0,0,vinfo->pagesize, false);
|
|
|
|
|
}
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* D<>file l'<27>cran de N ligne si le scrolling est activ<69> */
|
|
|
|
|
|
2018-10-12 20:37:26 +02:00
|
|
|
|
void scroll (u8 lines, u8 attrib)
|
|
|
|
|
{
|
2018-10-13 05:35:08 +02:00
|
|
|
|
if (vc[usedvc].scroll) {
|
|
|
|
|
if (!vinfo->isgraphic)
|
|
|
|
|
{
|
|
|
|
|
u32 gain=vinfo->currentpitch*lines;
|
2018-10-13 11:25:55 +02:00
|
|
|
|
video_to_video(gain,0,vinfo->pagesize-gain);
|
|
|
|
|
mem_to_video(space ,vinfo->pagesize-gain-2,gain, false);
|
|
|
|
|
mem_to_video(attrib,vinfo->pagesize-gain-1,gain, false);
|
2018-10-13 05:35:08 +02:00
|
|
|
|
}
|
2018-10-13 13:23:00 +02:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
u32 gain=vinfo->currentpitch*(lines<<3);
|
|
|
|
|
video_to_video(gain,0,vinfo->pagesize-gain);
|
|
|
|
|
mem_to_video(0x0 ,vinfo->pagesize-gain-2,gain, false);
|
|
|
|
|
}
|
2018-10-13 05:35:08 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
clearscreen();
|
|
|
|
|
}
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Active le scrolling */
|
|
|
|
|
|
2018-10-12 20:37:26 +02:00
|
|
|
|
void scroll_enable(void)
|
|
|
|
|
{
|
2018-10-13 05:35:08 +02:00
|
|
|
|
vc[usedvc].scroll=true;
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* D<>sactive le scrolling */
|
|
|
|
|
|
2018-10-12 20:37:26 +02:00
|
|
|
|
void scroll_disable(void)
|
|
|
|
|
{
|
2018-10-13 05:35:08 +02:00
|
|
|
|
vc[usedvc].scroll=false;
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Affiche un caract<63>re */
|
|
|
|
|
|
2018-10-13 05:35:08 +02:00
|
|
|
|
void showchar(u16 coordx, u16 coordy, u8 thechar, u8 attrib)
|
2018-10-12 20:37:26 +02:00
|
|
|
|
{
|
2018-10-13 13:23:00 +02:00
|
|
|
|
u8 x, y, pattern, set;
|
2018-10-13 17:17:40 +02:00
|
|
|
|
u32 color;
|
2018-10-13 05:35:08 +02:00
|
|
|
|
if (!vinfo->isgraphic)
|
|
|
|
|
{
|
|
|
|
|
u32 addr=(coordx<<1)+vinfo->currentpitch*coordy;
|
2018-10-13 11:25:55 +02:00
|
|
|
|
mem_to_video(thechar,addr , 1, false);
|
|
|
|
|
mem_to_video(attrib, addr+1, 1, false);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
for (y = 0; y < 8; y++)
|
|
|
|
|
{
|
2018-10-13 13:23:00 +02:00
|
|
|
|
pattern = font8x8[(thechar<<3) + y];
|
|
|
|
|
for (x = 0; x < 8; x++)
|
|
|
|
|
{
|
|
|
|
|
set = pattern & 0x1;
|
|
|
|
|
if (set == 0)
|
2018-10-14 11:14:34 +02:00
|
|
|
|
color = egatovga((attrib & 0xF0) >> 8);
|
2018-10-13 13:23:00 +02:00
|
|
|
|
else
|
2018-10-14 11:14:34 +02:00
|
|
|
|
color = egatovga(attrib & 0x0F);
|
|
|
|
|
if (vinfo->currentdepth==32)
|
|
|
|
|
color = vgatorgb(color);
|
2018-10-13 17:17:40 +02:00
|
|
|
|
writepxl((coordx<<3) + x, (coordy<<3) + y, color);
|
2018-10-13 11:25:55 +02:00
|
|
|
|
rol(pattern);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-14 11:14:34 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Retourne une couleur RGB 32 bits depuis une couleur EGA/VGA */
|
|
|
|
|
|
|
|
|
|
static convertega[]={0,1,2,3,4,5,20,7,56,57,58,59,60,61,62,63};
|
|
|
|
|
|
|
|
|
|
u8 egatovga(u8 ega)
|
|
|
|
|
{
|
|
|
|
|
return convertega[ega & 0xF];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Retourne une couleur RGB 32 bits depuis une couleur EGA/VGA */
|
|
|
|
|
|
|
|
|
|
u32 vgatorgb(u8 vga)
|
|
|
|
|
{
|
|
|
|
|
if (vga==0) return 0;
|
|
|
|
|
u8 red = 85 * (((vga >> 4) & 2) | (vga >> 2) & 1);
|
|
|
|
|
u8 green = 85 * (((vga >> 3) & 2) | (vga >> 1) & 1);
|
|
|
|
|
u8 blue = 85 * (((vga >> 2) & 2) | vga & 1);
|
|
|
|
|
return (red<<16)+(green<<8)+blue+(0x0<<24);
|
|
|
|
|
}
|
2018-10-13 17:17:40 +02:00
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Retourne le caract<63>re du mode texte aux coordonn<6E>es sp<73>cifi<66>es */
|
2018-10-12 20:37:26 +02:00
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
u8 getchar (u16 coordx, u16 coordy)
|
|
|
|
|
{
|
|
|
|
|
u8 thechar=0;
|
|
|
|
|
if (!vinfo->isgraphic)
|
|
|
|
|
{
|
|
|
|
|
u32 addr=(coordx<<1)+vinfo->currentpitch*coordy;
|
|
|
|
|
video_to_mem(addr,&thechar,1);
|
|
|
|
|
}
|
|
|
|
|
return thechar;
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Retourne l'attribut du mode texte aux coordonn<6E>es sp<73>cifi<66>es */
|
|
|
|
|
|
2018-10-12 20:37:26 +02:00
|
|
|
|
u8 getattrib (u16 coordx, u16 coordy)
|
|
|
|
|
{
|
2018-10-13 11:25:55 +02:00
|
|
|
|
u8 attrib=0;
|
|
|
|
|
if (!vinfo->isgraphic)
|
|
|
|
|
{
|
|
|
|
|
u32 addr=(coordx<<1)+vinfo->currentpitch*coordy;
|
|
|
|
|
video_to_mem(addr+1,&attrib,1);
|
|
|
|
|
}
|
|
|
|
|
return attrib;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Affiche une ligne horizontale entre les points sp<73>cifi<66>s */
|
|
|
|
|
|
|
|
|
|
void hline(u32 x1, u32 x2, u32 y, u8 color)
|
|
|
|
|
{
|
2018-10-13 17:17:40 +02:00
|
|
|
|
if (vinfo->isgraphic)
|
|
|
|
|
{
|
|
|
|
|
if (x2 > x1)
|
|
|
|
|
mem_to_video(color,x1+vinfo->currentpitch*y,x2-x1,false);
|
|
|
|
|
else
|
|
|
|
|
mem_to_video(color,x2+vinfo->currentpitch*y,x1-x2,false);
|
|
|
|
|
}
|
2018-10-13 11:25:55 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-12 20:37:26 +02:00
|
|
|
|
|
2018-10-13 11:25:55 +02:00
|
|
|
|
/******************************************************************************/
|
|
|
|
|
/* Affiche un pixel <20> l'<27>cran */
|
|
|
|
|
void writepxl (u16 x, u16 y, u32 color)
|
|
|
|
|
{
|
2018-10-13 17:17:40 +02:00
|
|
|
|
if (vinfo->isgraphic)
|
|
|
|
|
{
|
|
|
|
|
u32 addr=(vinfo->currentdepth>>3)*x+vinfo->currentpitch*y;
|
2018-10-13 11:25:55 +02:00
|
|
|
|
mem_to_video(color,addr,1,false);
|
2018-10-13 17:17:40 +02:00
|
|
|
|
}
|
2018-10-12 20:37:26 +02:00
|
|
|
|
}
|
2018-10-13 11:25:55 +02:00
|
|
|
|
|