SPC Guide
SPC Guide
Version 0.9.5
Contents
2 Introduction 1
4.2 DigitalIn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
4.3 DigitalOut . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
4.4 DigitalControl . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
4.5 StrobeControl . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
4.6 Timer0/1/2/3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
4.7 SerialInCount . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
4.8 SerialInByte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
4.9 SerialOutCount . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
4.10 SerialOutByte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
4.11 DAC0Mode/DAC1Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
4.12 DAC0Frequency/DAC1Frequency . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
4.13 DAC0Voltage/DAC1Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
4.14 LEDControl . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
4.15 SystemClock . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
4.16 Shared Memory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
5 Module Documentation 30
5.1 Miscellaneous SPC constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
5.1.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
5.1.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
5.2 Pre-defined System constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
5.2.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
5.2.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
5.3 Pre-defined shared memory constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
5.3.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
5.3.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
5.4 SuperPro analog output mode constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
5.4.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
5.4.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
5.5 SuperPro LED control constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
5.5.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
5.5.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
5.6 SuperPro digital pin constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
5.6.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
5.6.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
5.7 SuperPro Strobe control constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
5.7.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
6 File Documentation 78
6.1 SPCAPIDocs.h File Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
6.1.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
6.2 SPCDefs.h File Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
6.2.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
6.2.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
6.2.3 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
6.3 spmem.h File Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108
6.3.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109
6.3.2 Macro Definition Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109
Index 131
by John Hansen
Introduction
2 Introduction
SPC implementation (such as the command-line compiler or Bricx Command Center). Refer to the documentation
provided with the SPC tool, such as the SPC User Manual, for information specific to that implementation.
For up-to-date information and documentation for SPC, visit the SPC website at http://bricxcc.-
sourceforge.net/spc/.
Lexical Rules
Program Structure
Statements
Expressions
The Preprocessor
The lexical rules describe how SPC breaks a source file into individual tokens.
This includes the way comments are written, the handling of whitespace, and valid characters for identifiers.
Comments
Whitespace
Numerical Constants
String Constants
Character Constants
System Constants
3.1.1 Comments
/* this is a comment */
/* this is a two
line comment */
/* another comment...
/* trying to nest...
ending the inner comment...*/
this text is no longer a comment! */
The second form of comments supported in SPC begins with // and continues to the end of the current line. These are
sometimes known as C++ style comments.
As you might guess, the compiler ignores comments. Their only purpose is to allow the programmer to document the
source code.
3.1.2 Whitespace
x=2;
x = 2 ;
Some of the C++ operators consist of multiple characters. In order to preserve these tokens, whitespace cannot appear
within them. In the example below, the first line uses a right shift operator (>>), but in the second line the added space
causes the > symbols to be interpreted as two separate tokens and thus results in a compiler error.
x = 10; // set x to 10
x = 0x10; // set x to 16 (10 hex)
f = 10.5; // set f to 10.5
String constants in SPC, just as in C, are delimited with double quote characters.
String constants can only be used in a few API functions that require a const char input parameter.
puts("testing\n");
printf("testing %d\n", value);
Character constants in SPC are delimited with single quote characters and may contain a single ASCII character.
The value of a character constant is the numeric ASCII value of the character.
char ch = a; // ch == 97
In SPC you can define special system memory address constants that are treated like a variable with an absolute
memory address.
A system address is simply a numeric constant preceded by the @ symbol.
int volt = @0x00; // read the voltage from analog input A0.
@0x0C = 1000; // set countdown timer 0 to 1000.
System constants can also be used to read and write to an area of shared memory that can be accessed via I2C from a
device such as the NXT. The shared memory area from 0x20 - 0x3F is mapped to the byte addressed I2C 0x80 - 0xFF
memory address range. This permits data to be exchanged between an attached NXT and the user program. See the
Shared Memory page for predefined constants to use this area of memory.
Identifiers are used for variable, task, function, and subroutine names.
The first character of an identifier must be an upper or lower case letter or the underscore (_). Remaining characters
may be letters, numbers, and underscores.
A number of tokens are reserved for use in the SPC language itself. These are called keywords and may not be used
as identifiers. A complete list of keywords appears below:
bool
char
const
The do statement
enum
The if statement
int
long
static
Structures
Tasks
typedef
3.1.7.1 const
The const keyword is used to alter a variable declaration so that the variable cannot have its value changed after it is
initialized.
The initialization must occur at the point of the variable declaration.
3.1.7.2 enum
The enumerated type consists of the elements in name-list. The var-list argument is optional, and can be used to create
instances of the type along with the declaration. For example, the following code creates an enumerated type for colors:
In the above example, the effect of the enumeration is to introduce several new constants named red, orange, yellow,
etc. By default, these constants are assigned consecutive integer values starting at zero. You can change the values of
those constants, as shown by the next example:
In the above example, green has a value of 16. Once you have defined an enumerated type you can use it to declare
variables just like you use any native type. Here are a few examples of using the enum keyword:
Days tomorrow;
task main()
{
TheSeasons test = FALL;
today = monday;
tomorrow = today+1;
printf("%d\n", THREE);
printf("%d\n", MEDIUM);
printf("%d\n", FRED);
printf("%d\n", SPRING);
printf("%d\n", friday);
printf("%d\n", today);
printf("%d\n", test);
printf("%d\n", tomorrow);
Wait(SEC_5);
}
3.1.7.3 static
The static keyword is used to alter a variable declaration so that the variable is allocated statically - the lifetime of the
variable extends across the entire run of the program - while having the same scope as variables declared without the
static keyword.
Note that the initialization of automatic and static variables is quite different. Automatic variables (local variables are
automatic by default, unless you explicitly use static keyword) are initialized during the run-time, so the initialization will
be executed whenever it is encountered in the program. Static (and global) variables are initialized during the compile-
time, so the initial values will simply be embeded in the executable file itself.
void func() {
static int x = 0; // x is initialized only once across three calls of func()
NumOut(0, LCD_LINE1, x); // outputs the value of x
x = x + 1;
}
task main() {
func(); // prints 0
func(); // prints 1
func(); // prints 2
}
3.1.7.4 typedef
A typedef declaration introduces a name that, within its scope, becomes a synonym for the type given by the type-
declaration portion of the declaration.
You can use typedef declarations to construct shorter or more meaningful names for types already defined by the
language or for types that you have declared. Typedef names allow you to encapsulate implementation details that may
change.
A typedef declaration does not introduce a new type - it introduces a new name for an existing type. Here are a few
examples of how to use the typedef keyword:
Code Order
Tasks
Functions
Variables
Structures
Arrays
Code order has two aspects: the order in which the code appears in the source code file and the order in which it is
executed at runtime.
The first will be referred to as the lexical order and the second as the runtime order.
The lexical order is important to the SPC compiler, but not to the SuperPro brick. This means that the order in which
you write your task and function definitions has no effect on the runtime order. The rules controlling runtime order are:
1. There must be a task called main and this task will always run first.
2. The time at which any other task will run is determined by the placement of API functions and keywords that start
other tasks.
This last rule may seem trivial, but it has important consequences when multiple tasks are running. If a task calls a
function that is already in the midst of running because it was called first by another task, unpredictable behavior and
results may ensue. Tasks can share functions by treating them as shared resources and using code to prevent one task
from calling the function while another task is using it.
The rules for lexical ordering are:
1. Any identifier naming a task or function must be known to the compiler before it is used in a code block.
2. A task or function definition makes its naming identifier known to the compiler.
3. A task or function declaration also makes a naming identifier known to the compiler.
Sometimes you will run into situations where is impossible or inconvenient to order the task and function definitions so
the compiler knows every task or function name before it sees that name used in a code block. You can work around
this by inserting task or function declarations of the form
task name();
return_type name(argument_list);
before the code block where the first usage occurs. The argument_list must match the list of formal arguments
given later in the functions actual definition.
3.2.2 Tasks
Since the SuperPro supports multi-threading, a task in SPC directly corresponds to a SuperPro thread or process.
Tasks are defined using the task keyword with the syntax shown in the code sample below.
task name()
{
// the tasks code is placed here
}
The name of the task may be any legal identifier. A program must always have at least one task - named "main" - which
is started whenever the program is run. The body of a task consists of a list of statements.
You can start tasks with the start statement, which is discussed below.
The StopAllTasks API function stops all currently running tasks. You can also stop all tasks using the Stop function. A
task can stop itself via the ExitTo function. Finally, a task will stop itself simply by reaching the end of its body.
3.2.3 Functions
It is often helpful to group a set of statements together into a single function, which your code can then call as needed.
SPC supports functions with arguments and return values. Functions are defined using the syntax below.
The return type is the type of data returned. In the C programming language, functions must specify the type of data
they return. Functions that do not return data simply return void.
Additional details about the keywords inline, and void can be found below.
The argument list of a function may be empty, or may contain one or more argument definitions. An argument is defined
by a type followed by a name. Commas separate multiple arguments. All values are represented as bool, char, int, long,
struct types, or arrays of any type.
SPC supports specifying a default value for function arguments that are not struct or array types. Simply add an equal
sign followed by the default value. Specifying a default value makes the argument optional when you call the function.
All optional arguments must be at the end of the argument list.
task main()
{
printf("%d\n", foo(10)); outputs 200
printf("%d\n", foo(10, 5)); outputs 50
Wait(SEC_10); // wait 10 seconds
}
SPC also supports passing arguments by value, by constant value, by reference, and by constant reference. These four
modes for passing parameters into a function are discussed below.
When arguments are passed by value from the calling function or task to the called function the compiler must allocate
a temporary variable to hold the argument. There are no restrictions on the type of value that may be used. However,
since the function is working with a copy of the actual argument, the caller will not see any changes the called function
makes to the value. In the example below, the function foo attempts to set the value of its argument to 2. This is perfectly
legal, but since foo is working on a copy of the original argument, the variable y from the main task remains unchanged.
void foo(int x)
{
x = 2;
}
task main()
{
int y = 1; // y is now equal to 1
foo(y); // y is still equal to 1!
}
The second type of argument, const arg_type, is also passed by value. If the function is an inline function then arguments
of this kind can sometimes be treated by the compiler as true constant values and can be evaluated at compile-time. If
the function is not inline then the compiler treats the argument as if it were a constant reference, allowing you to pass
either constants or variables. Being able to fully evaluate function arguments at compile-time can be important since
some SPC API functions only work with true constant arguments.
task main()
{
int x = 5;
foo(5); // ok
foo(4*5); // expression is still constant
foo(x); // x is not a constant but is okay
}
The third type, arg_type &, passes arguments by reference rather than by value. This allows the called function to
modify the value and have those changes be available in the calling function after the called function returns. However,
only variables may be used when calling a function using arg_type & arguments:
task main()
{
int y = 1; // y is equal to 1
The fourth type, const arg_type &, is interesting. It is also passed by reference, but with the restriction that the called
function is not allowed to modify the value. Because of this restriction, the compiler is able to pass anything, not just
variables, to functions using this type of argument. Currently, passing an argument by reference in SPC is not as optimal
as it is in C. A copy of the argument is still made but the compiler will enforce the restriction that the value may not be
modified inside the called function.
Functions must be invoked with the correct number and type of arguments. The code example below shows several
different legal and illegal calls to function foo.
task main()
{
int x; // declare variable x
foo(1, 2); // ok
foo(x, 2); // ok
foo(2); // error - wrong number of arguments!
}
task main()
{
foo(MS_100);
foo(MS_10);
foo(SEC_1);
foo(MS_50);
}
In this case task main will contain 4 Wait calls rather than 4 calls to the foo subroutine since it was expanded inline.
The void keyword allows you to define a function that returns no data.
Functions that do not return any value are sometimes referred to as procedures or subroutines. The sub keyword is an
alias for void. Both of these keywords can only be used when declaring or defining a function. Unlike C you cannot use
void when declaring a variable type.
In NQC the void keyword was used to declare inline functions that could have arguments but could not return a value.
In SPC void functions are not automatically inline as they were in NQC. To make a function inline you have to use the
inline keyword prior to the function return type as described in the Functions section above.
The sub keyword allows you to define a function that returns no data.
Functions that do not return any value are sometimes referred to as procedures or subroutines. The sub keyword is an
alias for void. Both of these keywords can only be used when declaring or defining a function.
In NQC you used this keyword to define a true subroutine which could have no arguments and return no value. For the
sake of C compatibility it is preferrable to use the void keyword if you want to define a function that does not return a
value.
3.2.4 Variables
All variables in SPC are defined using one of the types listed below:
bool
char
int
long
Structures
Arrays
Variables are declared using the keyword(s) for the desired type, followed by a comma-separated list of variable names
and terminated by a semicolon (;). Optionally, an initial value for each variable may be specified using an equals sign
(=) after the variable name. Several examples appear below:
int x; // declare x
bool y,z; // declare y and z
long a=1,b; // declare a and b, initialize a to 1
int data[10]; // an array of 10 zeros in data
bool flags[] = {true, true, false, false};
Global variables are declared at the program scope (outside of any code block). Once declared, they may be used
within all tasks, functions, and subroutines. Their scope begins at declaration and ends at the end of the program.
Local variables may be declared within tasks and functions. Such variables are only accessible within the code block in
which they are defined. Specifically, their scope begins with their declaration and ends at the end of their code block. In
the case of local variables, a compound statement (a group of statements bracketed by { and }) is considered a block:
int x; // x is global
task main()
{
int y; // y is local to task main
x = y; // ok
{ // begin compound statement
int z; // local z declared
y = z; // ok
}
y = z; // error - z no longer in scope
}
task foo()
{
x = 1; // ok
y = 2; // error - y is not global
}
3.2.4.1 bool
bool flag=true;
3.2.4.2 char
char ch=12;
char test = A;
3.2.4.3 int
int x = 0xfff;
int y = -23;
3.2.4.4 long
long x = 2147000000;
long y = -88235;
3.2.5 Structures
struct car
{
int car_type;
int manu_year;
};
struct person
{
int age;
car vehicle;
};
person myPerson;
After you have defined the structure type you can use the new type to declare a variable or nested within another
structure type declaration. Members (or fields) within the struct are accessed using a dot notation.
myPerson.age = 40;
anotherPerson = myPerson;
fooBar.car_type = honda;
fooBar.manu_year = anotherPerson.age;
You can assign structs of the same type but the compiler will complain if the types do not match.
3.2.6 Arrays
To declare arrays with more than one dimension simply add more pairs of square brackets. The maximum number of
dimensions supported in SPC is 4.
Arrays of up to two dimensions may be initialized at the point of declaration using the following syntax:
The elements of an array are identified by their position within the array (called an index). The first element has an index
of 0, the second has index 1, and so on. For example:
SPC also supports specifying an initial size for both global and local arrays. The compiler automatically generates the
required code to correctly initialize the array to zeros. If an array declaration includes both a size and a set of initial
values the size is ignored in favor of the specified values.
task main()
{
int myArray[10][10];
int myVector[10];
3.3 Statements
Variable Declaration
Assignment
Control Structures
Variable declaration, which has already been discussed, is one type of statement.
Its purpose is to declare a local variable (with optional initialization) for use within the code block. The syntax for a
variable declaration is shown below.
arg_type variables;
Here arg_type must be one of the types supported by SPC. Following the type are variable names, which must be a
comma-separated list of identifiers with optional initial values as shown in the code fragment below.
name[=expression]
int array[n][=initializer];
You can also define variables using user-defined aggregate structure types.
struct TPerson {
int age;
string name;
};
TPerson bob; // cannot be initialized at declaration
3.3.2 Assignment
Once declared, variables may be assigned the value of an expression using the syntax shown in the code sample below.
There are eleven different assignment operators. The most basic operator, =, simply assigns the value of the expression
to the variable. The other operators modify the variables value in some other way as shown in the table below.
Operator Action
= Set variable to expression
+= Add expression to variable
-= Subtract expression from variable
= Multiple variable by expression
/= Divide variable by expression
Operators
The code sample below shows a few of the different types of operators that you can use in SPC expressions.
x = 2; // set x to 2
y = 7; // set y to 7
x += y; // x is 9, y is still 7
The if statement
The do statement
{
x = 1;
y = 2;
}
Although this may not seem very significant, it plays a crucial role in building more complicated control structures. Many
control structures expect a single statement as their body. By using a compound statement, the same control structure
can be used to control multiple statements.
if (condition) consequence
The condition of an if-statement must be enclosed in parentheses, as shown in the code sample below. The compound
statement in the last example allows two statements to execute as a consequence of the condition being true.
if (x==1) y = 2;
if (x==1) { y = 1; z = 2; }
The condition of an if-statement must be enclosed in parentheses, as shown in the code sample below. The compound
statement in the last example allows two statements to execute as a consequence of the condition being true as well as
two which execute when the condition is false.
if (x==1)
y = 3;
else
y = 4;
if (x==1) {
y = 1;
z = 2;
}
else {
y = 3;
z = 5;
}
Because the body of a while statement must be a single statement, it is very common to use a compound statement as
the body. The sample below illustrates this usage pattern.
The difference between a while loop and a do-while loop is that the do-while loop always executes the body at least
once, whereas the while loop may not execute it at all.
do
{
x = x+1;
y = y*2;
} while(x < 10);
A for loop always executes statement1, and then it repeatedly checks the condition. While the condition remains true, it
executes the body followed by statement2. The for loop is equivalent to the code shown below.
statement1;
while(condition)
{
body
statement2;
}
Frequently, statement1 sets a loop counter variable to its starting value. The condition is generally a relational statement
that checks the counter variable against a termination value, and statement2 increments or decrements the counter
value.
Here is an example of how to use the for loop:
The expression determines how many times the body will be executed. Note: the expression following the repeat
keyword is evaluated a single time and then the body is repeated that number of times. This is different from both the
while and do-while loops which evaluate their condition each time through the loop.
Here is an example of how to use the repeat loop:
int i=0;
repeat (8)
{
printf("%d\n", i++);
}
A switch statement executes one of several different code sections depending on the value of an expression.
One or more case labels precede each code section. Each case must be a constant and unique within the switch
statement. The switch statement evaluates the expression, and then looks for a matching case label. It will execute
any statements following the matching case until either a break statement or the end of the switch is reached. A single
default label may also be used - it will match any value not already appearing in a case label. A switch statement uses
the syntax shown below.
Additional information about the case and default labels and the break statement can be found below.
switch(x)
{
case 1:
// do something when x is 1
break;
case 2:
case 3:
// do something else when x is 2 or 3
break;
default:
// do this when x is not 1, 2, or 3
break;
}
case constant_expression :
The switch statement page contains an example of how to use the case label.
default :
The switch statement page contains an example of how to use the default label.
my_loop:
x++;
goto my_loop;
The goto statement should be used sparingly and cautiously. In almost every case, control structures such as if, while,
and switch make a program much more readable and maintainable than using goto.
In other words, until will continue looping until the condition becomes true. It is most often used in conjunction with an
empty body statement or a body which simply yields to other tasks:
The asm statement is used to define many of the SPC API calls.
The syntax of the statement is shown below.
asm {
one or more lines of SPRO assembly language
}
The statement simply emits the body of the statement as SuperPro ASM code and passes it directly to the compilers
backend. The asm statement can often be used to optimize code so that it executes as fast as possible on the SuperPro
firmware. The following example shows an asm block containing variable declarations, labels, and basic SPRO ASM
statements as well as comments.
asm {
MVI WORK2, 12
MOV PTR, WORK2
MOV (PTR), WORK1
INC PTR
}
The asm block statement and these special ASM keywords are used throughout the SPC API. You can have a look
at the SPCDefs.h header file for several examples of how they are used. To keep the main SPC code as "C-like" as
possible and for the sake of better readability SPC asm block statements can be wrapped in preprocessor macros and
placed in custom header files which are included using #include.
Many expressions are not legal statements. A notable exception are expressions using increment (++) or decrement ()
operators.
x++;
name(arguments);
The arguments list is a comma-separated list of expressions. The number and type of arguments supplied must match
the definition of the function itself. Optionally, the return value may be assigned to a variable.
start task_name;
Within loops (such as a while loop) you can use the break statement to exit the loop immediately.
It only exits out of the innermost loop
break;
The break statement is also a critical component of most switch statements. It prevents code in subsequent code
sections from being executed, which is usually a programmers intent, by immediately exiting the switch statement.
Missing break statements in a switch are a frequent source of hard-to-find bugs.
Here is an example of how to use the break statement:
while (x<100) {
x = get_new_x();
if (button_pressed())
break;
process(x);
}
Within loops you can use the continue statement to skip to the top of the next iteration of the loop without executing any
of the code in the loop that follows the continue statement.
continue;
while (x<100) {
ch = get_char();
if (ch != s)
continue;
process(ch);
}
If you want a function to return a value or to return before it reaches the end of its code, use a return statement.
An expression may optionally follow the return keyword and, when present, is the value returned by the function. The
type of the expression must be compatible with the return type of the function.
return [expression];
3.4 Expressions
Expression Operators
x = 2 + 3 * 4; // set x to 14
y = (2 + 3) * 4; // set y to 20
Conditions
3.4.1 Conditions
Condition Meaning
Expr true if expr is not equal to 0
Expr1 == expr2 true if expr1 equals expr2
Expr1 != expr2 true if expr1 is not equal to expr2
Expr1 < expr2 true if one expr1 is less than expr2
Expr1 <= expr2 true if expr1 is less than or equal to expr2
Expr1 > expr2 true if expr1 is greater than expr2
Expr1 >= expr2 true if expr1 is greater than or equal to expr2
! condition logical negation of a condition - true if condition is false
Cond1 && cond2 logical AND of two conditions (true if and only if both
conditions are true)
Cond1 || cond2 logical OR of two conditions (true if and only if at least
one of the conditions are true)
Conditions
There are also two special constant conditions which can be used anywhere that the above conditions are allowed.
They are listed below.
You can use conditions in SPC control structures, such as the if-statement and the while or until statements, to specify
exactly how you want your program to behave.
SPC also includes a preprocessor that is modeled after the Standard C preprocessor.
The C preprocessor processes a source code file before the compiler does. It handles such tasks as including code from
other files, conditionally including or excluding blocks of code, stripping comments, defining simple and parameterized
macros, and expanding macros wherever they are encountered in the source code.
The SPC preprocessor implements the following standard preprocessor directives: #include, #define, #ifdef, #ifndef,
#endif, #if, #elif, #undef, ##, #line, #error, and #pragma. Its implementation is close to a standard C preprocessors, so
most preprocessor directives should work as C programmers expect in SPC. Any significant deviations are explained
below.
#include
#define
## (Concatenation)
Conditional Compilation
Pragmas
3.5.1 #include
The #include command works as in Standard C, with the caveat that the filename must be enclosed in double quotes.
There is no notion of a system include path, so enclosing a filename in angle brackets is forbidden.
#include "foo.h" // ok
#include <foo.h> // error!
SPC programs can begin with #include "NXCDefs.h" but they dont need to. This standard header file includes many
important constants and macros, which form the core SPC API. SPC no longer require that you manually include the
NXCDefs.h header file. Unless you specifically tell the compiler to ignore the standard system files, this header file is
included automatically.
3.5.2 #define
3.5.3 ## (Concatenation)
Directive Meaning
#ifdef symbol If symbol is defined then compile the following code
#ifndef symbol If symbol is not defined then compile the following code
#else Switch from compiling to not compiling and vice versa
#endif Return to previous compiling state
#if condition If the condition evaluates to true then compile the
following code
#elif Same as #else but used with #if
See the SPCDefs.h header files for many examples of how to use conditional compilation.
3.5.5 Pragmas
The #pragma directive is the method specified by the C standard for providing additional information to the compiler,
beyond what is conveyed in the language itself.
A C compiler is free to attach any meaning it likes to pragmas.
In SuperPro C the only pragma that has any significant meaning is autostart.
#pragma autostart
The autostart instruction tells the compiler to modify the generated executable so that it automatically starts running
whenever the SuperPro is powered on.
Pre-defined system constants for directly interacting with the SuperPro hardware.
The spmem.h header file uses system constants to define names for the I/O mapped memory addresses of the SuperPro
board you are targetting. A complete list of these system constants appears below:
ADChannel0/1/2/3
DigitalIn
DigitalOut
DigitalControl
StrobeControl
Timer0/1/2/3
SerialInCount
SerialInByte
SerialOutCount
SerialOutByte
DAC0Mode/DAC1Mode
DAC0Frequency/DAC1Frequency
DAC0Voltage/DAC1Voltage
LEDControl
SystemClock
Shared Memory
4.1 ADChannel0/1/2/3
These variables return the voltage on pins A0/1/2/3 as a value in the range 0 - 1023.
This range of values represents a voltage range of 0 - 3.3 volts, or 3.222 mV per step.
4.2 DigitalIn
This variable returns the current state of the 8 digital lines, B0 - B7.
This includes the state of any of the lines which are configured as outputs.
4.3 DigitalOut
This variable sets the current state of any of the 8 digital lines, B0 - B7 which are set as outputs.
See SuperPro digital pin constants.
4.4 DigitalControl
This variable defines which of the 8 digital lines, B0 - B7, are set as outputs.
If the corresponding bit in 1, the line is configured as an output, else it will be an input. See SuperPro digital pin
constants.
4.5 StrobeControl
D31-D6 D5 D4 D3 D2 D1 D0
- WR RD S3 S2 S1 S0
Strobe Lines
There are 4 general purpose outputs, S0 - S3. These 4 lines may be used as digital outputs. There are 2 special
purpose outputs, RD and WR. These lines are automatically activated when DigitalIn is read or DigitalOut is written.
When DigitalIn is read, the RD output will pulse for about 10 S. If the StrobeControl RD bit is 0, the RD output will pulse
high, if the bit is 1, the output will pulse low.
The timing for a read. An external device which is relying on the RD strobe output for synchronizing with the SuperPro
hardware may use the leading edge of the RD strobe to present data on B0 - B7. The device must have the data ready
within 9 microseconds of the start (leading edge) of the RD strobe. The timing for a write.
An external device which is relying on the WR strobe output for synchronizing with the SuperPro hardware may use the
leading edge of the WR strobe as either an edge type clock or a latch type due to the data being presented on B0 - B7
at least 1 microsecond before the strobe is active until 1 microsecond after.
In a typical example of using the strobes to use the B0-7 bus bi-directionally:
4.6 Timer0/1/2/3
4.7 SerialInCount
The SerialInCount returns the number of characters waiting in an input FIFO (First In, First Out) buffer of up to 255
entries.
Characters can be transferred from the host PC to the SuperPro via a terminal emulation program running at 115200bps,
8 bits, no parity. A program can wait for a character to become available using this value.
4.8 SerialInByte
The SerialInByte returns the character waiting in the input FIFO receive queue.
A program should wait for a character to become available before performing a read from SerialInByte. The result of
reading from an empty FIFO receive queue is unpredictable.
4.9 SerialOutCount
The SerialOutCount returns the number of characters waiting in an output FIFO send queue of 255 entries.
Characters from the output FIFO are transferred to the host PC at approximately 10,000 per second. If the program is
generating characters at a rate greater than this, the output FIFO will start to fill up. This state can be checked by the
program by comparing the count with SERIAL_BUFFER_SIZE. In the event that this check is not performed, no data
will be lost since the program will stall waiting for space to become available in the FIFO.
4.10 SerialOutByte
4.11 DAC0Mode/DAC1Mode
The DACnMode controls the operation of the analog output pins O0/O1.
The following modes are available for use:
Mode DAC_MODE_DCOUT uses the DACnVoltage to control the output voltage between 0 and 3.3 volts in steps of
3.222 mV.
The waveforms associated with modes DAC_MODE_SINEWAVE, DAC_MODE_SQUAREWAVE, DAC_MODE_SAW-
POSWAVE, DAC_MODE_SAWNEGWAVE, and DAC_MODE_TRIANGLEWAVE are centered around a DC offset of
1.65 volts. The DACnVoltage controls the amplitude from +/- 0 to +/- 1.65 volts.
The waveform associated with mode DAC_MODE_PWMVOLTAGE is a rectangular waveform switching between 0 and
3.3 volts. The DACnVoltage controls the mark to space ratio between 0% and 100%. The average DC value of this
waveform thus varies from 0 to 3.3 volts.
As of firmware version 2.3 the waveform generator has been improved to provide:
Start of waveform generation will start from the beginning of the wave table. When the DAC0/DAC1 Mode bytes
are changed from 0x00 to a non zero number, the waveform generation will start from the start of the wave table.
A frequency value of zero is interpreted as a DC output of 1.65v, the center offset value used for waveform output.
Addition of bit 7 of the DAC0/DAC1 Mode bytes to signify force waveform generation from the beginning of the
wave table. If the Mode byte is written with bit 7 set, i.e., 0x81 for a sine wave, then the wave table pointer will
reset to the start of the table. Once this reset has been performed, the 7 bit will be cleared.
Immediate cessation of waveform generation when the DAC0/DAC1 Mode bytes are set to 0x00. The previous
firmware version would inadvertently insert a 0 - 4mS dead time when the DAC0/DAC1 Mode bytes were changed
to 0x00. The reaction is now a few microseconds instead.
4.12 DAC0Frequency/DAC1Frequency
The DACnFrequency controls the generator frequency for the analog output pins O0/O1 for DACnModes DAC_MODE-
_SINEWAVE, DAC_MODE_SQUAREWAVE, DAC_MODE_SAWPOSWAVE, DAC_MODE_SAWNEGWAVE, DAC_M-
ODE_TRIANGLEWAVE, and DAC_MODE_PWMVOLTAGE.
The available frequency range is 1 - 8000 Hz.
4.13 DAC0Voltage/DAC1Voltage
The DACnVoltage controls the output voltage levels for the analog output pins O0/O1.
DACnMode DAC_MODE_DCOUT uses the DACnVoltage to control the output voltage between 0 and 3.3 volts in steps
of 3.222 mV.
For DACnModes DAC_MODE_SINEWAVE, DAC_MODE_SQUAREWAVE, DAC_MODE_SAWPOSWAVE, DAC_MO-
DE_SAWNEGWAVE, and DAC_MODE_TRIANGLEWAVE, the DACnVoltage controls the amplitude from +/- 0 to +/-
1.65 volts.
For DACnMode DAC_MODE_PWMVOLTAGE, DACnVoltage controls the mark to space ratio between 0% and 100%.
The average DC value of this waveform thus varies from 0 to 3.3 volts.
4.14 LEDControl
The LEDControl location can be used to turn two on-board LEDs on and off.
Bit 0 controls the state of a red LED, while bit 1 controls a blue LED.
4.15 SystemClock
The SystemClock returns the number of milliseconds since power was applied to the SuperPro board.
long x = SystemClock;
There are 32 shared memory locations on the SuperPro board which can be accessed remotely via I2C using a device
like the NXT.
They are named SharedMem01 through SharedMem32. If you write 4 bytes to I2C address 0x80 these bytes can be
read as a signed long value in SuperPro C at address 0x20 (SharedMem01).
long x = SharedMem01;
SharedMem32 = ADChannel0;
5 Module Documentation
Modules
Macros
#define TRUE 1
#define FALSE 0
#define SERIAL_BUFFER_SIZE 255
A false value
A true value
Pre-defined system constants for use in SuperPro C to read or read/write all of the SuperPro hardware capabilities.
Macros
Pre-defined system constants for use in SuperPro C to read or read/write all of the SuperPro hardware capabilities.
Reads the current voltage on A0 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Examples:
Reads the current voltage on A1 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Examples:
Reads the current voltage on A2 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Reads the current voltage on A3 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Examples:
ex_DAC0ToA3.spc.
Examples:
ex_DAC0ToA3.spc.
Control the operation of the DAC0 analog output (O0). See SuperPro analog output mode constants for valid values.
Read/write.
Examples:
ex_DAC0ToA3.spc.
Examples:
ex_DAC0ToA3.spc.
Examples:
Control the operation of the DAC1 analog output (O1). See SuperPro analog output mode constants for valid values.
Read/write.
Examples:
Examples:
Write 8 bits to the digital control port B0 - B7. Set the mode of any of the 8 digital signals. 1 == output, 0 == input.
Examples:
Examples:
Control the operation of the two onboard LDEs (red and blue). See SuperPro LED control constants for valid values.
Read/write.
Examples:
ex_ledcontrol.spc.
Read the next serial byte from the serial port receive queue. Reading this value removes the byte from the receive
queue. Serial port input data is stored in a 255 byte temporary buffer. Read only.
Examples:
ex_digiserial.spc.
Read the count of serial bytes in the receive queue. Enables a user program to check if any data is available to be read
from the serial port. Read only.
Examples:
ex_digiserial.spc.
Write a byte to the serial port send queue. Serial port output data is stored in a 255 byte temporary buffer. Do not write
to this address if SerialCount is 255. Write only.
Examples:
ex_serialout.spc.
Read the count of serial bytes in the send queue. Enables a user program to check how many bytes are waiting to be
sent out the serial port. Read only.
Examples:
ex_serialout.spc.
Write 6 bits to the digital strobe port S0 - WR. Controls the operation of the six strobe outputs (S0, S1, S2, S3, RD, and
WR). See SuperPro Strobe control constants for valid values.
Read the system clock. The system clock counts up continuously at one count per millisecond. Read only.
Examples:
Read/write countdown timer 0. Counts down until it reaches zero (per millisecond).
Examples:
Read/write countdown timer 1. Counts down until it reaches zero (per millisecond).
Examples:
Read/write countdown timer 2. Counts down until it reaches zero (per millisecond).
Examples:
ex_timer.spc.
Read/write countdown timer 3. Counts down until it reaches zero (per millisecond).
Examples:
Pre-defined shared memory constants for use in SuperPro C to read/write addresses in SuperPro memory that are
shared with the I2C address space.
Macros
Pre-defined shared memory constants for use in SuperPro C to read/write addresses in SuperPro memory that are
shared with the I2C address space. This allows for an external device to send data to or receive data from a SuperPro
program while it is executing using the I2C communication layer.
Macros
#define DAC_MODE_DCOUT 0
#define DAC_MODE_SINEWAVE 1
#define DAC_MODE_SQUAREWAVE 2
#define DAC_MODE_SAWPOSWAVE 3
#define DAC_MODE_SAWNEGWAVE 4
#define DAC_MODE_TRIANGLEWAVE 5
#define DAC_MODE_PWMVOLTAGE 6
#define DAC_MODE_RESTART_MASK 0x80
Constants for controlling the 2 analog output modes. Two analog outputs, which can span 0 to 3.3 volts, can be
programmed to output a steady voltage or can be programmed to output a selection of waveforms over a range of
frequencies.
In the DC output mode, the DAC0/DAC1 voltage fields control the voltage on the two analog outputs in increments of
3.2mV from 0 - 1023 giving 0 - 3.3v.
In waveform modes, the channel outputs will center on 1.65 volts when generating waveforms. The DAC0/DAC1 voltage
fields control the signal levels of the waveforms by adjusting the peak to peak signal levels from 0 - 3.3v.
In PWFM voltage mode, the channel outputs will create a variable mark:space ratio square wave at 3.3v signal level.
The average output voltage is set by the O0/O1 voltage fields.
Add mask to DAC mode constants to force waveform generation from the start of the wave table.
Examples:
ex_DAC0ToA3.spc.
Examples:
Macros
Examples:
ex_ledcontrol.spc.
Examples:
ex_ledcontrol.spc.
Macros
Constants for controlling the 8 digital pins. The eight digital inputs are returned as a byte representing the state of the
eight inputs. The eight digital outputs are controlled by two bytes, the first of which sets the state of any of the signals
which have been defined as outputs and the second of which controls the input/output state of each signal.
Macros
Constants for manipulating the six digital strobe outputs. Six digital strobe outputs are available. One is pre-configured
as a read strobe, another is pre-configured as a write strobe while the other four can be set to a high or low logic
level. These strobe lines enable external devices to synchronize with the digital data port and multiplex the eight digital
input/output bits to wider bit widths.
The RD and WR bits set the inactive state of the read and write strobe outputs. Thus, if these bits are set to 0, the
strobe outputs will pulse high.
Macros
#define CHAR_BIT 32
#define LONG_MIN -2147483648
#define SCHAR_MIN -2147483648
#define INT_MIN -2147483648
#define CHAR_MIN -2147483648
#define LONG_MAX 2147483647
#define SCHAR_MAX 2147483647
#define INT_MAX 2147483647
#define CHAR_MAX 2147483647
Macros
#define SLOT1 0
#define SLOT2 1
#define SLOT3 2
#define SLOT4 3
#define SLOT5 4
#define SLOT6 5
#define SLOT7 6
See Also
Run()
Program slot 1.
Program slot 2.
Program slot 3.
Program slot 4.
Program slot 5.
Program slot 6.
Program slot 7.
Macros
#define LOG_STATUS_OPEN 2
#define LOG_STATUS_BUSY 1
#define LOG_STATUS_CLOSED 0
See Also
Run()
Examples:
ex_stat.spc.
Macros
#define MS_1 1
#define MS_2 2
#define MS_3 3
#define MS_4 4
#define MS_5 5
#define MS_6 6
#define MS_7 7
#define MS_8 8
#define MS_9 9
#define MS_10 10
#define MS_20 20
#define MS_30 30
#define MS_40 40
#define MS_50 50
#define MS_60 60
#define MS_70 70
#define MS_80 80
#define MS_90 90
#define MS_100 100
#define MS_150 150
#define MS_200 200
#define MS_250 250
#define MS_300 300
#define MS_350 350
#define MS_400 400
#define MS_450 450
#define MS_500 500
#define MS_600 600
#define MS_700 700
#define MS_800 800
#define MS_900 900
#define SEC_1 1000
#define SEC_2 2000
#define SEC_3 3000
#define SEC_4 4000
#define SEC_5 5000
#define SEC_6 6000
#define SEC_7 7000
#define SEC_8 8000
#define SEC_9 9000
#define SEC_10 10000
#define SEC_15 15000
#define SEC_20 20000
#define SEC_30 30000
See Also
Wait()
1 minute
Examples:
ex_stat.spc.
5.11.2.2 #define MS 1 1
1 millisecond
Examples:
ex_arrays.spc.
5.11.2.3 #define MS 10 10
10 milliseconds
Examples:
ex_DAC0ToA3.spc.
100 milliseconds
Examples:
ex_CurrentTick.spc.
150 milliseconds
5.11.2.6 #define MS 2 2
2 milliseconds
5.11.2.7 #define MS 20 20
20 milliseconds
200 milliseconds
250 milliseconds
5.11.2.10 #define MS 3 3
3 milliseconds
5.11.2.11 #define MS 30 30
30 milliseconds
300 milliseconds
350 milliseconds
5.11.2.14 #define MS 4 4
4 milliseconds
5.11.2.15 #define MS 40 40
40 milliseconds
400 milliseconds
450 milliseconds
5.11.2.18 #define MS 5 5
5 milliseconds
5.11.2.19 #define MS 50 50
50 milliseconds
500 milliseconds
Examples:
5.11.2.21 #define MS 6 6
6 milliseconds
5.11.2.22 #define MS 60 60
60 milliseconds
600 milliseconds
5.11.2.24 #define MS 7 7
7 milliseconds
5.11.2.25 #define MS 70 70
70 milliseconds
700 milliseconds
5.11.2.27 #define MS 8 8
8 milliseconds
5.11.2.28 #define MS 80 80
80 milliseconds
800 milliseconds
5.11.2.30 #define MS 9 9
9 milliseconds
5.11.2.31 #define MS 90 90
90 milliseconds
900 milliseconds
Examples:
Examples:
1 second
Examples:
10 seconds
Examples:
ex_Stop.spc.
15 seconds
Examples:
ex_timer.spc.
2 seconds
Examples:
ex_timer.spc.
20 seconds
3 seconds
Examples:
ex_StartTask.spc.
30 seconds
Examples:
ex_timer.spc.
4 seconds
5 seconds
Examples:
6 seconds
7 seconds
8 seconds
9 seconds
Macros
See Also
DAC0Frequency, DAC1Frequency
Third octave A
Examples:
ex_Twinkle.spc.
Fourth octave A
Examples:
ex_TwinkleL.spc.
Fifth octave A
Sixth octave A
Seventh octave A
Third octave B
Fourth octave B
Fifth octave B
Sixth octave B
Seventh octave B
Third octave C
Examples:
ex_Twinkle.spc.
Fourth octave C
Examples:
ex_TwinkleL.spc.
Fifth octave C
Sixth octave C
Seventh octave C
Third octave D
Examples:
ex_Twinkle.spc.
Fourth octave D
Examples:
ex_TwinkleL.spc.
Fifth octave D
Sixth octave D
Seventh octave D
Third octave E
Examples:
ex_Twinkle.spc.
Fourth octave E
Examples:
ex_TwinkleL.spc.
Fifth octave E
Sixth octave E
Seventh octave E
Third octave F
Examples:
ex_Twinkle.spc.
Fourth octave F
Examples:
ex_TwinkleL.spc.
Fifth octave F
Sixth octave F
Seventh octave F
Third octave G
Examples:
ex_Twinkle.spc.
Fourth octave G
Examples:
ex_TwinkleL.spc.
Fifth octave G
Sixth octave G
Seventh octave G
Functions
Examples:
ex_abort.spc.
Absolute value.
Return the absolute value of the value argument. Any scalar type can be passed into this function.
Parameters
num The numeric value.
Returns
The absolute value of num. The return type matches the input type.
Examples:
ex_abs.spc.
Close file.
Close the log file.
Returns
Examples:
Returns
Examples:
Parameters
newTask The task to start executing after exiting the current task.
Examples:
ex_exitto.spc.
Open file.
Opens the log file. The operations that are allowed on the stream and how these are performed are defined by the mode
parameter.
Parameters
mode The file access mode. Valid values are "r" - opens the existing log file for reading, "w" - creates a
new log file and opens it for writing.
Returns
Examples:
Returns
Examples:
ex_pushpop.spc.
Parameters
format A constant string literal specifying the desired format.
Examples:
Parameters
value The value you want to push onto the stack.
Returns
Examples:
ex_pushpop.spc.
Parameters
ch The character to be written.
Returns
Examples:
ex_putchar.spc.
Parameters
str The string of characters to be written.
Returns
Examples:
Returns
Examples:
Rotate left.
Rotate the specified variable one bit left through carry.
Parameters
value The value to rotate left one bit.
Examples:
ex_rotate.spc.
Rotate right.
Rotate the specified variable one bit right through carry.
Parameters
value The value to rotate right one bit.
Examples:
ex_rotate.spc.
Parameters
slot The constant slot number for the program you want to execute. See Program slot constants.
Sign value.
Return the sign of the value argument (-1, 0, or 1). Any scalar type can be passed into this function.
Parameters
num The numeric value for which to calculate its sign value.
Returns
Examples:
ex_sign.spc.
Parameters
value The variable.
Returns
Examples:
ex_SizeOf.spc.
Parameters
x integer value.
Returns
Square root of x.
Examples:
ex_sqrt.spc.
Start a task.
Start the specified task.
Parameters
t The task to start.
Examples:
ex_StartTask.spc.
Returns
Examples:
ex_stat.spc.
Stop the running program if bvalue is true. This will halt the program completely, so any code following this command
will be ignored.
Parameters
bvalue If this value is true the program will stop executing.
Examples:
ex_Stop.spc.
Examples:
ex_StopAllTasks.spc.
Parameters
ms The number of milliseconds to sleep.
Examples:
Parameters
value The value to write to the file.
Returns
Examples:
Examples:
ex_yield.spc.
Functions
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is either a digit or a letter, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c has a graphical representation, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is an lowercase alphabetic letter, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is an uppercase alphabetic letter, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is a hexadecimal digit character, otherwise it returns 0 (false).
Examples:
Parameters
c Uppercase letter character to be converted.
Returns
Examples:
Parameters
c Lowercase letter character to be converted.
Returns
Examples:
6 File Documentation
Additional documentation for the SPC API. SPCAPIDocs.h contains additional documentation for the SPC API
License:
The contents of this file are subject to the Mozilla Public License Version 1.1 (the "License"); you may not use this file
except in compliance with the License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either
express or implied. See the License for the specific language governing rights and limitations under the License.
The Initial Developer of this code is John Hansen. Portions created by John Hansen are Copyright (C) 2009-2013 John
Hansen. All Rights Reserved.
Author
Date
2013-02-17
Version
Macros
#define TRUE 1
#define FALSE 0
#define SERIAL_BUFFER_SIZE 255
#define CHAR_BIT 32
#define LONG_MIN -2147483648
#define SCHAR_MIN -2147483648
#define INT_MIN -2147483648
#define CHAR_MIN -2147483648
#define LONG_MAX 2147483647
#define SCHAR_MAX 2147483647
#define INT_MAX 2147483647
#define MS_80 80
#define MS_90 90
#define MS_100 100
#define MS_150 150
#define MS_200 200
#define MS_250 250
#define MS_300 300
#define MS_350 350
#define MS_400 400
#define MS_450 450
#define MS_500 500
#define MS_600 600
#define MS_700 700
#define MS_800 800
#define MS_900 900
#define SEC_1 1000
#define SEC_2 2000
#define SEC_3 3000
#define SEC_4 4000
#define SEC_5 5000
#define SEC_6 6000
#define SEC_7 7000
#define SEC_8 8000
#define SEC_9 9000
#define SEC_10 10000
#define SEC_15 15000
#define SEC_20 20000
#define SEC_30 30000
#define MIN_1 60000
#define NOTE_WHOLE 1000
#define NOTE_HALF (NOTE_WHOLE/2)
#define NOTE_QUARTER (NOTE_WHOLE/4)
#define NOTE_EIGHT (NOTE_WHOLE/8)
#define NOTE_SIXTEEN (NOTE_WHOLE/16)
#define TONE_C3 131
#define TONE_CS3 139
#define TONE_D3 147
#define TONE_DS3 156
#define TONE_E3 165
#define TONE_F3 175
#define TONE_FS3 185
#define TONE_G3 196
#define TONE_GS3 208
#define TONE_A3 220
#define TONE_AS3 233
#define TONE_B3 247
#define TONE_C4 262
#define TONE_CS4 277
#define TONE_D4 294
#define TONE_DS4 311
#define TONE_E4 330
Functions
Rotate right.
void Run (const int slot)
Run another program.
int stat (void)
Check log file status.
void StopProcesses (void)
Stop all processes.
int isupper (int c)
Check if character is uppercase letter.
int islower (int c)
Check if character is lowercase letter.
int isalpha (int c)
Check if character is alphabetic.
int isdigit (int c)
Check if character is decimal digit.
int isalnum (int c)
Check if character is alphanumeric.
int isspace (int c)
Check if character is a white-space.
int iscntrl (int c)
Check if character is a control character.
int isprint (int c)
Check if character is printable.
int isgraph (int c)
Check if character has graphical representation.
int ispunct (int c)
Check if character is a punctuation.
int isxdigit (int c)
Check if character is hexadecimal digit.
int toupper (int c)
Convert lowercase letter to uppercase.
int tolower (int c)
Convert uppercase letter to lowercase.
Constants, macros, and API functions for SPC. SPCDefs.h contains declarations for the SPC API resources
License:
The contents of this file are subject to the Mozilla Public License Version 1.1 (the "License"); you may not use this file
except in compliance with the License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either
express or implied. See the License for the specific language governing rights and limitations under the License.
The Initial Developer of this code is John Hansen. Portions created by John Hansen are Copyright (C) 2009-2013 John
Hansen. All Rights Reserved.
Author
Date
2013-02-16
Version
Add mask to DAC mode constants to force waveform generation from the start of the wave table.
Examples:
ex_DAC0ToA3.spc.
Examples:
A false value
Examples:
ex_ledcontrol.spc.
Examples:
ex_ledcontrol.spc.
Examples:
ex_stat.spc.
1 minute
Examples:
ex_stat.spc.
6.2.2.31 #define MS 1 1
1 millisecond
Examples:
ex_arrays.spc.
6.2.2.32 #define MS 10 10
10 milliseconds
Examples:
ex_DAC0ToA3.spc.
100 milliseconds
Examples:
ex_CurrentTick.spc.
150 milliseconds
6.2.2.35 #define MS 2 2
2 milliseconds
6.2.2.36 #define MS 20 20
20 milliseconds
200 milliseconds
250 milliseconds
6.2.2.39 #define MS 3 3
3 milliseconds
6.2.2.40 #define MS 30 30
30 milliseconds
300 milliseconds
350 milliseconds
6.2.2.43 #define MS 4 4
4 milliseconds
6.2.2.44 #define MS 40 40
40 milliseconds
400 milliseconds
450 milliseconds
6.2.2.47 #define MS 5 5
5 milliseconds
6.2.2.48 #define MS 50 50
50 milliseconds
500 milliseconds
Examples:
6.2.2.50 #define MS 6 6
6 milliseconds
6.2.2.51 #define MS 60 60
60 milliseconds
600 milliseconds
6.2.2.53 #define MS 7 7
7 milliseconds
6.2.2.54 #define MS 70 70
70 milliseconds
700 milliseconds
6.2.2.56 #define MS 8 8
8 milliseconds
6.2.2.57 #define MS 80 80
80 milliseconds
800 milliseconds
6.2.2.59 #define MS 9 9
9 milliseconds
6.2.2.60 #define MS 90 90
90 milliseconds
900 milliseconds
Examples:
Examples:
1 second
Examples:
10 seconds
Examples:
ex_Stop.spc.
15 seconds
Examples:
ex_timer.spc.
2 seconds
Examples:
ex_timer.spc.
20 seconds
3 seconds
Examples:
ex_StartTask.spc.
30 seconds
Examples:
ex_timer.spc.
4 seconds
5 seconds
Examples:
6 seconds
7 seconds
8 seconds
9 seconds
Program slot 1.
Program slot 2.
Program slot 3.
Program slot 4.
Program slot 5.
Program slot 6.
Program slot 7.
Third octave A
Examples:
ex_Twinkle.spc.
Fourth octave A
Examples:
ex_TwinkleL.spc.
Fifth octave A
Sixth octave A
Seventh octave A
Third octave B
Fourth octave B
Fifth octave B
Sixth octave B
Seventh octave B
Third octave C
Examples:
ex_Twinkle.spc.
Fourth octave C
Examples:
ex_TwinkleL.spc.
Fifth octave C
Sixth octave C
Seventh octave C
Third octave D
Examples:
ex_Twinkle.spc.
Fourth octave D
Examples:
ex_TwinkleL.spc.
Fifth octave D
Sixth octave D
Seventh octave D
Third octave E
Examples:
ex_Twinkle.spc.
Fourth octave E
Examples:
ex_TwinkleL.spc.
Fifth octave E
Sixth octave E
Seventh octave E
Third octave F
Examples:
ex_Twinkle.spc.
Fourth octave F
Examples:
ex_TwinkleL.spc.
Fifth octave F
Sixth octave F
Seventh octave F
Third octave G
Examples:
ex_Twinkle.spc.
Fourth octave G
Examples:
ex_TwinkleL.spc.
Fifth octave G
Sixth octave G
Seventh octave G
A true value
Examples:
ex_abort.spc.
Absolute value.
Return the absolute value of the value argument. Any scalar type can be passed into this function.
Parameters
num The numeric value.
Returns
The absolute value of num. The return type matches the input type.
Examples:
ex_abs.spc.
Close file.
Close the log file.
Returns
Examples:
Returns
Examples:
Parameters
newTask The task to start executing after exiting the current task.
Examples:
ex_exitto.spc.
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is either a digit or a letter, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c has a graphical representation, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is an lowercase alphabetic letter, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is an uppercase alphabetic letter, otherwise it returns 0 (false).
Examples:
Parameters
c Character to be checked.
Returns
Returns a non-zero value (true) if c is a hexadecimal digit character, otherwise it returns 0 (false).
Examples:
Open file.
Opens the log file. The operations that are allowed on the stream and how these are performed are defined by the mode
parameter.
Parameters
mode The file access mode. Valid values are "r" - opens the existing log file for reading, "w" - creates a
new log file and opens it for writing.
Returns
Examples:
Returns
Examples:
ex_pushpop.spc.
Parameters
format A constant string literal specifying the desired format.
Examples:
Parameters
value The value you want to push onto the stack.
Returns
Examples:
ex_pushpop.spc.
Parameters
ch The character to be written.
Returns
Examples:
ex_putchar.spc.
Parameters
str The string of characters to be written.
Returns
Examples:
Returns
Examples:
Rotate left.
Rotate the specified variable one bit left through carry.
Parameters
value The value to rotate left one bit.
Examples:
ex_rotate.spc.
Rotate right.
Rotate the specified variable one bit right through carry.
Parameters
value The value to rotate right one bit.
Examples:
ex_rotate.spc.
Parameters
slot The constant slot number for the program you want to execute. See Program slot constants.
Sign value.
Return the sign of the value argument (-1, 0, or 1). Any scalar type can be passed into this function.
Parameters
num The numeric value for which to calculate its sign value.
Returns
Examples:
ex_sign.spc.
Parameters
value The variable.
Returns
Examples:
ex_SizeOf.spc.
Parameters
x integer value.
Returns
Square root of x.
Examples:
ex_sqrt.spc.
Start a task.
Start the specified task.
Parameters
t The task to start.
Examples:
ex_StartTask.spc.
Returns
Examples:
ex_stat.spc.
Parameters
bvalue If this value is true the program will stop executing.
Examples:
ex_Stop.spc.
Examples:
ex_StopAllTasks.spc.
Parameters
c Uppercase letter character to be converted.
Returns
Examples:
Parameters
c Lowercase letter character to be converted.
Returns
Examples:
Parameters
ms The number of milliseconds to sleep.
Examples:
Parameters
value The value to write to the file.
Returns
Examples:
Examples:
ex_yield.spc.
Macros
Constants defining superpro shared memory addresses. spmem.h contains declarations for superpro shared memory
addresses.
License:
The contents of this file are subject to the Mozilla Public License Version 1.1 (the "License"); you may not use this file
except in compliance with the License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either
express or implied. See the License for the specific language governing rights and limitations under the License.
The Initial Developer of this code is John Hansen. Portions created by John Hansen are Copyright (C) 2009-2013 John
Hansen. All Rights Reserved.
Author
Date
2013-02-16
Version
Reads the current voltage on A0 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Examples:
Reads the current voltage on A1 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Examples:
Reads the current voltage on A2 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Reads the current voltage on A3 input. Value ranges from 0 to 1023. Updated every millisecond. Read only.
Examples:
ex_DAC0ToA3.spc.
Examples:
ex_DAC0ToA3.spc.
Control the operation of the DAC0 analog output (O0). See SuperPro analog output mode constants for valid values.
Read/write.
Examples:
ex_DAC0ToA3.spc.
Examples:
ex_DAC0ToA3.spc.
Examples:
Control the operation of the DAC1 analog output (O1). See SuperPro analog output mode constants for valid values.
Read/write.
Examples:
Examples:
Write 8 bits to the digital control port B0 - B7. Set the mode of any of the 8 digital signals. 1 == output, 0 == input.
Examples:
Examples:
Control the operation of the two onboard LDEs (red and blue). See SuperPro LED control constants for valid values.
Read/write.
Examples:
ex_ledcontrol.spc.
Read the next serial byte from the serial port receive queue. Reading this value removes the byte from the receive
queue. Serial port input data is stored in a 255 byte temporary buffer. Read only.
Examples:
ex_digiserial.spc.
Read the count of serial bytes in the receive queue. Enables a user program to check if any data is available to be read
from the serial port. Read only.
Examples:
ex_digiserial.spc.
Write a byte to the serial port send queue. Serial port output data is stored in a 255 byte temporary buffer. Do not write
to this address if SerialCount is 255. Write only.
Examples:
ex_serialout.spc.
Read the count of serial bytes in the send queue. Enables a user program to check how many bytes are waiting to be
sent out the serial port. Read only.
Examples:
ex_serialout.spc.
Write 6 bits to the digital strobe port S0 - WR. Controls the operation of the six strobe outputs (S0, S1, S2, S3, RD, and
WR). See SuperPro Strobe control constants for valid values.
Read the system clock. The system clock counts up continuously at one count per millisecond. Read only.
Examples:
Read/write countdown timer 0. Counts down until it reaches zero (per millisecond).
Examples:
Read/write countdown timer 1. Counts down until it reaches zero (per millisecond).
Examples:
Read/write countdown timer 2. Counts down until it reaches zero (per millisecond).
Examples:
ex_timer.spc.
Read/write countdown timer 3. Counts down until it reaches zero (per millisecond).
Examples:
7 Example Documentation
7.1 arrays.spc
struct Car {
int Make;
int Model;
bool TwoDoor;
};
struct Person {
int Age;
bool Male;
char Initial;
int Kids;
Car Vehicle;
int Weight;
int Data[4];
};
task main()
{
int x;
/*
int data[5][5], buf[5], foo[2][2][2], bar[2][3][2][3];
int *p;
x++;
jch++;
jch.Age = 23;
jch.Kids = 4;
jch.Kids = jch.Kids + 2;
jch.Initial = C;
jch.Male = true;
jch.Kids = x++;
jch.Kids++;
jch.Kids *= 2;
jch.Kids--;
jch.Vehicle.Make = 10;
jch.Vehicle.Model = 20;
jch.Vehicle.TwoDoor = false;
jch.Weight = 270;
// ++jch.Kids; // bad code
// please[0].Age = 45; // bad code
}
7.2 ex abort.spc
task main()
{
while(true)
{
if (ADChannel0 > 500)
abort(); // stop the program
}
}
7.3 ex abs.spc
task main()
{
int x = 1000 - Timer0;
int val = abs(x); // return the absolute value of x
printf("x = %d, val = %d\n", x, val);
}
7.4 ex arrays.spc
task main()
{
int i;
int myVector[10];
7.5 ex close.spc
task main()
{
open("r");
int x = read();
printf("x = %d\n", x);
close();
}
7.6 ex ctype.spc
This is an example of how to use the ctype API functions: isupper, islower, isalpha, isdigit, isalnum, isspace, iscntrl,
isprint, isgraph, ispunct, isxdigit, toupper, and tolower.
task main()
{
printf("%d\n", isalnum(a));
printf("%d\n", isalpha(1));
printf("%d\n", iscntrl(g));
printf("%d\n", isdigit(2));
printf("%d\n", isgraph(%));
printf("%d\n", islower(G));
printf("%d\n", isprint(());
printf("%d\n", ispunct(a));
printf("%d\n", isspace(1));
printf("%d\n", isupper(g));
printf("%d\n", isxdigit(2));
printf("%d\n", tolower(.));
printf("%d\n", toupper(f));
Wait(SEC_5);
}
7.7 ex CurrentTick.spc
task main()
{
while (true) {
Wait(MS_100);
int x = CurrentTick();
printf("x = %d\n", x);
}
}
7.8 ex DAC0ToA3.spc
This is an example of how to use the DAC0Mode, DAC0Frequency, DAC0Voltage, and ADChannel3 system constants
as well as the Wait and printf functions.
task main()
{
int A3;
int i, c;
DAC0Voltage = 1023;
Wait(MS_10);
}
}
7.9 ex digiserial.spc
This is an example of how to use the DigitalControl, DigitalOut, Timer0, ADChannel0, ADChannel1, SerialInCount, and
SerialInByte system constants. It is also an example of how to use the printf, puts, and Wait functions.
task leds()
{
int DigValue = 1;
int DigCount = 8;
int DigLen = 7;
int DigDir = 0;
DigitalControl = 0xFF;
while(true)
{
DigitalOut = DigValue; // output to LEDS
Timer0 = 10000/(ADChannel0+25);
while(Timer0 > 0); // wait for counter to reach 0
DigCount--;
if (DigCount != 0)
{
// shifting
if (DigDir != 0) {
DigValue >>= 1;
} else
DigValue <<= 1;
continue;
}
DigCount = DigLen;
DigDir ^= 1;
if (DigDir != 0)
{
// shifting
DigValue >>= 1;
continue;
}
switch(ADChannel1/128)
{
case 0:
DigLen = 7;
DigCount = 7;
DigValue = 0x02;
break;
case 1:
DigLen = 6;
DigCount = 6;
DigValue = 0x06;
break;
case 2:
DigLen = 5;
DigCount = 5;
DigValue = 0x0E;
break;
case 3:
DigLen = 4;
DigCount = 4;
DigValue = 0x1E;
break;
case 4:
DigLen = 3;
DigCount = 3;
DigValue = 0x3E;
break;
case 5:
DigLen = 2;
DigCount = 2;
DigValue = 0x7E;
break;
default:
DigLen = 1;
DigCount = 1;
DigValue = 0xFE;
break;
}
}
}
task main()
{
start leds;
int b;
while (true) {
if (SerialInCount) {
b = SerialInByte;
printf("Byte %d ",b);
if (b == m || b == M)
printf("Got an m or M");
else if (b == H)
printf("Got an H");
else if (b == h)
printf("Got an h");
printf("\r\n");
}
else
puts("nothing\r\n");
Wait(1000);
}
}
7.10 ex exitto.spc
// When run, this program alternates between task A and task B until halted
// by pressing the gray button.
task B();
task A()
{
printf("task A\n");
ExitTo(B);
}
task B()
{
printf("task B\n");
ExitTo(A);
}
task main()
{
printf("task main\n");
ExitTo(B);
}
7.11 ex isalnum.spc
task main()
{
printf("%d\n", isalnum(c));
}
7.12 ex isalpha.spc
task main()
{
printf("%d\n", isalpha(c));
}
7.13 ex iscntrl.spc
task main()
{
printf("%d\n", iscntrl(c));
}
7.14 ex isdigit.spc
task main()
{
printf("%d\n", isdigit(c));
}
7.15 ex isgraph.spc
task main()
{
printf("%d\n", isgraph(c));
}
7.16 ex islower.spc
task main()
{
printf("%d\n", islower(c));
}
7.17 ex isprint.spc
task main()
{
printf("%d\n", isprint(c));
}
7.18 ex ispunct.spc
task main()
{
printf("%d\n", ispunct(c));
}
7.19 ex isspace.spc
task main()
{
printf("%d\n", isspace(c));
}
7.20 ex isupper.spc
task main()
{
printf("%d\n", isupper(c));
}
7.21 ex isxdigit.spc
task main()
{
printf("%d\n", isxdigit(c));
}
7.22 ex ledcontrol.spc
This is an example of how to use the LEDControl system constant as well as the Wait function.
task main()
{
while(true)
{
LEDControl = LED_BLUE;
Wait(SEC_1);
LEDControl = LED_RED;
Wait(SEC_1);
LEDControl = LED_BLUE|LED_RED;
Wait(SEC_1);
}
}
7.23 ex ledtest.spc
This is an example of how to use the DigitalControl, DigitalOut, Timer0, ADChannel0, and ADChannel1 system con-
stants.
#pragma autostart
task main()
{
int DigValue = 1;
int DigCount = 8;
int DigLen = 7;
int DigDir = 0;
DigitalControl = 0xFF;
while(true)
{
DigitalOut = DigValue; // output to LEDS
Timer0 = 10000/(ADChannel0+25);
while(Timer0 > 0); // wait for counter to reach 0
DigCount--;
if (DigCount != 0)
{
// shifting
if (DigDir != 0) {
DigValue >>= 1;
} else
DigValue <<= 1;
continue;
}
DigCount = DigLen;
DigDir ^= 1;
if (DigDir != 0)
{
// shifting
DigValue >>= 1;
continue;
}
switch(ADChannel1/128)
{
case 0:
DigLen = 7;
DigCount = 7;
DigValue = 0x02;
break;
case 1:
DigLen = 6;
DigCount = 6;
DigValue = 0x06;
break;
case 2:
DigLen = 5;
DigCount = 5;
DigValue = 0x0E;
break;
case 3:
DigLen = 4;
DigCount = 4;
DigValue = 0x1E;
break;
case 4:
DigLen = 3;
DigCount = 3;
DigValue = 0x3E;
break;
case 5:
DigLen = 2;
DigCount = 2;
DigValue = 0x7E;
break;
default:
DigLen = 1;
DigCount = 1;
DigValue = 0xFE;
break;
}
}
}
7.24 ex open.spc
task main()
{
open("r");
int x = read();
printf("x = %d\n", x);
close();
}
7.25 ex printf.spc
task main()
{
int value = ADChannel0;
printf("value = %d\n", value);
}
7.26 ex pushpop.spc
task main()
{
int x = Timer3;
int y;
y = push(x);
x = x*x;
printf("x = %d\n", x);
x = pop();
printf("x = %d\n", x);
}
7.27 ex putchar.spc
task main()
{
int y;
y = putchar(\n);
y = putchar(\t);
y = putchar(\r);
y = putchar(X);
}
7.28 ex puts.spc
task main()
{
puts("testing\none, two, three\n");
}
7.29 ex read.spc
task main()
{
open("r");
int x = read();
printf("x = %d\n", x);
close();
}
7.30 ex rotate.spc
task main()
{
int x = ADChannel0;
printf("x = %d\n", x);
repeat(4)
RotateLeft(x); // rotate left through carry by 1 bit (4 times)
printf("x = %d\n", x);
repeat(2)
RotateRight(x); // rotate right through carry by 1 bit (2 times)
printf("x = %d\n", x);
}
7.31 ex run.spc
7.32 ex serialout.spc
This is an example of how to use the SerialOutCount and SerialOutByte system constants as well as the Wait and printf
functions.
task main()
{
while(true)
{
if (SerialOutCount > 200)
continue;
SerialOutByte = a;
SerialOutByte = b;
SerialOutByte = c;
SerialOutByte = d;
SerialOutByte = e;
printf("%d\n", SerialOutCount);
Wait(MS_500);
}
}
7.33 ex sign.spc
task main()
{
int x = 1000 - CurrentTick();
char val = sign(x); // return -1, 0, or 1
printf("sign(x) = %d\n", val);
}
7.34 ex SizeOf.spc
task main()
{
int x;
bool b;
char data[] = {1, 2, 3, 4, 5, 6};
7.35 ex sqrt.spc
task main()
{
int x = CurrentTick();
printf("x = %d\n", x);
x = sqrt(x);
printf("sqrt(x) = %d\n", x);
}
7.36 ex StartTask.spc
task foo()
{
while(true) {
Wait(SEC_5);
puts("foo is running\n");
}
}
task main()
{
StartTask(foo); // start the foo task
while(true)
{
Wait(SEC_3);
puts("main is running\n");
}
}
7.37 ex stat.spc
task main()
{
Timer0 = MIN_1;
open("w");
if (stat() == LOG_STATUS_OPEN)
{
write(Timer0);
}
close();
}
7.38 ex Stop.spc
task main()
{
int x;
Timer0 = SEC_10;
while (true)
{
x = Timer0;
Stop(x == 24); // stop the program if x==24
}
}
7.39 ex StopAllTasks.spc
task main()
{
while(true)
{
if (CurrentTick() > 50000)
StopAllTasks(); // stop the program
}
}
7.40 ex StopProcesses.spc
7.41 ex systemclock.spc
This is an example of how to use the SystemClock system constant as well as the Wait and printf functions.
task main()
{
while(true)
{
printf("%d\n", SystemClock);
Wait(SEC_5);
}
}
7.42 ex timer.spc
This is an example of how to use the Timer0, Timer1, Timer2, and Timer3 system constants. It also is an example of
how to use the Wait and printf functions.
task main()
{
Timer0 = START_MS;
Timer1 = START_MS;
Timer2 = START_MS;
Timer3 = START_MS;
while(true)
{
printf("%d\n", Timer0);
printf("%d\n", Timer1);
printf("%d\n", Timer2);
printf("%d\n", Timer3);
Wait(SEC_2);
if (Timer2 < SEC_15)
Timer2 = START_MS;
if (Timer3 < SEC_30)
Timer3 = START_MS;
}
}
7.43 ex tolower.spc
task main()
{
printf("tolower(C) = %d\n", tolower(C));
}
7.44 ex toupper.spc
task main()
{
printf("toupper(c) = %d\n", toupper(c));
}
7.45 ex Twinkle.spc
This is an example of how to use the DAC1Mode, DAC1Frequency, and DAC1Voltage system constants. It is also an
example of how to use the Wait function.
DAC1Voltage = 0;
}
void TwinkleA()
{
PlayNoteStacato(TONE_C3, NOTE_QUARTER);
PlayNoteStacato(TONE_C3, NOTE_QUARTER);
PlayNoteStacato(TONE_G3, NOTE_QUARTER);
PlayNoteStacato(TONE_G3, NOTE_QUARTER);
PlayNoteStacato(TONE_A3, NOTE_QUARTER);
PlayNoteStacato(TONE_A3, NOTE_QUARTER);
PlayNoteStacato(TONE_G3, NOTE_HALF);
PlayNoteStacato(TONE_F3, NOTE_QUARTER);
PlayNoteStacato(TONE_F3, NOTE_QUARTER);
PlayNoteStacato(TONE_E3, NOTE_QUARTER);
PlayNoteStacato(TONE_E3, NOTE_QUARTER);
PlayNoteStacato(TONE_D3, NOTE_QUARTER);
PlayNoteStacato(TONE_D3, NOTE_QUARTER);
PlayNoteStacato(TONE_C3, NOTE_HALF);
}
void TwinkleB()
{
PlayNoteStacato(TONE_G3, NOTE_QUARTER);
PlayNoteStacato(TONE_G3, NOTE_QUARTER);
PlayNoteStacato(TONE_F3, NOTE_QUARTER);
PlayNoteStacato(TONE_F3, NOTE_QUARTER);
PlayNoteStacato(TONE_E3, NOTE_QUARTER);
PlayNoteStacato(TONE_E3, NOTE_QUARTER);
PlayNoteStacato(TONE_D3, NOTE_HALF);
}
task main()
{
int A0;
7.46 ex TwinkleL.spc
This is an example of how to use the DAC1Mode, DAC1Frequency, DAC1Voltage, and SharedMem01 system constants.
It is also an example of how to use the Wait function.
void TwinkleA()
{
PlayNoteStacato(TONE_C4, NOTE_QUARTER);
PlayNoteStacato(TONE_C4, NOTE_QUARTER);
PlayNoteStacato(TONE_G4, NOTE_QUARTER);
PlayNoteStacato(TONE_G4, NOTE_QUARTER);
PlayNoteStacato(TONE_A4, NOTE_QUARTER);
PlayNoteStacato(TONE_A4, NOTE_QUARTER);
PlayNoteStacato(TONE_G4, NOTE_HALF);
PlayNoteStacato(TONE_F4, NOTE_QUARTER);
PlayNoteStacato(TONE_F4, NOTE_QUARTER);
PlayNoteStacato(TONE_E4, NOTE_QUARTER);
PlayNoteStacato(TONE_E4, NOTE_QUARTER);
PlayNoteStacato(TONE_D4, NOTE_QUARTER);
PlayNoteStacato(TONE_D4, NOTE_QUARTER);
PlayNoteStacato(TONE_C4, NOTE_HALF);
}
void TwinkleB()
{
PlayNoteStacato(TONE_G4, NOTE_QUARTER);
PlayNoteStacato(TONE_G4, NOTE_QUARTER);
PlayNoteStacato(TONE_F4, NOTE_QUARTER);
PlayNoteStacato(TONE_F4, NOTE_QUARTER);
PlayNoteStacato(TONE_E4, NOTE_QUARTER);
PlayNoteStacato(TONE_E4, NOTE_QUARTER);
PlayNoteStacato(TONE_D4, NOTE_HALF);
}
task main()
{
// Set up Analog 1 output to output a square wave
DAC1Voltage = 0;
DAC1Mode = DAC_MODE_SQUAREWAVE;
DAC1Frequency = 0;
7.47 ex wait.spc
task main()
{
printf("tick = %d\n", SystemClock);
Wait(SEC_5); // wait 5 seconds
printf("tick = %d\n", SystemClock);
}
7.48 ex write.spc
task main()
{
int x = Timer1;
open("w");
write(x);
close();
}
7.49 ex yield.spc
task main()
{
printf("tick = %d\n", SystemClock);
Yield();
printf("tick = %d\n", SystemClock);
}
7.50 if test.spc
task main(){
int x = 3;
bool b1, b2, b3;
task main()
{
int y=5;
int z;
z = Foo(y);
}
7.52 t1.spc
#pragma autostart
task t1()
{
while(true)
{
puts("1 ");
Wait(MS_500);
}
}
task t2()
{
while(true)
{
puts("2 ");
Wait(MS_500);
}
}
task main()
{
start t1;
start t2;
}
LONG_MAX, 45 isupper
LONG_MIN, 45 ctype API, 74
SCHAR_MAX, 45 SPCDefs.h, 100
SCHAR_MIN, 45 isxdigit
DigitalControl ctype API, 75
Pre-defined System constants, 33 SPCDefs.h, 100
spmem.h, 110
DigitalIn LED_BLUE
Pre-defined System constants, 33 SPCDefs.h, 84
spmem.h, 110 SuperPro LED control constants, 42
DigitalOut LED_RED
Pre-defined System constants, 33 SPCDefs.h, 85
spmem.h, 110 SuperPro LED control constants, 42
LEDControl
ExitTo Pre-defined System constants, 33
SPCDefs.h, 97 spmem.h, 110
SuperPro C API, 64 LOG_STATUS_BUSY
Log status constants, 48
FALSE SPCDefs.h, 85
Miscellaneous SPC constants, 30 LOG_STATUS_CLOSED
SPCDefs.h, 84 Log status constants, 48
SPCDefs.h, 85
INT_MAX LOG_STATUS_OPEN
Data type limits, 45 Log status constants, 48
SPCDefs.h, 84 SPCDefs.h, 85
INT_MIN LONG_MAX
Data type limits, 45 Data type limits, 45
SPCDefs.h, 84 SPCDefs.h, 85
isalnum LONG_MIN
ctype API, 71 Data type limits, 45
SPCDefs.h, 97 SPCDefs.h, 85
isalpha Log status constants, 48
ctype API, 72 LOG_STATUS_BUSY, 48
SPCDefs.h, 97 LOG_STATUS_CLOSED, 48
iscntrl LOG_STATUS_OPEN, 48
ctype API, 72
SPCDefs.h, 98 MIN_1
isdigit SPCDefs.h, 85
ctype API, 72 Time constants, 50
SPCDefs.h, 98 MS_1
isgraph SPCDefs.h, 85
ctype API, 73 Time constants, 50
SPCDefs.h, 98 MS_10
islower SPCDefs.h, 85
ctype API, 73 Time constants, 50
SPCDefs.h, 98 MS_100
isprint SPCDefs.h, 85
ctype API, 73 Time constants, 50
SPCDefs.h, 99 MS_150
ispunct SPCDefs.h, 86
ctype API, 74 Time constants, 50
SPCDefs.h, 99 MS_2
isspace SPCDefs.h, 86
ctype API, 74 Time constants, 50
SPCDefs.h, 99 MS_20
SPCDefs.h, 86 SPCDefs.h, 87
Time constants, 51 Time constants, 52
MS_200 MS_700
SPCDefs.h, 86 SPCDefs.h, 87
Time constants, 51 Time constants, 52
MS_250 MS_8
SPCDefs.h, 86 SPCDefs.h, 87
Time constants, 51 Time constants, 52
MS_3 MS_80
SPCDefs.h, 86 SPCDefs.h, 87
Time constants, 51 Time constants, 52
MS_30 MS_800
SPCDefs.h, 86 SPCDefs.h, 87
Time constants, 51 Time constants, 52
MS_300 MS_9
SPCDefs.h, 86 SPCDefs.h, 87
Time constants, 51 Time constants, 52
MS_350 MS_90
SPCDefs.h, 86 SPCDefs.h, 88
Time constants, 51 Time constants, 52
MS_4 MS_900
SPCDefs.h, 86 SPCDefs.h, 88
Time constants, 51 Time constants, 52
MS_40 Miscellaneous SPC constants, 30
SPCDefs.h, 86 FALSE, 30
Time constants, 51 TRUE, 30
MS_400
SPCDefs.h, 86 NOTE_EIGHT
Time constants, 51 SPCDefs.h, 88
MS_450 Time constants, 52
SPCDefs.h, 86 NOTE_HALF
Time constants, 51 SPCDefs.h, 88
MS_5 Time constants, 53
SPCDefs.h, 87 NOTE_QUARTER
Time constants, 51 SPCDefs.h, 88
MS_50 Time constants, 53
SPCDefs.h, 87 NOTE_SIXTEEN
Time constants, 51 SPCDefs.h, 88
MS_500 Time constants, 53
SPCDefs.h, 87 NOTE_WHOLE
Time constants, 51 SPCDefs.h, 88
MS_6 Time constants, 53
SPCDefs.h, 87
Time constants, 52 open
MS_60 SPCDefs.h, 100
SPCDefs.h, 87 SuperPro C API, 64
Time constants, 52
pop
MS_600
SPCDefs.h, 101
SPCDefs.h, 87
SuperPro C API, 64
Time constants, 52
Pre-defined shared memory constants, 36
MS_7
SharedMem01, 36
SPCDefs.h, 87
SharedMem02, 36
Time constants, 52
SharedMem03, 37
MS_70
SharedMem04, 37
SPCDefs.h, 89 close, 96
Time constants, 54 CurrentTick, 96
SEC_30 DAC_MODE_DCOUT, 83
SPCDefs.h, 89 DIGI_PIN0, 84
Time constants, 54 DIGI_PIN1, 84
SEC_4 DIGI_PIN2, 84
SPCDefs.h, 89 DIGI_PIN3, 84
Time constants, 54 DIGI_PIN4, 84
SEC_5 DIGI_PIN5, 84
SPCDefs.h, 89 DIGI_PIN6, 84
Time constants, 54 DIGI_PIN7, 84
SEC_6 ExitTo, 97
SPCDefs.h, 89 FALSE, 84
Time constants, 54 INT_MAX, 84
SEC_7 INT_MIN, 84
SPCDefs.h, 89 isalnum, 97
Time constants, 54 isalpha, 97
SEC_8 iscntrl, 98
SPCDefs.h, 90 isdigit, 98
Time constants, 54 isgraph, 98
SEC_9 islower, 98
SPCDefs.h, 90 isprint, 99
Time constants, 54 ispunct, 99
SERIAL_BUFFER_SIZE isspace, 99
Miscellaneous SPC constants, 30 isupper, 100
SPCDefs.h, 90 isxdigit, 100
SLOT1 LED_BLUE, 84
Program slot constants, 47 LED_RED, 85
SPCDefs.h, 90 LOG_STATUS_BUSY, 85
SLOT2 LOG_STATUS_OPEN, 85
Program slot constants, 47 LONG_MAX, 85
SPCDefs.h, 90 LONG_MIN, 85
SLOT3 MIN_1, 85
Program slot constants, 47 MS_1, 85
SPCDefs.h, 90 MS_10, 85
SLOT4 MS_100, 85
Program slot constants, 47 MS_150, 86
SPCDefs.h, 90 MS_2, 86
SLOT5 MS_20, 86
Program slot constants, 47 MS_200, 86
SPCDefs.h, 90 MS_250, 86
SLOT6 MS_3, 86
Program slot constants, 47 MS_30, 86
SPCDefs.h, 90 MS_300, 86
SLOT7 MS_350, 86
Program slot constants, 47 MS_4, 86
SPCDefs.h, 90 MS_40, 86
SPCAPIDocs.h, 77 MS_400, 86
SPCDefs.h, 77 MS_450, 86
abort, 96 MS_5, 87
abs, 96 MS_50, 87
CHAR_BIT, 83 MS_500, 87
CHAR_MAX, 83 MS_6, 87
CHAR_MIN, 83 MS_60, 87
TONE_B7 TONE_DS5
SPCDefs.h, 92 SPCDefs.h, 93
Tone constants, 57 Tone constants, 59
TONE_C3 TONE_DS6
SPCDefs.h, 92 SPCDefs.h, 93
Tone constants, 57 Tone constants, 59
TONE_C4 TONE_DS7
SPCDefs.h, 92 SPCDefs.h, 93
Tone constants, 57 Tone constants, 59
TONE_C5 TONE_E3
SPCDefs.h, 92 SPCDefs.h, 93
Tone constants, 57 Tone constants, 59
TONE_C6 TONE_E4
SPCDefs.h, 92 SPCDefs.h, 94
Tone constants, 57 Tone constants, 59
TONE_C7 TONE_E5
SPCDefs.h, 92 SPCDefs.h, 94
Tone constants, 58 Tone constants, 59
TONE_CS3 TONE_E6
SPCDefs.h, 92 SPCDefs.h, 94
Tone constants, 58 Tone constants, 59
TONE_CS4 TONE_E7
SPCDefs.h, 92 SPCDefs.h, 94
Tone constants, 58 Tone constants, 59
TONE_CS5 TONE_F3
SPCDefs.h, 92 SPCDefs.h, 94
Tone constants, 58 Tone constants, 59
TONE_CS6 TONE_F4
SPCDefs.h, 92 SPCDefs.h, 94
Tone constants, 58 Tone constants, 59
TONE_CS7 TONE_F5
SPCDefs.h, 93 SPCDefs.h, 94
Tone constants, 58 Tone constants, 59
TONE_D3 TONE_F6
SPCDefs.h, 93 SPCDefs.h, 94
Tone constants, 58 Tone constants, 60
TONE_D4 TONE_F7
SPCDefs.h, 93 SPCDefs.h, 94
Tone constants, 58 Tone constants, 60
TONE_D5 TONE_FS3
SPCDefs.h, 93 SPCDefs.h, 94
Tone constants, 58 Tone constants, 60
TONE_D6 TONE_FS4
SPCDefs.h, 93 SPCDefs.h, 94
Tone constants, 58 Tone constants, 60
TONE_D7 TONE_FS5
SPCDefs.h, 93 SPCDefs.h, 94
Tone constants, 58 Tone constants, 60
TONE_DS3 TONE_FS6
SPCDefs.h, 93 SPCDefs.h, 95
Tone constants, 58 Tone constants, 60
TONE_DS4 TONE_FS7
SPCDefs.h, 93 SPCDefs.h, 95
Tone constants, 58 Tone constants, 60
TONE_G3 MS_6, 52
SPCDefs.h, 95 MS_60, 52
Tone constants, 60 MS_600, 52
TONE_G4 MS_7, 52
SPCDefs.h, 95 MS_70, 52
Tone constants, 60 MS_700, 52
TONE_G5 MS_8, 52
SPCDefs.h, 95 MS_80, 52
Tone constants, 60 MS_800, 52
TONE_G6 MS_9, 52
SPCDefs.h, 95 MS_90, 52
Tone constants, 60 MS_900, 52
TONE_G7 NOTE_EIGHT, 52
SPCDefs.h, 95 NOTE_HALF, 53
Tone constants, 60 NOTE_QUARTER, 53
TONE_GS3 NOTE_SIXTEEN, 53
SPCDefs.h, 95 NOTE_WHOLE, 53
Tone constants, 60 SEC_1, 53
TONE_GS4 SEC_10, 53
SPCDefs.h, 95 SEC_15, 53
Tone constants, 61 SEC_2, 53
TONE_GS5 SEC_20, 53
SPCDefs.h, 95 SEC_3, 54
Tone constants, 61 SEC_30, 54
TONE_GS6 SEC_4, 54
SPCDefs.h, 95 SEC_5, 54
Tone constants, 61 SEC_6, 54
TONE_GS7 SEC_7, 54
SPCDefs.h, 95 SEC_8, 54
Tone constants, 61 SEC_9, 54
TRUE Timer0
Miscellaneous SPC constants, 30 Pre-defined System constants, 34
SPCDefs.h, 95 spmem.h, 113
Time constants, 49 Timer1
MIN_1, 50 Pre-defined System constants, 34
MS_1, 50 spmem.h, 113
MS_10, 50 Timer2
MS_100, 50 Pre-defined System constants, 34
MS_150, 50 spmem.h, 114
MS_2, 50 Timer3
MS_20, 51 Pre-defined System constants, 34
MS_200, 51 spmem.h, 114
MS_250, 51 tolower
MS_3, 51 ctype API, 75
MS_30, 51 SPCDefs.h, 105
MS_300, 51 Tone constants, 55
MS_350, 51 TONE_A3, 56
MS_4, 51 TONE_A4, 56
MS_40, 51 TONE_A5, 56
MS_400, 51 TONE_A6, 56
MS_450, 51 TONE_A7, 56
MS_5, 51 TONE_AS3, 56
MS_50, 51 TONE_AS4, 57
MS_500, 51 TONE_AS5, 57