|
@@ -474,9 +474,7 @@ static addr16_t buff = {(uint8_t *)(RAMSTART)};
|
|
|
#endif
|
|
|
#endif
|
|
|
|
|
|
-#if (SPM_PAGESIZE <= save_vect_num)
|
|
|
-#error Save vector not in the same page as reset!
|
|
|
-#endif
|
|
|
+
|
|
|
#if FLASHEND > 8192
|
|
|
|
|
|
|
|
@@ -488,6 +486,7 @@ static addr16_t buff = {(uint8_t *)(RAMSTART)};
|
|
|
#define appstart_vec (save_vect_num*2)
|
|
|
#else
|
|
|
|
|
|
+
|
|
|
#define rstVect0 0
|
|
|
#define rstVect1 1
|
|
|
#define saveVect0 (save_vect_num*2)
|
|
@@ -787,18 +786,30 @@ int main(void) {
|
|
|
|
|
|
rstVect0_sav = buff.bptr[rstVect0];
|
|
|
rstVect1_sav = buff.bptr[rstVect1];
|
|
|
- saveVect0_sav = buff.bptr[saveVect0];
|
|
|
- saveVect1_sav = buff.bptr[saveVect1];
|
|
|
|
|
|
-
|
|
|
- buff.bptr[saveVect0] = rstVect0_sav;
|
|
|
- buff.bptr[saveVect1] = rstVect1_sav;
|
|
|
|
|
|
|
|
|
|
|
|
buff.bptr[rstVect0] = ((uint16_t)main) & 0xFF;
|
|
|
buff.bptr[rstVect1] = ((uint16_t)main) >> 8;
|
|
|
- }
|
|
|
+#if (save_vect_num>SPM_PAGESIZE/4)
|
|
|
+ } else if (address.word == (SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/4)))) {
|
|
|
+ saveVect0_sav = buff.bptr[saveVect0-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/4)))];
|
|
|
+ saveVect1_sav = buff.bptr[saveVect1-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/4)))];
|
|
|
+
|
|
|
+
|
|
|
+ buff.bptr[saveVect0-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/4)))] = rstVect0_sav;
|
|
|
+ buff.bptr[saveVect1-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/4)))] = rstVect1_sav;
|
|
|
+ }
|
|
|
+#else
|
|
|
+ saveVect0_sav = buff.bptr[saveVect0];
|
|
|
+ saveVect1_sav = buff.bptr[saveVect1];
|
|
|
+
|
|
|
+
|
|
|
+ buff.bptr[saveVect0] = rstVect0_sav;
|
|
|
+ buff.bptr[saveVect1] = rstVect1_sav;
|
|
|
+ }
|
|
|
+#endif
|
|
|
|
|
|
#else
|
|
|
|
|
@@ -817,19 +828,19 @@ int main(void) {
|
|
|
buff.bptr[0] = vect.bytes[0];
|
|
|
buff.bptr[1] = vect.bytes[1] | 0xC0;
|
|
|
#if (save_vect_num > SPM_PAGESIZE/2)
|
|
|
-} else if (address.word == SPM_PAGESIZE) {
|
|
|
+} else if (address.word == (SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/2)))) {
|
|
|
|
|
|
|
|
|
|
|
|
addr16_t vect;
|
|
|
vect.bytes[0] = rstVect0_sav;
|
|
|
vect.bytes[1] = rstVect1_sav;
|
|
|
- saveVect0_sav = buff.bptr[saveVect0-SPM_PAGESIZE];
|
|
|
- saveVect1_sav = buff.bptr[saveVect1-SPM_PAGESIZE];
|
|
|
+ saveVect0_sav = buff.bptr[saveVect0-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/2)))];
|
|
|
+ saveVect1_sav = buff.bptr[saveVect1-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/2)))];
|
|
|
vect.word = (vect.word-save_vect_num);
|
|
|
|
|
|
- buff.bptr[saveVect0-SPM_PAGESIZE] = vect.bytes[0];
|
|
|
- buff.bptr[saveVect1-SPM_PAGESIZE] = (vect.bytes[1] & 0x0F)| 0xC0;
|
|
|
+ buff.bptr[saveVect0-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/2)))] = vect.bytes[0];
|
|
|
+ buff.bptr[saveVect1-(SPM_PAGESIZE*(save_vect_num/(SPM_PAGESIZE/2)))] = (vect.bytes[1] & 0x0F)| 0xC0;
|
|
|
}
|
|
|
|
|
|
#else
|
|
@@ -1008,6 +1019,7 @@ uint8_t getch(void) {
|
|
|
#if UART_B_VALUE > 255
|
|
|
#error Baud rate too slow for soft UART
|
|
|
#endif
|
|
|
+
|
|
|
#if UART_B_VALUE < 6
|
|
|
|
|
|
|