2018-07-25 23:00:46 +00:00
|
|
|
/******************************************
|
|
|
|
* stack - Stack Memory Functions for C02 *
|
|
|
|
******************************************/
|
|
|
|
|
|
|
|
/* Set Stack Start Address *
|
|
|
|
* Args: &addr - Start Address */
|
|
|
|
void stkbgn();
|
|
|
|
|
2018-07-26 14:33:03 +00:00
|
|
|
/* Drop Top Entry from Stack *
|
|
|
|
* Returns: A=Number of bytes dropped *
|
|
|
|
* 0 if none */
|
|
|
|
char stkdrp();
|
|
|
|
|
2018-07-25 23:00:46 +00:00
|
|
|
/* Set Destination to Stack Pointer *
|
|
|
|
* Returns: Y,X=Pointer Address */
|
|
|
|
void stkdst();
|
|
|
|
|
2018-07-26 14:33:03 +00:00
|
|
|
/* Duplicate Top Stack Entry *
|
|
|
|
* Returns: A=Number of bytes retrieved *
|
|
|
|
* 0 if none or overflow */
|
|
|
|
char stkdup();
|
|
|
|
|
2018-07-25 23:00:46 +00:00
|
|
|
/* Set Stack End Address *
|
|
|
|
* Args: &addr - End Address */
|
|
|
|
void stkend();
|
|
|
|
|
2018-07-26 14:33:03 +00:00
|
|
|
/* Duplicate Entry Under Top of Stack *
|
|
|
|
* Returns: A=Number of bytes retrieved *
|
|
|
|
* 0 if none or overflow */
|
|
|
|
char stkovr();
|
|
|
|
|
|
|
|
/* Pop Top Stack Entry into Array *
|
2018-07-25 23:00:46 +00:00
|
|
|
* Args: n - Number of bytes to write *
|
|
|
|
* &m - Array to pop contents into *
|
|
|
|
* Returns: A=Number of bytes retrieved *
|
|
|
|
* 0 if none */
|
|
|
|
char stkpop();
|
|
|
|
|
|
|
|
/* Push Array Contents onto Stack *
|
|
|
|
* Args: n - Number of bytes to write *
|
|
|
|
* &m - Array containing bytes to push *
|
|
|
|
* Returns: A=$FF if bytes were written *
|
|
|
|
* $00 if block was overflowed */
|
|
|
|
char stkpsh();
|
|
|
|
|
|
|
|
/* Get Stack Pointer Address *
|
|
|
|
* Returns: Y,X=Pointer Address */
|
|
|
|
void stkptr();
|
|
|
|
|
|
|
|
/* Reset Stack Pointer to Stack Start *
|
|
|
|
* Returns: Y,X=Pointer Address */
|
|
|
|
void stkrst();
|
|
|
|
|
|
|
|
/* Set Stack Pointer Address *
|
|
|
|
* Args: &addr - Pointer Address */
|
|
|
|
void stkset();
|
|
|
|
|
|
|
|
/* Push String onto Stack *
|
|
|
|
* Args: &m - String to push *
|
|
|
|
* Returns: A=$FF if bytes were written *
|
|
|
|
* $00 if block was overflowed */
|
|
|
|
char stkstr();
|
|
|
|
|
2018-07-26 14:33:03 +00:00
|
|
|
/* Copy Top Stack Entry into Array *
|
|
|
|
* Args: n - Number of bytes to write *
|
|
|
|
* &m - Array to pop contents into *
|
|
|
|
* Returns: A=Number of bytes retrieved *
|
|
|
|
* 0 if none */
|
|
|
|
char stktop();
|
|
|
|
|