Propeller OS
Mike Green
Posts: 23,101
Here's the latest version of the Propeller OS. In addition to some bug fixes, these are the major features added/changes:
1) All 3 display versions are included. There are 4 modules currently that are display dependent and the display dependent versions are in folders labelled with the type of display desired (TV, lowres VGA, hires VGA). The different types of modules have the same names (OS_initialization, OS_dspText, OS_dspTextInit, OS_loader). Just copy the set you need into the top level folder and compile.
2) The keyboard lights work again
3) There are early versions of support for GHI Electronics' uALFAT-SD and USBwiz. The USBwiz version is for SPI, but will be changed to I2C. The OS compiles with the uALFAT-SD support which uses the TEST command and just allows you to type commands to the uALFAT and see the resulting messages. Like the editor, the App key (to the left of Ins) is used to exit from the TEST command. Eventually these devices will be integrated into the PROBE, LIST, COPY and RUN commands. For those that are not familiar with them, these support MMC/SD cards with standard FAT directories (compatible with Windows, Mac, and Linux). The USBwiz also supports USB flash drives and a slightly different uALFAT-USB device supports USB flash drives instead of the MMC/SD cards, but with essentially the same command set.
4) The initialization routine has been moved to its own object. This simplfies the process of writing your own program using the OS routines without the command interpreter. You only have to reference the initialization object and call its start routine as the first thing in your main program.
Other plans:
1) Add cursor capability to the TV and lores VGA drivers and eventually make all three drivers strictly compatible except for display size and color capability. As much as possible, the color display control sequences will be made compatible. The intention is to make the three drivers interchangable
2) There is an experimental version of a LOAD command intended to allow direct downloading from the Propeller Tool using a USB2SER adapter (to avoid the reset from the Propeller Tool). It doesn't work yet and I'm not sure why. We'll see if I can get it to work eventually.
The pre-Halloween update is attached. There's a ReadMe file and some more demo programs, some minor corrections and additions.
Post Edited (Mike Green) : 10/27/2006 11:09:51 PM GMT
1) All 3 display versions are included. There are 4 modules currently that are display dependent and the display dependent versions are in folders labelled with the type of display desired (TV, lowres VGA, hires VGA). The different types of modules have the same names (OS_initialization, OS_dspText, OS_dspTextInit, OS_loader). Just copy the set you need into the top level folder and compile.
2) The keyboard lights work again
3) There are early versions of support for GHI Electronics' uALFAT-SD and USBwiz. The USBwiz version is for SPI, but will be changed to I2C. The OS compiles with the uALFAT-SD support which uses the TEST command and just allows you to type commands to the uALFAT and see the resulting messages. Like the editor, the App key (to the left of Ins) is used to exit from the TEST command. Eventually these devices will be integrated into the PROBE, LIST, COPY and RUN commands. For those that are not familiar with them, these support MMC/SD cards with standard FAT directories (compatible with Windows, Mac, and Linux). The USBwiz also supports USB flash drives and a slightly different uALFAT-USB device supports USB flash drives instead of the MMC/SD cards, but with essentially the same command set.
4) The initialization routine has been moved to its own object. This simplfies the process of writing your own program using the OS routines without the command interpreter. You only have to reference the initialization object and call its start routine as the first thing in your main program.
Other plans:
1) Add cursor capability to the TV and lores VGA drivers and eventually make all three drivers strictly compatible except for display size and color capability. As much as possible, the color display control sequences will be made compatible. The intention is to make the three drivers interchangable
2) There is an experimental version of a LOAD command intended to allow direct downloading from the Propeller Tool using a USB2SER adapter (to avoid the reset from the Propeller Tool). It doesn't work yet and I'm not sure why. We'll see if I can get it to work eventually.
The pre-Halloween update is attached. There's a ReadMe file and some more demo programs, some minor corrections and additions.
Post Edited (Mike Green) : 10/27/2006 11:09:51 PM GMT
zip
171K
Comments
Nico Hattink
I've got a newer version of the IDE. I don't remember if the fix for this has been posted yet. Do you have the 0.98.1 version?
If it's not been posted yet, I'll have to post the compiled binaries for now so people don't have to compile.
Mike
Nico Hattink
I ran across this 32 object limit before, trimmed back the number of objects. Parallax did fix the IDE, but I had forgotten that it hadn't been released yet. In trying to fix other stuff in the OS, I guess I've crept across the 32 object boundary again. Sorry.
I'll post the binaries this afternoon for each of the display types. You could try to embed the initialization routine back in the main program. That would eliminate one more object and might make it possible to compile. The editWindow object was put in a separate object because I expect it to get more complicated in the future. That could also be put back in the main program to eliminate another object.
Nico Hattink
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
In both the low resolution VGA version and the high resolution VGA version, there is an ability to affect the color of the display. In both cases, look at the list of control codes at the beginning of the display object (OS_vgaHiresText.spin or OS_vgaLoresText.spin). Most of these are the same in the different display versions, but the color ones are display dependent. The one you want is called "Color".
For the high resolution VGA display, do a series of "dsp.out" calls like "dsp.out(dsp#Color)", then "dsp.out(row)" where "row" is the display row to be affected, then "dsp.out(foreground)" where "foreground" is a foreground color, and "dsp.out(background)" where "background" is a background color. There's a comment describing "colorPtr" which gives the format for each color byte. Essentially it's %RRGGBB00 where RR is the two bits for red intensity, GG is the same for green, and BB is the same for blue. You'll have to experiment. I think the high resolution VGA text display demo program that Chip wrote displays samples of each text color combination.
For the low resolution VGA display, the color is set on a character by character basis with the same control code followed by a color number from 0 to 15 as in "dsp.out(dsp#Color)", then "dsp.out(color_code)". The default color codes are listed in a comment at the beginning of the OS_vgaLoresTextInit object and can be changed with a control code "SetColor". Again, this is based on Chip's video driver and the demo program for it does display text in different colors.
Color······ = $13········ ' change the colors of a row (Y, FG, BG follow)
I finally figured out that Y was row, FG was foreground color and BG was background color.· I won't bore you with the details but after a couple of hours I wrote:
· text.out($13)
· text.out(6)
· text.out(62)
· text.out(10)
· text.str(string("B - Red motor Off",13,13))
and it turned the text string bright blue with the same background as the default.· Then I wrote:
· text.str(string($13,6,62,10,"B - Red motor Off",13,13))·····
Same result - pefect.· Exactly what I wanted, but not where I wanted it.
So....I wrote in the DAT list:
op4Desc··· byte 13,"' -- ' is the decrement operator, either pre or post.· Let's say X := 10",13,13
byte $13,3,62,10,"Example of pre-decrement:· Y := --X + 2",13,13
byte "In this case X is decremented by 1 before the calculation is performed",13
byte "So...Y := --X + 2 = Y := 9 + 2 = 11.",13,13
byte "Example of post-decrement:· Y := X-- + 2.",13,13
byte "In this case, Y := 10 + 2 = 12, and then· X is decremented to 9",13
byte "In both cases X becomes 9 and retains that value until otherwise changed", 13, 13,0
and·the red·line changed to bright blue.· I tried to change color on the "post decrement" example but couldn't do it.· I could change it in combination with the previous line but never just by itself.· So finally I wrote:
op4Desc··· byte 13,"' -- ' is the decrement operator......···········
byte $13,3,62,10,"Example of pre-decrement:· Y := --X + 2",13,13
byte $13,5,62,10,"In this case X is decremented by 1 before .....······ byte $13,7,62,10,"So...Y := --X + 2 = Y := 9 + 2
byte $13,8,62,10,"Example of post-decrement:· Y := X-- + 2.",13,13
byte $13,10,62,10,"In this case, Y := 10 + 2 = 12, and then..........
byte $13,11,62,10,"In both cases X becomes 9 and retains........
and all lines changed to bright blue.· I then deleted the color change from all lines except the example lines.· Both example lines changed color, PLUS the line before the post-decrement example.· Don't understand it.
have a doctor's appointment.· Will post more when I return.
Sid
·····
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
The VGA driver has only limited color capability and a row of text can have only one color pair (foreground and background). The Color command changes the colors of a line when it (the command) is output, not when the actual text is output. I hope this helps.
Mike
I read the portion you quoted above, but since I don't know what word calls
up what color, nor how to call the pointer, it didn't really help.· I can make
things work with the $13 command hopefully, but my question now is - in
the DAT block, if I put the command at Line 8, why does it change Line 7 also?
That part bugs me.
In $13, 8, 62,10 - 62 is the foreground color (bright blue) and 10 is the back-
ground color (dark blue)· 10 is just what I want for background, but do you
have a list of what numbers yield what colors for the foreground?· If not,
I can punch in all the numbers and jot down what color I get.
Had an idea - changed Line 7 to $13,6,12,10, and left Line 8 alone.· Now Line
7 changes to a different color and Line 8 changes to bright blue.· If I had the
color number for yellow (or whatever the default is) I'd have it made.
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
The line number is zero-based as are all positioning commands and it doesn't matter what position the "cursor" is in when you do a "Color" command, the command contains the line number of the line to be affected. Do check out the hires VGA text demo that Chip wrote. I think it does demonstrate a variety of color combinations. I don't have a list of color codes.
Mike
you get.· Fascinating!
PUB colorfile
··· text.out(0)
··· text.out(13)
··· text.str(string($13,1,62,10,"Color is 62",13,13))
··· text.str(string($13,3,180,10,"Color is 180",13,13))
··· text.str(string($13,5,200,10,"Color is 200",13,13))
··· text.str(string($13,7,230,10,"Color is 230",13,13))
··· text.str(string($13,9,240,10,"Color is 240",13,13))
··· text.str(string($13,11,254,10,"Color is 254",13,13))
··· text.str(string(13,13,$13,15,254,10,"Press any key to return to Menu",13))
··· key.getkey
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
I noticed that when I returned to the Menu screen, the background color changes
carried over into the Menu screen.· In order to offset this, I had to add the
following at the end of the colorfile method:
key.getkey
··· text.str(string($13,19,240,10))
··· text.str(string($13,21,240,10))
··· text.str(string($13,23,240,10))
··· text.str(string($13,25,240,10))
··· text.str(string($13,27,240,10))
··· text.str(string($13,29,240,10))
··· start2
This forced the offending lines back to the default colors, but I was wondering -
is there a command I could enter just before the ShowMenu method that would
reset all the rows back to the default color, thus negating the previous color
changes.· I tried returning to "initialize" instead of "start2" but that did not solve
the problem.· I can reset and everything goes back to normal but that is not an
option I want to use.
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
folder, and renamed the keyboard and keyboardinit files to keyboardA and
keyboardinitA.· Put them in the OBJ block of my current program and now
all the keyboard lights work great.
Tried to run your simple Demo but no display - looks like the VGA is never started.
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
there any way I can simultaneously display this data on Hyperterminal
where it can be saved to an Excel file - perhaps use the existing "serialout"
method and change the pin to 31?
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
You could use the existing serialout method. The biggest problem with using the existing serial/USB connection is that, on most boards, DTR transitions always causes a reset and, when Windows or the Mac OS open that serial port, they fiddle with DTR. If you can temporarily disconnect the reset line, then you could usefully use pin 31, otherwise use some other pin with a USB2SER or PropPlug adapter.
Mike
Sneaky, eh what?
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
Mike
Does anyone have any idea if this will easily fit into your Propeller OS scheme?
Also, I am curious if you ever resolved the lack of a cursor in the opening posting.
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
"If you want more fiber, eat the package.· Not enough?· Eat the manual."········
I'm trying to integrate another SD reader/writer (the GHI one), but the same code would apply with Terry's except that you can't delete or rewrite a file as far as I can tell. Ask me again in a couple of weeks.
Mike
Something like the Graphics_Demo for TV.
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
·text.str(string($02,j,21,"*",13))
· text.str(string($02,j,22,"*",13))
· text.str(string($02,j,23,"*",13))
· text.str(string($02,j,24,"*",13))
· text.str(string($02,j,25,"*",13))·
j = X = a constant 10.· This prints 5 vertical " * " starting at X = 10, Y = 21.
Is there a way to increment Y a given number of times without having to
write a separate line for each Y position?· I wrote 21++ and
that didn't work.
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
?
$02,X,Y
X and Y are both constants or a unary value.· It I stick a variable in place of X or Y it won't compile.
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·
That allows any x,y you like. I'd make a function if I were you set_xy
Sid
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Sid Weaver
Don't have VGA?
Newzed@aol.com
·