Page 1 of 3
print function
Posted: Sun Dec 22, 2002 11:43 am
by pini
I wrote a C 'putchar' function and used it to write a 'print' function.
The first one works correctly, but the second one is making me crazy :
I think that the problem is in the call : print("My string");
On a P166 and on a 386, it works very well
On a PIII667 and on a P90, it prints nothing.
After hex-editing my elf-compiled file, I found out that the strings that are supposed to be print out are stored sequentially in the file. This means that there is a \0 character (marking the end of a string) between each pair of strings.
In my print function, I am using this kind of code :
while(*string!=0)
{
putchar(*string);
string++;
}
where string is a pointer to an unsigned char.
May the problem come from the fact that the call is using a false address (I mean giving the address of the character before (ie : \0) the first one in my string) ?
Can anyone give me a piece of help ?
Re:print function
Posted: Sun Dec 22, 2002 12:28 pm
by Whatever5k
Please show us the whole code of print() and putchar().
And try this here:
Re:print function
Posted: Sun Dec 22, 2002 1:31 pm
by pini
Here you are :
[pre]void putchar(unsigned char chr)
{
unsigned char x;
unsigned char y;
unsigned char*dest;
unsigned short position;
x=ttytable[currenttty].column;
y=ttytable[currenttty].row;
switch(chr)
{
case 0xA:
x=0;
y++;
if(y>24)
{
scrollup(1);
y=24;
}
break;
case 0x8:
if(x>0)
x--;
else
{
if(y>0)
{
x=79;
y--;
}
else
break;
}
dest=(unsigned char*)(VIDRAM+160*y+2*x);
position=80*y+x;
ttytable[currenttty].screen[position].ascii=0x0;
ttytable[currenttty].screen[position].attribute=ttytable[currenttty].attribute;
*dest=ttytable[currenttty].screen[position].ascii;
*(dest+1)=ttytable[currenttty].screen[position].attribute;
break;
default:
dest=(unsigned char*)(VIDRAM+160*y+2*x);
position=80*y+x;
ttytable[currenttty].screen[position].ascii=chr;
ttytable[currenttty].screen[position].attribute=ttytable[currenttty].attribute;
*dest=ttytable[currenttty].screen[position].ascii;
*(dest+1)=ttytable[currenttty].screen[position].attribute;
x++;
break;
}
if(x>79)
{
x=0;
y++;
if(y>24)
{
scrollup(1);
y=24;
}
}
gotoxy(x,y);
return;
}
void print(unsigned char*string)
{
while(*string!=0)
{
putchar(*string);
string++;
}
return;
}[/pre]
Re:print function
Posted: Sun Dec 22, 2002 1:39 pm
by pini
It didn't change anything to replace 0 by '\0'
I have found that replacing
[pre]print("hello");[/pre]
by
[pre]print(str);[/pre]
where str is definded as follow :
[pre]unsigned char str[6]={'H','e','l','l','o',0};[/pre]
makes my print function work correctly on my four test machines.
Re:print function
Posted: Sun Dec 22, 2002 2:15 pm
by jrfritz
Not a good idea to make you printf like that.
Instead...check if you like my code and if you do, use that. it's in fstdio.h in the include directory.
download it at:
http://sourceforge.net/projects/fritzos
Re:print function
Posted: Sun Dec 22, 2002 4:05 pm
by pini
Ok, thanks for your help.
But I still can't understand why it works on two computer and why not on two others... It's a little "brainstorming"...
Re:print function
Posted: Sun Dec 22, 2002 4:27 pm
by pini
Hum...
Here are the results of my last test :
I replaced
[pre]
while(*string!='\0')
{
putchar(*string);
string++;
}
[/pre]
by
[pre]
for(i=0;i<=5;i++)
putchar(string[]);
putchar('\n');
[/pre]
The result of this is that only the new line appears on the screen.
Does this mean that there is a problem in the address of string? Because there may be a '\0' just before my string in the compiled file, but my string is not entirely composed of null characters...
Re:print function
Posted: Sun Dec 22, 2002 6:39 pm
by Unexpected
I change my Print function, and now it doesn't work well... When I Print a text like txt[]="Simple" I got a colored and mixed text.
I don't know whats wrong?
Here is code:
Code: Select all
char* video = (char*)0xB8000;
static long curX, curY;
static unsigned char textattrib=0x07;
void PutCh(char ch)
{
unsigned int i = 0;
i = (curY*80*2) + curX;
if (ch != 0)
{
if (ch == '\n')
{
curY++;
curX = 0;
}
else
{
video[i] = ch;
i++;
video[i] = textattrib;
curX++;
}
if (curY > 25) curY = 0;
Update_Cursor();
}
}
void Print(char *msg)
{
while (*msg != "\0")
{
PutCh(*msg);
*msg++;
}
}
Re:print function
Posted: Sun Dec 22, 2002 7:25 pm
by jrfritz
I'm looking...but FritzOS has a good well tested Printf.
I'll post if I find a prob.
Re:print function
Posted: Sun Dec 22, 2002 7:27 pm
by jrfritz
Could I see your update_cursor function?
Re:print function
Posted: Sun Dec 22, 2002 7:45 pm
by Unexpected
Here:
Code: Select all
void GotoXY(int x, int y)
{
unsigned short position = (y*80+x);
outportb(0x3D4, 0x0F);
outportb(0x3D5, (unsigned char)(position&0xFF));
outportb(0x3D4, 0x0E);
outportb(0x3D5, (unsigned char)((position>>8)&0xFF));
curX = x;
curY = y;
}
void Update_Cursor()
{
GotoXY(curX, curY);
}
I dont understand.. how text became a colored?
This is very simple:
video
= ch;
i++;
video = textattrib;
curX++;
So whats wrong?
Re:print function
Posted: Sun Dec 22, 2002 7:54 pm
by Unexpected
P.S. - There is one thing... For example if I want to print a text "Hello", my functions prints colored "Hlo". Thats means - first symbol is printed correctly, but second is used as textattrib :/ ???
Re:print function
Posted: Sun Dec 22, 2002 7:56 pm
by jrfritz
Hmmm...I can't find anything.
Must be some sortof hard to fine typo...
try this:
Code: Select all
unsigned int k_printf(char *message, unsigned int line) // the message and then the line #
{
char *vidmem = (char *) 0xb8000;
unsigned int i=0;
i=(line*80*2);
while(*message!=0)
{
if(*message==0x2F) // check for the next line stuff
{
*message++;
if(*message==0x6e)
{
line++;
i=(line*80*2);
*message++;
if(*message==0)
{
return(1);
};
};
*message--; // got to go back, this is just a forward slash
};
vidmem[i]=*message;
*message++;
i++;
vidmem[i]=WHITE_TXT;
i++;
};
return(1);
};
Re:print function
Posted: Sun Dec 22, 2002 8:34 pm
by jrfritz
Worked?
Re:print function
Posted: Sun Dec 22, 2002 8:46 pm
by Unexpected
No... :-\
i = (curY*80*2) + curX;
vidmem = 'A';
i++;
vidmem = 0x07;
curX++;
And I have 'A'(writed 2 times in same place) and background color - blue, text - red...
Can you write a simple WORKING putch() function plz?