ARM programming for Risc OS
RISC OS was the operating system of
the Acorn Archimedes... although the machine is long since dead,
RISC OS has survived and ported to modern machines like the
Raspberry Pi
In these tutorials we'll be testing with Risc OS 3.57 - which
is the OS of the successor of the Archimedes, but where
possible we'll try and support the classic RiscOS 2... and we'll be
using instructions compatible with ARM2 for backwards compatibility!
These tutorials use the VASM
assembler
|
|
|
|
Acorn Archimedes versions
|
A3000 |
A5000 |
RISC PC |
CPU |
8mhz ARM2 |
25 mhz ARM3 |
30mhz ARM 610 |
Memory |
1 MB |
1-8 MB |
? |
OS |
RISC OS 2 |
RISC OS 3 |
Risc OS 3.5 - 4.03 |
Screen |
320x240 16/256 color |
320x240 16/256 color |
320x240 16/256 color |
|
|
|
If you want to learn ARM get the Cheatsheet! it has all the ARM7 commands, it covers the
commands, and options like Bitshifts and conditions as well as
the bytecode structure of the commands! |
|
Resources
RPCEMU - Risc OS
emulator
Rom Images
- Images for RISC OS
ARM Hello World Series
ARM Platform Specific Lessons
ARM Simple Samples
Executable files
The easiest way to create a program is save it as a FF8.... eg
'prog,ff8'... NOTE: this is a COMMA before ff8 not a full stop -
this is how RISC OS denotes file type
Our program just needs to start from 0x8000 and it will work
fine!... please note, you'll need to create your own stack area and
define a stack pointer if you need the Stack, as the OS doesn't
create one!
The Example Hello World to the right will compile correctly with VASM |
.org
0x08000
SWI
01
;OS_WriteS
.ascii
"Hello World!"
.byte
0
;End of string
.align
4
MOV
R0,#0
;0=No
Error
SWI 0x11
;OS_Exit |
We can also create a !Run,feb to autostart the program with
the emulator, we |
RMEnsure
UtilityModule 3.10 Error This !Boot structure is only suitable
for RISC OS 3.1 or later
Set Boot$Dir <Obey$Dir>
Set Boot$Path <Boot$Dir>.
desktop prog |
Using Risc OS
When using Risc OS, you will often
want the options on a file... to get this use the MIDDLE
MOUSE button |
|
You can get a command prompt by
pressing CTRL-F12, or selecting Task Window by middle clicking on
the Acorn icon
The commands you can use are known as Star Commands... there is a
list of them here |
|
256 color mode
On RiscOS, 256 color mode probably doesn't work the way you want!
Only 64 colors are configurable, Each of these are presented using 4
different brightness (defined by the bottom 2 bits.
Here is the default 256 color palette:
Bit
|
Meaning |
0 |
Tint
bit 0 (red + green + blue bit 0) |
1 |
Tint
bit 1 (red + green + blue bit 1) |
2 |
Red
bit 2 |
3 |
Blue
bit 2 |
4 |
Red
bit 3 (high) |
5 |
Green
bit 2 |
6 |
Green
bit 3 (high) |
7 |
Blue
bit 3 (high) |
VDU Commands
Many screen functions are performed via 'VDU Commands'... to
use these, we just write special character codes to the screen with SWI 0
Page |
Meaning
|
Parameters |
Example |
VDU 0 |
Does nothing |
0 |
|
VDU 1 |
Sends next character to printer only |
1,c |
|
VDU 2 |
Enables printer |
2 |
|
VDU 3 |
Disables printer |
3 |
|
VDU 4 |
Writes text at text cursor |
4 |
|
VDU 5 |
Writes text at graphics cursor |
5 |
|
VDU 6 |
Enables VDU driver |
6 |
|
VDU 7 |
Generates bell sound |
7 |
|
VDU 8 |
Moves cursor back one character |
8 |
|
VDU 9 |
Moves cursor on one space |
9 |
|
VDU 10 |
Moves cursor down one line |
10 |
|
VDU 11 |
Moves cursor up one line |
11 |
|
VDU 12 |
Clears text window |
12 |
|
VDU 13 |
Moves cursor to start of current line |
13 |
|
VDU 14 |
Turns on paged mode |
14 |
|
VDU 15 |
Turns off paged mode |
15 |
|
VDU 16 |
Clears graphics window |
16 |
|
VDU 17 |
Defines text colour |
17,color |
|
VDU 18 |
Defines graphics colour |
18,maskmode,color |
|
VDU 19 |
Defines logical colour |
19,color,mode,r,g,b |
19,0,16,255,128,0 |
VDU 20 |
Restores default logical colours |
20 |
|
VDU 21 |
Disables VDU drivers |
21 |
|
VDU 22 |
Selects screen mode |
22,ScreenMode |
22,9 |
VDU 23 |
Multi-purpose command: |
n,n,n,n,n,n,n,n,n |
|
VDU 23 |
Sets the interlace and controls cursor
appearance |
? |
|
VDU 23 |
Controls text cursor appearance |
? |
|
VDU 23 |
Defines ECF pattern and colours |
? |
|
VDU 23 |
Sets dot-dash line style |
? |
|
VDU 23 |
Scrolls text window or screen |
? |
|
VDU 23 |
Clears a block of the text window |
? |
|
VDU 23 |
Sets first flash time |
? |
|
VDU 23 |
Sets second flash time |
? |
|
VDU 23 |
Sets default patterns |
? |
|
VDU 23 |
Defines simple ECF patterns and colours |
? |
|
VDU 23 |
Controls cursor movement after printing |
? |
|
VDU 23 |
Sets the tint for a colour |
? |
|
VDU 23 |
Chooses ECF patterns |
? |
|
VDU 23 |
Exchanges text foreground and background
colours |
? |
|
VDU 23 |
Sets ECF origin |
? |
|
VDU 23 |
Sets character size/spacing |
? |
|
VDU 23 |
Reserved for future expansion |
? |
|
VDU 23 |
Private Font Manager calls |
? |
|
VDU 23 |
Private Sprite Manager calls |
? |
|
VDU 23 |
Reserved for use by application programs |
? |
|
VDU 23 |
Redefines printable characters |
? |
|
VDU 24 |
Defines graphics window |
24,x1,y1,x2,y2 |
|
VDU 25 |
PLOT command |
25,x,y |
|
VDU 26 |
Restores default windows |
26 |
|
VDU 27 |
Does nothing |
27 |
|
VDU 28 |
Defines text window |
28,x1,y1,x2,y2 |
|
VDU 29 |
Defines graphics origin |
29,x,y |
|
VDU 30 |
Homes text cursor |
30 |
|
VDU 31 |
Moves text cursor |
31,x,y |
|
VDU 127 |
Delete |
127 |
|
SWI commands
SWI's are systems calls to the operating system... many SWI's were added in
later operating system versions, so ensure you only use SWI's that exist on
the version you want to support.
OS Ver |
Number |
Name |
Function |
2 |
&00
|
OS_WriteC
|
Write
Character
R0 to Screen |
2 |
&01
|
OS_WriteS
|
Write
0
termniated string to screen � string follows SWI in code |
2 |
&02
|
OS_Write0
|
|
2 |
&03
|
OS_NewLine
|
Start
a new line (no params)
|
2 |
&04
|
OS_ReadC
|
|
2 |
&05
|
OS_CLI
|
|
2 |
&06
|
OS_Byte
Index of OS_Bytes |
|
2 |
&07
|
OS_Word
Index of OS_Words |
|
2 |
&08
|
OS_File
|
|
2 |
&09
|
OS_Args
|
|
2 |
&0A
|
OS_BGet
|
|
2 |
&0B
|
OS_BPut
|
|
2 |
&0C
|
OS_GBPB
|
|
2 |
&0D
|
OS_Find
|
|
2 |
&0E
|
OS_ReadLine
|
|
2 |
&0F
|
OS_Control
|
|
2 |
&100-1FF
|
OS_WriteI
|
|
2 |
&10
|
OS_GetEnv
|
|
2 |
&11
|
OS_Exit
|
Return
to
OS� R0=Errorcode (0=no error) |
2 |
&12
|
OS_SetEnv
|
|
2 |
&13
|
OS_IntOn
|
|
2 |
&14
|
OS_IntOff
|
|
2 |
&15
|
OS_CallBack
|
|
2 |
&16
|
OS_EnterOS
|
|
2 |
&17
|
OS_BreakPt
|
|
2 |
&18
|
OS_BreakCtrl
|
|
2 |
&19
|
OS_UnusedSWI
|
|
2 |
&1A
|
OS_UpdateMEMC
|
|
2 |
&1B
|
OS_SetCallBack
|
|
2 |
&1C
|
OS_Mouse
|
|
2 |
&1D
|
OS_Heap
OS_Heap (5a) |
|
2 |
&1E
|
OS_Module
|
|
2 |
&1F
|
OS_Claim
|
|
2 |
&20
|
OS_Release
|
|
2 |
&21
|
OS_ReadUnsigned
|
|
2 |
&22
|
OS_GenerateEvent
|
|
2 |
&23
|
OS_ReadVarVal
|
|
2 |
&24
|
OS_SetVarVal
|
|
2 |
&25
|
OS_GSInit
|
|
2 |
&26
|
OS_GSRead
|
|
2 |
&27
|
OS_GSTrans
|
|
2 |
&28
|
OS_BinaryToDecimal
|
|
2 |
&29
|
OS_FSControl
OS_FSControl 55 |
|
2 |
&2A
|
OS_ChangeDynamicArea
OS_ChangeDynamicArea (5a) |
|
2 |
&2B
|
OS_GenerateError
|
|
2 |
&2C
|
OS_ReadEscapeState
|
|
2 |
&2D
|
OS_EvaluateExpression
|
|
2 |
&2E
|
OS_SpriteOp
Changes to OS_SpriteOp
OS_SpriteOp 17 |
|
2 |
&2F
|
OS_ReadPalette
|
|
2 |
&30
|
OS_ServiceCall
OS_ServiceCall (5a) |
|
2 |
&31
|
OS_ReadVduVariables
|
R0 = pointer to input block , R1 = pointer to output block
|
2 |
&32
|
OS_ReadPoint
|
|
2 |
&33
|
OS_UpCall
|
|
2 |
&34
|
OS_CallAVector
|
|
2 |
&35
|
OS_ReadModeVariable
OS_ReadModeVariable (5a) |
|
2 |
&36
|
OS_RemoveCursors
|
Disable
Cursor (No Params)
|
2 |
&37
|
OS_RestoreCursors
|
|
2 |
&38
|
OS_SWINumberToString
|
|
2 |
&39
|
OS_SWINumberFromString
|
|
2 |
&3A
|
OS_ValidateAddress
|
|
2 |
&3B
|
OS_CallAfter
|
|
2 |
&3C
|
OS_CallEvery
|
|
2 |
&3D
|
OS_RemoveTickerEvent
|
|
2 |
&3E
|
OS_InstallKeyHandler
|
|
2 |
&3F
|
OS_CheckModeValid
OS_CheckModeValid (5a) |
|
2 |
&40
|
OS_ChangeEnvironment
|
|
2 |
&41
|
OS_ClaimScreenMemory
|
|
2 |
&42
|
OS_ReadMonotonicTime
|
|
2 |
&43
|
OS_SubstituteArgs
|
|
2 |
&44
|
OS_PrettyPrint
|
|
2 |
&45
|
OS_Plot
OS_Plot (5a) |
|
2 |
&46
|
OS_WriteN
|
|
2 |
&47
|
OS_AddToVector
|
|
2 |
&48
|
OS_WriteEnv
|
|
2 |
&49
|
OS_ReadArgs
|
|
2 |
&4A
|
OS_ReadRAMFsLimits
|
|
2 |
&4B
|
OS_ClaimDeviceVector
|
|
2 |
&4C
|
OS_ReleaseDeviceVector
|
|
2 |
&4D
|
OS_DelinkApplication
|
|
2 |
&4E
|
OS_RelinkApplication
|
|
2 |
&4F
|
OS_HeapSort
|
|
2 |
&50
|
OS_ExitAndDie
|
|
2 |
&51
|
OS_ReadMemMapInfo
|
|
2 |
&52
|
OS_ReadMemMapEntries
|
|
2 |
&53
|
OS_SetMemMapEntries
OS_SetMemMapEntries (5a) |
|
2 |
&54
|
OS_AddCallBack
|
|
2 |
&55
|
OS_ReadDefaultHandler
|
|
2 |
&56
|
OS_SetECFOrigin
|
|
2 |
&57
|
OS_SerialOp
OS_SerialOp (5a) |
|
2 |
&58
|
OS_ReadSysInfo
OS_ReadSysInfo (5a) |
|
2 |
&59
|
OS_Confirm
|
|
2 |
&5A
|
OS_ChangedBox
|
|
2 |
&5B
|
OS_CRC
|
|
3 |
&5C
|
OS_ReadDynamicArea
OS_ReadDynamicArea (5a) |
|
3 |
&5D
|
OS_PrintChar
|
|
3 |
&5E
|
OS_ChangeRedirection
|
|
3 |
&5F
|
OS_RemoveCallBack
|
|
3 |
&60
|
OS_FindMemMapEntries
|
|
3 |
&61
|
OS_SetColour
OS_SetColour (5a) |
|
3 |
&64
|
OS_Pointer
|
|
3.5 |
&65
|
OS_ScreenMode
|
|
3.5 |
&66
|
OS_DynamicArea
|
|
2 |
&68
|
OS_Memory
|
|
2 |
&69
|
OS_ClaimProcessorVector
|
|
3.5 |
&6A
|
OS_Reset
|
|
3.5 |
&6B
|
OS_MMUControl
|
|
2 |
&C0
|
OS_ConvertStandardDateAndTime
|
|
2 |
&C1
|
OS_ConvertDateAndTime
|
|
2 |
&D0
|
OS_ConvertHex1
|
|
2 |
&D1
|
OS_ConvertHex2
|
|
2 |
&D2
|
OS_ConvertHex3
|
|
2 |
&D3
|
OS_ConvertHex4
|
|
2 |
&D4
|
OS_ConvertHex8
|
|
2 |
&D5
|
OS_ConvertCardinal1
|
|
2 |
&D6
|
OS_ConvertCardinal2
|
|
2 |
&D7
|
OS_ConvertCardinal3
|
|
2 |
&D8
|
OS_ConvertCardinal4
|
|
2 |
&D9
|
OS_ConvertInteger1
|
|
2 |
&DA
|
OS_ConvertInteger2
|
|
2 |
&DB
|
OS_ConvertInteger3
|
|
2 |
&DC
|
OS_ConvertInteger4
|
|
2 |
&DD
|
OS_ConvertBinary1
|
|
2 |
&DE
|
OS_ConvertBinary2
|
|
2 |
&DF
|
OS_ConvertBinary3
|
|
2 |
&E0
|
OS_ConvertBinary4
|
|
2 |
&E1
|
OS_ConvertSpacedCardinal1
|
|
2 |
&E2
|
OS_ConvertSpacedCardinal2
|
|
2 |
&E3
|
OS_ConvertSpacedCardinal3
|
|
2 |
&E4
|
OS_ConvertSpacedCardinal4
|
|
2 |
&E5
|
OS_ConvertSpacedInteger1
|
|
2 |
&E6
|
OS_ConvertSpacedInteger2
|
|
2 |
&E7
|
OS_ConvertSpacedInteger3
|
|
2 |
&E8
|
OS_ConvertSpacedInteger4
|
|
2 |
&E9
|
OS_ConvertFixedNetStation
|
|
2 |
&EA
|
OS_ConvertNetStation
|
|
2 |
&EB
|
OS_ConvertFixedFileSize
|
|
2 |
&EC
|
OS_ConvertFileSize
|
|
OS_Bytes - (SWI 6)
Number
|
Description |
R0
|
Options |
&00 |
Display OS version information |
0 |
|
&02 |
Specify input stream |
2 |
|
&03 |
Specify output streams |
3 |
|
&04 |
Cursor key status |
4 |
|
&05 |
Write printer driver type |
5 |
|
&06 |
Write printer ignore character |
6 |
|
&07 |
Write RS423 receive rate |
7 |
|
&08 |
Write RS423 transmit rate |
8 |
|
&09 |
Write duration of first colour |
9 |
|
&0A |
Write duration of second colour |
10 |
|
&0B |
Write keyboard auto-repeat delay |
11 |
|
&0C |
Write keyboard auto-repeat rate |
12 |
|
&0D |
Disable event |
13 |
|
&0E |
Enable event |
14 |
|
&0F |
Flush buffer |
15 |
|
&10 |
Store the number of channels to be sampled |
16 |
|
&11 |
Return to the caller, doing nothing |
17 |
|
&12 |
Reset function keys |
18 |
|
&13 |
Wait for vertical sync (vsync) |
19 |
|
&14 |
Reset font definitions |
20 |
|
&15 |
Flush selected buffer |
21 |
|
&19 |
Reset group of font definitions |
25 |
|
&46 |
Read/write country number |
70 |
|
&47 |
Read/write alphabet or keyboard |
71 |
|
&6A |
Select pointer / activate mouse |
106 |
|
&70 |
Write VDU driver screen bank |
112 |
|
&71 |
Write display hardware screen bank |
113 |
|
&72 |
Write shadow/non-shadow state |
114 |
|
&75 |
Read VDU status |
117 |
|
&76 |
Reflect keyboard status in LEDs |
118 |
|
&79 |
Keyboard scan |
121 |
|
&7A |
Keyboard scan from 16 decimal |
122 |
|
&7C |
Clear escape condition |
124 |
|
&7D |
Set escape condition |
125 |
|
&7E |
Acknowledge escape condition |
126 |
|
&7F |
Check for end of file |
127 |
|
&80 |
Get buffer/mouse status |
128 |
|
&80 |
Return switch state and last channel converted |
128 |
|
&81 |
Scan a for a particular key |
129 |
R1=Wait, R2=0.... Returns R1=Ascii
R1=255^Keycode,R2=255... Returns R1=255 if pressed
|
&86 |
Read text cursor position |
134 |
|
&87 |
Read character at text cursor and screen mode |
135 |
|
&8A |
Insert character code into buffer |
138 |
|
&8B |
Write filing system options |
139 |
|
&8F |
Issue module service call |
143 |
|
&90 |
Set vertical screen shift and interlace |
144 |
|
&91 |
Get character from buffer |
145 |
|
&98 |
Examine buffer status |
152 |
|
&99 |
Insert character into buffer |
153 |
|
&9C |
Read/write asynchronous communications state |
156 |
|
&A0 |
Read VDU variable value |
160 |
|
&A1 |
Read battery backed RAM |
161 |
|
&A2 |
Write battery backed RAM |
162 |
|
&A3 |
Read/write general graphics information |
163 |
|
&A5 |
Read output cursor position |
165 |
|
&B0 |
50Hz counter |
176 |
|
&B1 |
Read input source |
177 |
|
&B5 |
Read/write RS423 input interpretation status |
181 |
|
&B6 |
Read/write NoIgnore state |
182 |
|
&BC |
Read the current channel |
188 |
|
&BD |
Read the number of channels to be sampled |
189 |
|
&BE |
Read the resolution of conversion |
190 |
|
&BF |
Read/write RS423 busy flag |
191 |
|
&C0 |
Read RS423 control byte |
192 |
|
&C1 |
Read/write flash counter |
193 |
|
&C2 |
Read duration of second colour |
194 |
|
&C3 |
Read duration of first colour |
195 |
|
&C4 |
Read/write keyboard auto-repeat delay |
196 |
|
&C5 |
Read/write keyboard auto-repeat rate |
197 |
|
&C6 |
Read/write *Exec file handle |
198 |
|
&C7 |
Read/write *Spool file handle |
199 |
|
&C8 |
Read/write Break and Escape effect |
200 |
|
&C9 |
Read/write keyboard disable flag |
201 |
|
&CA |
Read/write keyboard status byte |
202 |
|
&CB |
Read/write RS423 input buffer minimum space |
203 |
|
&CC |
Read/write RS423 ignore flag |
204 |
|
&D3 |
Read/write bell channel |
211 |
|
&D4 |
Read/write bell sound volume |
212 |
|
&D5 |
Read/write bell frequency |
213 |
|
&D6 |
Read/write bell duration |
214 |
|
&D8 |
Read/write length of function key string |
216 |
|
&D9 |
Read/write paged mode line count |
217 |
|
&DA |
Read/write bytes in VDU queue |
218 |
|
&DB |
Read/write Tab key code |
219 |
|
&DC |
Read/write escape character |
220 |
|
&DD |
Read/write interpretation of input values &C0 -
&CF |
221 |
|
&DE |
Read/write interpretation of input values &D0 -
&DF |
222 |
|
&DF |
Read/write interpretation of input values &E0 -
&EF |
223 |
|
&E0 |
Read/write interpretation of input values &F0 -
&FF |
224 |
|
&E1 |
Read/write function key interpretation |
225 |
|
&E2 |
Read/write Shift function key interpretation |
226 |
|
&E3 |
Read/write Ctrl function key interpretation |
227 |
|
&E4 |
Read/write Ctrl Shift function key interpretation |
228 |
|
&E5 |
Read/write Escape key status |
229 |
|
&E6 |
Read/write escape effects |
230 |
|
&EC |
Read/write character destination status |
236 |
|
&ED |
Read/write cursor key status |
237 |
|
&EE |
Read/write numeric keypad interpretation |
238 |
|
&F0 |
Read country flag |
240 |
|
&F2 |
Read RS423 baud rates |
242 |
|
&F3 |
Read timer switch state |
243 |
|
&F5 |
Read printer driver type |
245 |
|
&F6 |
Read/write printer ignore character |
246 |
|
&F7 |
Read/write Break key actions |
247 |
|
&FA |
Read VDU driver screen bank number |
250 |
|
&FB |
Read display screen bank number |
251 |
|
&FD |
Read last break type |
253 |
|
&FE |
Set effect of Shift Ctrl on numeric keypad |
254 |
|
&FF |
Read/write boot option |
255 |
|
Keycodes
Esc:112 |
|
F1: 113 |
F2: 114 |
F3: 115 |
F4: 20 |
F5: 116 |
F6: 117 |
F7: 22 |
F8: 118 |
F9: 119 |
F10:30 |
F11: 28 |
F12: 29 |
|
|
Print: 32 |
ScrlLk:31 |
Brk:44 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
`: 45 |
1: 48 |
2: 49 |
3: 17 |
4: 18 |
5: 19 |
6: 24 |
7: 36 |
8: 21 |
9: 38 |
0: 39 |
-: 23 |
=: 93 |
Pnd: 46 |
Bksp: 47 |
|
Ins: 61 |
Home:62 |
PgUp:63 |
|
NmLk: 77 |
/: 74 |
*: 91 |
#: 90 |
Tab: 96 |
Q: 16 |
W: 33 |
E: 34 |
R: 51 |
T: 35 |
Y: 68 |
U: 53 |
I: 37 |
O: 54 |
P: 55 |
[: 56 |
]: 88 |
|
\: 120 |
|
Del: 89 |
Copy:105 |
PgDown:78 |
|
7: 27 |
8: 42 |
9: 43 |
-: 59 |
Ctrl: 14 |
A: 65 |
S: 81 |
D: 50 |
F: 67 |
G: 83 |
H: 84 |
J: 69 |
K: 70 |
L: 86 |
;: 72 |
': 79 |
|
|
Retn: 73 |
|
|
|
|
|
4: 122 |
5: 123 |
6: 26 |
+: 58 |
Shift: 03 |
|
Z: 97 |
X: 66 |
C: 82 |
V: 99 |
B: 100 |
N: 85 |
M: 101 |
,: 102 |
.: 103 |
/: 104 |
|
|
Shift:06 |
|
|
U:57 |
|
|
1: 107 |
2: 124 |
3:108 |
Enter: 60 |
Caps: 64 |
|
Alt: 25 |
|
|
|
Spc: 98 |
|
|
|
|
|
Alt:28 |
|
Ctrl: 17 |
|
L:25 |
D:41 |
R:121 |
|
0:106 |
|
.:76 |
|
Sound Control
SWI |
Name |
Description |
Entry |
Exit |
&40140
|
Sound_Configure |
Configure
Sound |
R0
= channels (1,2,4,8)
R1 = sample length (bytes per channel, default 208)
R2 = sample period (in MUs per channel, default 48)
R3 = pointer to Channel Handler (0=preserve system Handler)
R4 = pointer to Scheduler (0=preserve system Scheduler) |
R0
- R4 = previous values |
&40141 |
Sound_Enable |
Sound
On/Off |
R0
= new state (0= nochange/read state, 1=Off 2=On) |
R0
= previous state (1=Off, 2=On) |
&40142 |
Sound_Stereo |
Set
panning position |
R0
= channel
R1 = position (0=Center, 127=Right -127=Left -128=ReadState) |
R0
= unchanged
R1 = previous position |
&40143 |
Sound_Speaker |
Speaer
On/Off |
R0
= new state (0=readstate 1=Off, 2=On) |
R0
= previous state (1=Off 2=On) |
&40180 |
Sound_Volume |
Set
Volume |
R0
= sound volume (1 - 127) (0 to inspect last setting) |
R0
= previous volume |
&40181 |
Sound_SoundLog |
Convert
signed int to logarithm
scaled by volume |
R0
= 32-bit signed integer |
R0
= 8-bit signed volume-scaled logarithm |
&40182 |
Sound_LogScale |
Scale
signed logarithm by
current Volume |
R0
= 8-bit signed logarithm |
R0
= 8-bit signed volume-scaled logarithm |
&40183 |
Sound_InstallVoice |
Install
a Voice |
R0
= pointer to Voice Generator
R1 = voice slot (0=Next free slot / 1 - 32) |
R0
= pointer to name of previous voice
R1 = voice number allocated / 0 if failed |
&40183 |
Sound_InstallVoice
0 |
Read
Voice name |
R0
= 0
R1 = voice slot |
R0
= pointer to name of installed voice
R1 = Unchanged |
&40183 |
Sound_InstallVoice
1 |
Add
a voice (name in local language) |
R0
= 1
R1 = voice slot (0=Next free slot / 1 - 32)
R2 = pointer to Voice Generator
R3 = pointer to voice name in local language, or 0 if no local
name |
R0
preserved
R1 = voice number allocated, 0=failed
R2 = pointer to name of previous voice
R3 preserved |
&40183 |
Sound_InstallVoice
2 |
Read
name of voice from slot |
R0
= 2
R1 = voice slot |
R0,
R1 = Unchanged
R2 = pointer to name of installed voice
R3 = pointer to name of installed voice in local language |
&40183 |
Sound_InstallVoice
3 |
Change
the local name of a voice |
R0
= 3, R1 = voice slot , R2 = 0
R3 = pointer to new voice name in local language |
R0
- R3 = Unchanged |
&40184 |
Sound_RemoveVoice |
Remove
a voice |
R1
= voice slot to remove (1 - 32) |
R0
= pointer to name of previous voice (or error message)
R1 = voice number removed (0=fail) |
&40185 |
Sound_AttachVoice |
Channel
number |
R0
= channel number (1 - 8)
R1 = voice slot to attach (0 = Detatch and mute) |
R0
= Unchanged
R1 = previous voice number (0=none) |
&40186 |
Sound_ControlPacked |
Make
an immediate sound |
R0
is AAAACCCC Amp/Channel
R1 is DDDDPPPP Duration/Pitch |
R0,R1
= Unchanged |
&40187 |
Sound_Tuning |
Set
Tuning
|
R0
= new tuning value (0 = no change) |
R0
= previous tuning value |
&40188 |
Sound_Pitch |
Convert
pitch to internal format
(phase accumulator value) |
R0
= 15-bit pitch value %-OOOFFFFFFFFFFFF O=Octive F=Fraction (units
of 1/4096 octive) |
R0
= 32-bit phase accumulator value / unchanged if R0 >= &8000
|
&40189 |
Sound_Control |
Make
an immediate sound |
R0
= channel number (1 - 8)
R1 = amplitude:
&FFF1 - &FFFF / &0000 = BBC emulation amplitude (0 to
-15)
&0001 - &000F = BBC envelope not emulated
&0100 - &01FF = full amplitude/gate control %1GSAAAAAA
G=Gate On/Off S=Smooth Gate A=Amplitude
R2 = pitch
&0000 - &00FF = BBC emulation pitch
&0100 - &7FFF = enhanced pitch control: %-OOOFFFFFFFFFFFF
O=Octave F=Fractional (&4000=Middle C)
&8000+n = 'n' (n=0-&7FFF) is phase accumulator increment
R3 = duration
&0001-&00FE = BBC emulation in 5 centisecond periods
&00FF = BBC emulation 'infinite' time (converted to
&F0000000)
>&00FF = duration in 5 centisecond periods. |
R0
- R3 = Unchanged |
&4018A |
Sound_AttachNamedVoice |
Attach
a voice |
R0
= channel number (1 - 8)
R1 = pointer to voice name (0 terminated ASCII string) |
R0
= Unchanged / 0 = fail
R1 = Unchanged |
&4018B |
Sound_ReadControlBlock |
Read
control block |
R0
= channel number (1 - 8)
R1 = offset to read from (0 - 255) |
R0
= Unchanged / 0 = fail , R1 = Unchanged
R2 = 32-bit word read (if R0!=0) |
&4018C |
Sound_WriteControlBlock |
Write
a value to sound control block |
R0
= channel number (1 - 8)
R1 = offset to write to (0 - 255)
R2 = 32-bit word to write |
R0
= Unchanged / 0= fail
R1 = Unchanged
R2 = previous 32-bit word |
&401C0 |
Sound_QInit |
Init
Schedule |
None |
R0
= 0, indicating success |
&401C1 |
Sound_QSchedule |
Schedule
Sound SWI event |
R0
= schedule period (-1 = synchronise with the previously scheduled
event / -2 = immediate scheduling)
R1 = 0 = schedule a Sound_ControlPacked call, or SWI code to
schedule (of the form &xF000000 + SWI number)
R2 = SWI parameter to be passed in R0
R3 = SWI parameter to be passed in R1 |
R0
= 0 for successfully queued
R0 < 0 for failure (queue full)
|
&401C2 |
Sound_QRemove |
- |
Do not use |
Do not use |
&401C3 |
Sound_QFree |
Returns
number of free slots
in event queue |
none |
R0
= number of guaranteed slots free
R0 < 0 = over worst case limit, may still be free slots |
&401C4 |
Sound_QSDispatch |
- |
Do not use |
Do not use |
&401C5 |
Sound_QTempo |
Sets
tempo |
R0
= new tempo (0 = no change) |
R0
= previous tempo value |
&401C6 |
Sound_QBeat |
Set/Read
BeatCounter/BarLength |
R0
= 0 = BeatNumber / R0 = -1 = BarLength
R0 < -1 = Disable BeatCounter & set BarLength=0
R0 = +N = enable beat counter with bar length N (0 to N-1) |
R0
= Current BeatNum (if R0 = 0 on entry) else previous BarLength
|
&401C7 |
Sound_QInterface |
- |
Do not use |
Do not use |
File Formats
RiscOS file extensions use a 3 character type, preceded by a COMMA, not a
full stop, eg "prog,ff8" (PROG COMMA FF8)
Category |
EXT |
Type |
|
General |
FFF |
Plain ASCII
text |
Text |
|
FFE |
Command
(Exec) file |
Command |
|
FFD |
Data |
Data |
|
FFC |
Position
independent code |
Utility |
|
FFB |
Tokenised
BASIC program |
BASIC |
|
FFA |
Relocatable
module |
Module |
|
FF9 |
Sprite or
saved screen |
Sprite |
|
FF8 |
Absolute
application loaded at &8000 |
Absolute |
|
FF7 |
BBC font file
(sequence of VDU operations) |
BBC font |
|
FF6 |
Font |
Font |
|
FF5 |
PostScript |
PoScript |
|
FF4 |
Dot Matrix
data file |
Printout |
|
FF3 |
LaserJet data
file |
LaserJet |
|
FF2 |
Configuration
(CMOS RAM) |
Config |
|
FF1 |
Raw
unprocessed data (e.g. terminal streams) |
RawData |
|
FF0 |
Tagged Image
File Format |
TIFF |
|
FED |
Palette data |
Palette |
|
FEC |
Template file |
Template |
|
FEB |
Obey file |
Obey |
|
FEA |
Desktop |
Desktop |
|
FE9 |
ViewWord |
ViewWord |
|
FE8 |
ViewPS |
ViewPS |
|
FE7 |
ViewSheet |
ViewSht |
|
FE6 |
UNIX
executable |
UNIX Ex |
|
FE4 |
DOS file |
DOS |
|
FE3 |
Atari file |
Atari |
|
FE2 |
Commodore
Amiga file |
Amiga |
|
FE1 |
Make data |
Make |
|
FDF |
TCP/IP suite |
VT220 script |
|
FDE |
TCP/IP suite |
VT220 setup |
|
FDD |
Master
utilities |
MasterUtl |
|
FDC |
TCP/IP suite |
unresolvable
UNIX soft link |
|
FDB |
Text using CR
and LF for line ends |
TextCRLF |
|
FDA |
PC Emulator |
DOS batch
file |
|
FD9 |
PC Emulator |
DOS
executable file |
|
FD8 |
PC Emulator |
DOS command
file |
|
FD7 |
Obey file in
a task window |
TaskObey |
|
FD6 |
Exec file in
a task window |
TaskExec |
|
FD5 |
DOS Pict |
Pict |
|
FD4 |
International
MIDI Assoc. MIDIfiles standard |
MIDI |
|
FD3 |
Acorn DDE |
debuggable
image |
|
FD1 |
BASIC stored
as text |
BASICTxt |
|
FD0 |
PC Emulator |
configuration |
|
FCF |
Font cache |
Cache |
|
FCE |
FileCore
floppy disc image FileCoreFloppyDisc |
|
|
FCD |
FileCore hard
disc image |
FileCoreHardDisc |
|
FCC |
Device object
within DeviceFS |
Device |
|
FCA |
Single
compressed file |
Squash |
|
FC9 |
Sun raster
file |
SunRastr |
|
FC8 |
DOS MultiFS
disc image |
DOSDisc |
Industry
standard file types |
DFE |
Comma
separated values |
CSV |
|
DEA |
Data exchange
format (AutoCAD etc) |
DXF |
|
DB4 |
SuperCalc III
file |
SuperCalc |
|
DB3 |
DBase III
file |
DBaseIII |
|
DB2 |
DBase II |
DBaseII |
|
DB1 |
DBase index
file |
DBaseIndex |
|
DB0 |
Lotus 123
file |
WK1 (was
Lotus123) |
|
CE5 |
TEX file |
TeX |
|
CAF |
IGES graphics |
IGES |
|
CAE |
Hewlett-Packard
graphics language |
HPGLPlot |
|
C85 |
JPEG (Joint
Photographic Experts Group) file |
JPEG |
Acorn
Advance file types |
C25 |
Acorn Advance
Wordprocessor |
AWord |
|
C26 |
Acorn Advance
Spreadsheet |
ASheet |
|
C27 |
Acorn Advance
Database |
ADBase |
|
C28 |
Acorn Advance
Graph |
AGraph |
BBC ROM
file type |
BBC |
BBC ROM file
(ROMFS) |
BBC ROM |
|
|
|
|
|
|
|
|
Acornsoft
file types |
AFF |
Draw file |
DrawFile |
|
AFE |
Mouse event
record |
Mouse |
|
AFA |
DTP style
file |
DtpStyle |
|
AF9 |
DTP documents |
DtpDoc |
|
AF8 |
First Word
Plus file |
1stWord+ |
|
AF7 |
Help file |
HelpInfo |
|
AF1 |
Maestro file |
Music |
|
AF0 |
ArcWriter
file |
ARCWriter |
|
AE9 |
Alarm file |
Alarms |
|
ADB |
Outline font
(obsolete file type) |
New Font |
BASIC commands
RiscOS has a built in BBC Basic interpreter, which is also capable of
assembly!
Category |
Basic Command |
Assembly language |
CALL, SYS, USR |
Character/string handling |
ASC, CHR$, INSTR(, LEFT$(, LEN, MID$(, RIGHT$(, STR$,
STRING$( |
Error handling |
ERL, ERR, ERROR, LOCAL ERROR, ON ERROR, REPORT,
REPORT$, RESTORE ERROR |
File commands |
BGET#, BPUT#, CLOSE#, EOF#, EXT#, GET$#, INPUT#,
OPENIN, OPENOUT, OPENUP, PRINT#, PTR# |
Graphics |
BY, CIRCLE, CLG, CLS, COLOUR (COLOR), DRAW, ELLIPSE,
FILL, GCOL, LINE, MODE, MOVE, OFF, ON, ORIGIN, PLOT, POINT, POINT(,
RECTANGLE, TINT, VDU, WAIT |
Input/Output |
GET, GET$, INKEY, INKEY$, INPUT, INPUT LINE, LINE
INPUT, MOUSE, PRINT, SPC, TAB, WIDTH |
Logical |
AND, EOR, FALSE, NOT, OR, TRUE |
Numerical |
ABS, DIV, EVAL, INT, MOD, RND, SGN, SQR, SUM, SUMLEN,
SWAP, VAL |
Program construction |
APPEND, AUTO, *BASIC, *BASIC64, CRUNCH, DELETE, EDIT,
HELP, INSTALL, LIST, LISTO, LOAD, LVAR, NEW, OLD, RENUMBER, SAVE,
TEXTLOAD, TEXTSAVE, TWIN |
Program statements |
CHAIN, CLEAR, DATA, DEF, DIM, END, ENDPROC, FN,
GOSUB, GOTO, LET, LIBRARY, LOCAL, OSCLI, PROC, QUIT, READ, REM,
RESTORE, RETURN, RUN, STOP, TRACE |
Sound |
BEAT, BEATS, SOUND, STEREO, TEMPO, VOICES |
Structures |
CASE, ELSE, ENDCASE, ENDIF, ENDWHILE, FOR, IF, NEXT,
OF, OTHERWISE, REPEAT, THEN, UNTIL, WHEN, WHILE |
Trigonometric |
ACS, ASN, ATN, COS, DEG, EXP, LN, LOG, PI, RAD, SIN,
TAN |
Variables |
ADVAL, COUNT, HIMEM, LOMEM, PAGE, POS, TIME, TIME$,
TOP, VPOS |
| |
Buy my Assembly programming book on Amazon in Print or Kindle!
Available worldwide! Search 'ChibiAkumas' on your local Amazon website!
Click here for more info!
|