Norimasa Okamoto
/
pymite
python-on-a-chip online compiler
- http://pymbed.appspot.com/
- https://code.google.com/p/python-on-a-chip/
- http://www.youtube.com/watch?v=Oyqc2bFRW9I
- https://bitbucket.org/va009039/pymbed/
more info: python-on-a-chip
vm/pm.h@0:65f1469d6bfb, 2013-03-02 (annotated)
- Committer:
- va009039
- Date:
- Sat Mar 02 11:54:20 2013 +0000
- Revision:
- 0:65f1469d6bfb
first commit
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
va009039 | 0:65f1469d6bfb | 1 | /* |
va009039 | 0:65f1469d6bfb | 2 | # This file is Copyright 2002 Dean Hall. |
va009039 | 0:65f1469d6bfb | 3 | # This file is part of the PyMite VM. |
va009039 | 0:65f1469d6bfb | 4 | # This file is licensed under the MIT License. |
va009039 | 0:65f1469d6bfb | 5 | # See the LICENSE file for details. |
va009039 | 0:65f1469d6bfb | 6 | */ |
va009039 | 0:65f1469d6bfb | 7 | |
va009039 | 0:65f1469d6bfb | 8 | |
va009039 | 0:65f1469d6bfb | 9 | #ifndef __PM_H__ |
va009039 | 0:65f1469d6bfb | 10 | #define __PM_H__ |
va009039 | 0:65f1469d6bfb | 11 | |
va009039 | 0:65f1469d6bfb | 12 | |
va009039 | 0:65f1469d6bfb | 13 | /** |
va009039 | 0:65f1469d6bfb | 14 | * \file |
va009039 | 0:65f1469d6bfb | 15 | * \brief PyMite Header |
va009039 | 0:65f1469d6bfb | 16 | * |
va009039 | 0:65f1469d6bfb | 17 | * Include things that are needed by nearly everything. |
va009039 | 0:65f1469d6bfb | 18 | */ |
va009039 | 0:65f1469d6bfb | 19 | |
va009039 | 0:65f1469d6bfb | 20 | |
va009039 | 0:65f1469d6bfb | 21 | #ifdef __cplusplus |
va009039 | 0:65f1469d6bfb | 22 | extern "C" { |
va009039 | 0:65f1469d6bfb | 23 | #endif |
va009039 | 0:65f1469d6bfb | 24 | |
va009039 | 0:65f1469d6bfb | 25 | #ifdef HAVE_SNPRINTF_FORMAT |
va009039 | 0:65f1469d6bfb | 26 | #include <stdio.h> |
va009039 | 0:65f1469d6bfb | 27 | #endif |
va009039 | 0:65f1469d6bfb | 28 | #include <stdint.h> |
va009039 | 0:65f1469d6bfb | 29 | |
va009039 | 0:65f1469d6bfb | 30 | /** |
va009039 | 0:65f1469d6bfb | 31 | * Value indicating the release of PyMite |
va009039 | 0:65f1469d6bfb | 32 | * |
va009039 | 0:65f1469d6bfb | 33 | * This value should be incremented for every public release. |
va009039 | 0:65f1469d6bfb | 34 | * It helps locate a defect when used in conjunction with a fileID |
va009039 | 0:65f1469d6bfb | 35 | * and line number. |
va009039 | 0:65f1469d6bfb | 36 | */ |
va009039 | 0:65f1469d6bfb | 37 | #define PM_RELEASE 8 |
va009039 | 0:65f1469d6bfb | 38 | |
va009039 | 0:65f1469d6bfb | 39 | |
va009039 | 0:65f1469d6bfb | 40 | /** null for C code */ |
va009039 | 0:65f1469d6bfb | 41 | #define C_NULL 0 |
va009039 | 0:65f1469d6bfb | 42 | |
va009039 | 0:65f1469d6bfb | 43 | /** false for C code */ |
va009039 | 0:65f1469d6bfb | 44 | #define C_FALSE (uint8_t)0 |
va009039 | 0:65f1469d6bfb | 45 | |
va009039 | 0:65f1469d6bfb | 46 | /** true for C code */ |
va009039 | 0:65f1469d6bfb | 47 | #define C_TRUE (uint8_t)1 |
va009039 | 0:65f1469d6bfb | 48 | |
va009039 | 0:65f1469d6bfb | 49 | /** Comparison result is that items are the same */ |
va009039 | 0:65f1469d6bfb | 50 | #define C_SAME (int8_t)0 |
va009039 | 0:65f1469d6bfb | 51 | |
va009039 | 0:65f1469d6bfb | 52 | /** Comparison result is that items differ */ |
va009039 | 0:65f1469d6bfb | 53 | #define C_DIFFER (int8_t)-1 |
va009039 | 0:65f1469d6bfb | 54 | |
va009039 | 0:65f1469d6bfb | 55 | /** PORT inline for C code */ |
va009039 | 0:65f1469d6bfb | 56 | #define INLINE __inline__ |
va009039 | 0:65f1469d6bfb | 57 | |
va009039 | 0:65f1469d6bfb | 58 | |
va009039 | 0:65f1469d6bfb | 59 | /** |
va009039 | 0:65f1469d6bfb | 60 | * Returns an exception error code and stores debug data |
va009039 | 0:65f1469d6bfb | 61 | * |
va009039 | 0:65f1469d6bfb | 62 | * This macro must be used as an rval statement. That is, it must |
va009039 | 0:65f1469d6bfb | 63 | * be used after an assignment such as "retval = " or a return statement |
va009039 | 0:65f1469d6bfb | 64 | */ |
va009039 | 0:65f1469d6bfb | 65 | #if __DEBUG__ |
va009039 | 0:65f1469d6bfb | 66 | #define PM_RAISE(retexn, exn) \ |
va009039 | 0:65f1469d6bfb | 67 | do \ |
va009039 | 0:65f1469d6bfb | 68 | { \ |
va009039 | 0:65f1469d6bfb | 69 | retexn = (exn); \ |
va009039 | 0:65f1469d6bfb | 70 | gVmGlobal.errFileId = __FILE_ID__; \ |
va009039 | 0:65f1469d6bfb | 71 | gVmGlobal.errLineNum = (uint16_t)__LINE__; \ |
va009039 | 0:65f1469d6bfb | 72 | } while (0) |
va009039 | 0:65f1469d6bfb | 73 | #else |
va009039 | 0:65f1469d6bfb | 74 | #define PM_RAISE(retexn, exn) \ |
va009039 | 0:65f1469d6bfb | 75 | retexn = (exn) |
va009039 | 0:65f1469d6bfb | 76 | #endif |
va009039 | 0:65f1469d6bfb | 77 | |
va009039 | 0:65f1469d6bfb | 78 | /** if retval is not OK, break from the block */ |
va009039 | 0:65f1469d6bfb | 79 | #define PM_BREAK_IF_ERROR(retval) if ((retval) != PM_RET_OK) break |
va009039 | 0:65f1469d6bfb | 80 | |
va009039 | 0:65f1469d6bfb | 81 | /** return an error code if it is not PM_RET_OK */ |
va009039 | 0:65f1469d6bfb | 82 | #define PM_RETURN_IF_ERROR(retval) if ((retval) != PM_RET_OK) return (retval) |
va009039 | 0:65f1469d6bfb | 83 | |
va009039 | 0:65f1469d6bfb | 84 | /** print an error message if argument is not PM_RET_OK */ |
va009039 | 0:65f1469d6bfb | 85 | #define PM_REPORT_IF_ERROR(retval) if ((retval) != PM_RET_OK) \ |
va009039 | 0:65f1469d6bfb | 86 | plat_reportError(retval) |
va009039 | 0:65f1469d6bfb | 87 | |
va009039 | 0:65f1469d6bfb | 88 | /** Jumps to a label if argument is not PM_RET_OK */ |
va009039 | 0:65f1469d6bfb | 89 | #define PM_GOTO_IF_ERROR(retval, target) if ((retval) != PM_RET_OK) \ |
va009039 | 0:65f1469d6bfb | 90 | goto target |
va009039 | 0:65f1469d6bfb | 91 | |
va009039 | 0:65f1469d6bfb | 92 | #if __DEBUG__ |
va009039 | 0:65f1469d6bfb | 93 | /** If the boolean expression fails, return the ASSERT error code */ |
va009039 | 0:65f1469d6bfb | 94 | #define C_ASSERT(boolexpr) \ |
va009039 | 0:65f1469d6bfb | 95 | do \ |
va009039 | 0:65f1469d6bfb | 96 | { \ |
va009039 | 0:65f1469d6bfb | 97 | if (!((boolexpr))) \ |
va009039 | 0:65f1469d6bfb | 98 | { \ |
va009039 | 0:65f1469d6bfb | 99 | gVmGlobal.errFileId = __FILE_ID__; \ |
va009039 | 0:65f1469d6bfb | 100 | gVmGlobal.errLineNum = (uint16_t)__LINE__; \ |
va009039 | 0:65f1469d6bfb | 101 | return PM_RET_ASSERT_FAIL; \ |
va009039 | 0:65f1469d6bfb | 102 | } \ |
va009039 | 0:65f1469d6bfb | 103 | } \ |
va009039 | 0:65f1469d6bfb | 104 | while (0) |
va009039 | 0:65f1469d6bfb | 105 | |
va009039 | 0:65f1469d6bfb | 106 | #else |
va009039 | 0:65f1469d6bfb | 107 | /** Assert statements are removed from production code */ |
va009039 | 0:65f1469d6bfb | 108 | #define C_ASSERT(boolexpr) |
va009039 | 0:65f1469d6bfb | 109 | #endif |
va009039 | 0:65f1469d6bfb | 110 | |
va009039 | 0:65f1469d6bfb | 111 | /** Use as the first argument to C_DEBUG_PRINT for low volume messages */ |
va009039 | 0:65f1469d6bfb | 112 | #define VERBOSITY_LOW 1 |
va009039 | 0:65f1469d6bfb | 113 | |
va009039 | 0:65f1469d6bfb | 114 | /** Use as the first argument to C_DEBUG_PRINT for medium volume messages */ |
va009039 | 0:65f1469d6bfb | 115 | #define VERBOSITY_MEDIUM 2 |
va009039 | 0:65f1469d6bfb | 116 | |
va009039 | 0:65f1469d6bfb | 117 | /** Use as the first argument to C_DEBUG_PRINT for high volume messages */ |
va009039 | 0:65f1469d6bfb | 118 | #define VERBOSITY_HIGH 3 |
va009039 | 0:65f1469d6bfb | 119 | |
va009039 | 0:65f1469d6bfb | 120 | #if __DEBUG__ |
va009039 | 0:65f1469d6bfb | 121 | #include <stdio.h> |
va009039 | 0:65f1469d6bfb | 122 | |
va009039 | 0:65f1469d6bfb | 123 | /** To be used to set DEBUG_PRINT_VERBOSITY to a value so no prints occur */ |
va009039 | 0:65f1469d6bfb | 124 | #define VERBOSITY_OFF 0 |
va009039 | 0:65f1469d6bfb | 125 | |
va009039 | 0:65f1469d6bfb | 126 | /** Sets the level of verbosity to allow in debug prints */ |
va009039 | 0:65f1469d6bfb | 127 | #define DEBUG_PRINT_VERBOSITY VERBOSITY_OFF |
va009039 | 0:65f1469d6bfb | 128 | |
va009039 | 0:65f1469d6bfb | 129 | /** Prints a debug message when the verbosity is within the set value */ |
va009039 | 0:65f1469d6bfb | 130 | #define C_DEBUG_PRINT(v, f, ...) \ |
va009039 | 0:65f1469d6bfb | 131 | do \ |
va009039 | 0:65f1469d6bfb | 132 | { \ |
va009039 | 0:65f1469d6bfb | 133 | if (DEBUG_PRINT_VERBOSITY >= (v)) \ |
va009039 | 0:65f1469d6bfb | 134 | { \ |
va009039 | 0:65f1469d6bfb | 135 | printf("PM_DEBUG: " f, ## __VA_ARGS__); \ |
va009039 | 0:65f1469d6bfb | 136 | } \ |
va009039 | 0:65f1469d6bfb | 137 | } \ |
va009039 | 0:65f1469d6bfb | 138 | while (0) |
va009039 | 0:65f1469d6bfb | 139 | |
va009039 | 0:65f1469d6bfb | 140 | #else |
va009039 | 0:65f1469d6bfb | 141 | #define C_DEBUG_PRINT(...) |
va009039 | 0:65f1469d6bfb | 142 | #endif |
va009039 | 0:65f1469d6bfb | 143 | |
va009039 | 0:65f1469d6bfb | 144 | |
va009039 | 0:65f1469d6bfb | 145 | /** |
va009039 | 0:65f1469d6bfb | 146 | * Return values for system functions |
va009039 | 0:65f1469d6bfb | 147 | * to report status, errors, exceptions, etc. |
va009039 | 0:65f1469d6bfb | 148 | * Normally, functions which use these values |
va009039 | 0:65f1469d6bfb | 149 | * should propagate the same return value |
va009039 | 0:65f1469d6bfb | 150 | * up the call tree to the interpreter. |
va009039 | 0:65f1469d6bfb | 151 | */ |
va009039 | 0:65f1469d6bfb | 152 | typedef enum PmReturn_e |
va009039 | 0:65f1469d6bfb | 153 | { |
va009039 | 0:65f1469d6bfb | 154 | /* general status return values */ |
va009039 | 0:65f1469d6bfb | 155 | PM_RET_OK = 0, /**< Everything is ok */ |
va009039 | 0:65f1469d6bfb | 156 | PM_RET_NO = 0xFF, /**< General "no result" */ |
va009039 | 0:65f1469d6bfb | 157 | PM_RET_ERR = 0xFE, /**< General failure */ |
va009039 | 0:65f1469d6bfb | 158 | PM_RET_STUB = 0xFD, /**< Return val for stub fxn */ |
va009039 | 0:65f1469d6bfb | 159 | PM_RET_ASSERT_FAIL = 0xFC, /**< Assertion failure */ |
va009039 | 0:65f1469d6bfb | 160 | PM_RET_FRAME_SWITCH = 0xFB, /**< Frame pointer was modified */ |
va009039 | 0:65f1469d6bfb | 161 | PM_RET_ALIGNMENT = 0xFA, /**< Heap is not aligned */ |
va009039 | 0:65f1469d6bfb | 162 | |
va009039 | 0:65f1469d6bfb | 163 | /* return vals that indicate an exception occured */ |
va009039 | 0:65f1469d6bfb | 164 | PM_RET_EX = 0xE0, /**< General exception */ |
va009039 | 0:65f1469d6bfb | 165 | PM_RET_EX_EXIT = 0xE1, /**< System exit */ |
va009039 | 0:65f1469d6bfb | 166 | PM_RET_EX_IO = 0xE2, /**< Input/output error */ |
va009039 | 0:65f1469d6bfb | 167 | PM_RET_EX_ZDIV = 0xE3, /**< Zero division error */ |
va009039 | 0:65f1469d6bfb | 168 | PM_RET_EX_ASSRT = 0xE4, /**< Assertion error */ |
va009039 | 0:65f1469d6bfb | 169 | PM_RET_EX_ATTR = 0xE5, /**< Attribute error */ |
va009039 | 0:65f1469d6bfb | 170 | PM_RET_EX_IMPRT = 0xE6, /**< Import error */ |
va009039 | 0:65f1469d6bfb | 171 | PM_RET_EX_INDX = 0xE7, /**< Index error */ |
va009039 | 0:65f1469d6bfb | 172 | PM_RET_EX_KEY = 0xE8, /**< Key error */ |
va009039 | 0:65f1469d6bfb | 173 | PM_RET_EX_MEM = 0xE9, /**< Memory error */ |
va009039 | 0:65f1469d6bfb | 174 | PM_RET_EX_NAME = 0xEA, /**< Name error */ |
va009039 | 0:65f1469d6bfb | 175 | PM_RET_EX_SYNTAX = 0xEB, /**< Syntax error */ |
va009039 | 0:65f1469d6bfb | 176 | PM_RET_EX_SYS = 0xEC, /**< System error */ |
va009039 | 0:65f1469d6bfb | 177 | PM_RET_EX_TYPE = 0xED, /**< Type error */ |
va009039 | 0:65f1469d6bfb | 178 | PM_RET_EX_VAL = 0xEE, /**< Value error */ |
va009039 | 0:65f1469d6bfb | 179 | PM_RET_EX_STOP = 0xEF, /**< Stop iteration */ |
va009039 | 0:65f1469d6bfb | 180 | PM_RET_EX_WARN = 0xF0, /**< Warning */ |
va009039 | 0:65f1469d6bfb | 181 | PM_RET_EX_OFLOW = 0xF1, /**< Overflow */ |
va009039 | 0:65f1469d6bfb | 182 | } PmReturn_t; |
va009039 | 0:65f1469d6bfb | 183 | |
va009039 | 0:65f1469d6bfb | 184 | |
va009039 | 0:65f1469d6bfb | 185 | extern volatile uint32_t pm_timerMsTicks; |
va009039 | 0:65f1469d6bfb | 186 | |
va009039 | 0:65f1469d6bfb | 187 | |
va009039 | 0:65f1469d6bfb | 188 | /* WARNING: The order of the following includes is critical */ |
va009039 | 0:65f1469d6bfb | 189 | #include "plat.h" |
va009039 | 0:65f1469d6bfb | 190 | #include "pmfeatures.h" |
va009039 | 0:65f1469d6bfb | 191 | #include "pmEmptyPlatformDefs.h" |
va009039 | 0:65f1469d6bfb | 192 | #include "sli.h" |
va009039 | 0:65f1469d6bfb | 193 | #include "mem.h" |
va009039 | 0:65f1469d6bfb | 194 | #include "obj.h" |
va009039 | 0:65f1469d6bfb | 195 | #include "seq.h" |
va009039 | 0:65f1469d6bfb | 196 | #include "tuple.h" |
va009039 | 0:65f1469d6bfb | 197 | #include "strobj.h" |
va009039 | 0:65f1469d6bfb | 198 | #include "heap.h" |
va009039 | 0:65f1469d6bfb | 199 | #include "int.h" |
va009039 | 0:65f1469d6bfb | 200 | #include "seglist.h" |
va009039 | 0:65f1469d6bfb | 201 | #include "list.h" |
va009039 | 0:65f1469d6bfb | 202 | #include "dict.h" |
va009039 | 0:65f1469d6bfb | 203 | #include "codeobj.h" |
va009039 | 0:65f1469d6bfb | 204 | #include "func.h" |
va009039 | 0:65f1469d6bfb | 205 | #include "module.h" |
va009039 | 0:65f1469d6bfb | 206 | #include "frame.h" |
va009039 | 0:65f1469d6bfb | 207 | #include "class.h" |
va009039 | 0:65f1469d6bfb | 208 | #include "interp.h" |
va009039 | 0:65f1469d6bfb | 209 | #include "img.h" |
va009039 | 0:65f1469d6bfb | 210 | #include "global.h" |
va009039 | 0:65f1469d6bfb | 211 | #include "thread.h" |
va009039 | 0:65f1469d6bfb | 212 | #include "float.h" |
va009039 | 0:65f1469d6bfb | 213 | #include "plat_interface.h" |
va009039 | 0:65f1469d6bfb | 214 | #include "bytearray.h" |
va009039 | 0:65f1469d6bfb | 215 | |
va009039 | 0:65f1469d6bfb | 216 | |
va009039 | 0:65f1469d6bfb | 217 | /** Pointer to a native function used for lookup tables in interp.c */ |
va009039 | 0:65f1469d6bfb | 218 | typedef PmReturn_t (* pPmNativeFxn_t)(pPmFrame_t *); |
va009039 | 0:65f1469d6bfb | 219 | extern pPmNativeFxn_t const std_nat_fxn_table[]; |
va009039 | 0:65f1469d6bfb | 220 | extern pPmNativeFxn_t const usr_nat_fxn_table[]; |
va009039 | 0:65f1469d6bfb | 221 | |
va009039 | 0:65f1469d6bfb | 222 | |
va009039 | 0:65f1469d6bfb | 223 | /** |
va009039 | 0:65f1469d6bfb | 224 | * Initializes the PyMite virtual machine and indexes the user's application |
va009039 | 0:65f1469d6bfb | 225 | * image. The VM heap and globals are reset. The argument, pusrimg, may be |
va009039 | 0:65f1469d6bfb | 226 | * null for interactive sessions. |
va009039 | 0:65f1469d6bfb | 227 | * |
va009039 | 0:65f1469d6bfb | 228 | * @param heap_base The address where the contiguous heap begins |
va009039 | 0:65f1469d6bfb | 229 | * @param heap_size The size in bytes (octets) of the given heap. |
va009039 | 0:65f1469d6bfb | 230 | * Must be a multiple of four. |
va009039 | 0:65f1469d6bfb | 231 | * @param memspace Memory space in which the user image is located |
va009039 | 0:65f1469d6bfb | 232 | * @param pusrimg Address of the user image in the memory space |
va009039 | 0:65f1469d6bfb | 233 | * @return Return status |
va009039 | 0:65f1469d6bfb | 234 | */ |
va009039 | 0:65f1469d6bfb | 235 | PmReturn_t pm_init(uint8_t *heap_base, uint32_t heap_size, |
va009039 | 0:65f1469d6bfb | 236 | PmMemSpace_t memspace, uint8_t const * const pusrimg); |
va009039 | 0:65f1469d6bfb | 237 | |
va009039 | 0:65f1469d6bfb | 238 | /** |
va009039 | 0:65f1469d6bfb | 239 | * Executes the named module |
va009039 | 0:65f1469d6bfb | 240 | * |
va009039 | 0:65f1469d6bfb | 241 | * @param modstr Name of module to run |
va009039 | 0:65f1469d6bfb | 242 | * @return Return status |
va009039 | 0:65f1469d6bfb | 243 | */ |
va009039 | 0:65f1469d6bfb | 244 | PmReturn_t pm_run(uint8_t const *modstr); |
va009039 | 0:65f1469d6bfb | 245 | |
va009039 | 0:65f1469d6bfb | 246 | /** |
va009039 | 0:65f1469d6bfb | 247 | * Needs to be called periodically by the host program. |
va009039 | 0:65f1469d6bfb | 248 | * For the desktop target, it is periodically called using a signal. |
va009039 | 0:65f1469d6bfb | 249 | * For embedded targets, it needs to be called periodically. It should |
va009039 | 0:65f1469d6bfb | 250 | * be called from a timer interrupt. |
va009039 | 0:65f1469d6bfb | 251 | * |
va009039 | 0:65f1469d6bfb | 252 | * @param usecsSinceLastCall Microseconds (not less than those) that passed |
va009039 | 0:65f1469d6bfb | 253 | * since last call. This must be <64535. |
va009039 | 0:65f1469d6bfb | 254 | * @return Return status |
va009039 | 0:65f1469d6bfb | 255 | */ |
va009039 | 0:65f1469d6bfb | 256 | PmReturn_t pm_vmPeriodic(uint16_t usecsSinceLastCall); |
va009039 | 0:65f1469d6bfb | 257 | |
va009039 | 0:65f1469d6bfb | 258 | #ifdef __cplusplus |
va009039 | 0:65f1469d6bfb | 259 | } |
va009039 | 0:65f1469d6bfb | 260 | #endif |
va009039 | 0:65f1469d6bfb | 261 | |
va009039 | 0:65f1469d6bfb | 262 | #endif /* __PM_H__ */ |