⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 system.c

📁 编译后直接运行的MP3播放器全部C语言源代码 一个包含FAT文件系统、系统引导 Boot、FLASH Driver等内容的
💻 C
📖 第 1 页 / 共 2 页
字号:
/*************************************************************************** *             __________               __   ___. *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___ *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  / *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  < *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \ *                     \/            \/     \/    \/            \/ * $Id: system.c,v 1.23 2004/03/02 11:32:59 linusnielsen Exp $ * * Copyright (C) 2002 by Alan Korr * * All files in this archive are subject to the GNU General Public License. * See the file COPYING in the source tree root for full license agreement. * * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY * KIND, either express or implied. * ****************************************************************************/#include <stdio.h>#include "config.h"#include "lcd.h"#include "font.h"#include "led.h"#include "system.h"#include "rolo.h"#define default_interrupt(name,number) \  extern __attribute__((weak,alias("UIE" #number))) void name (void); void UIE##number (void)#define reserve_interrupt(number) \  void UIE##number (void)extern void reset_pc (void);extern void reset_sp (void);static const char* irqname[] = {    "", "", "", "", "IllInstr", "", "IllSltIn","","",    "CPUAdrEr", "DMAAdrEr", "NMI", "UserBrk",    "","","","","","","","","","","","","","","","","","","",    "Trap32","Trap33","Trap34","Trap35","Trap36","Trap37","Trap38","Trap39",    "Trap40","Trap41","Trap42","Trap43","Trap44","Trap45","Trap46","Trap47",    "Trap48","Trap49","Trap50","Trap51","Trap52","Trap53","Trap54","Trap55",    "Trap56","Trap57","Trap58","Trap59","Trap60","Trap61","Trap62","Trap63",    "Irq0","Irq1","Irq2","Irq3","Irq4","Irq5","Irq6","Irq7",    "Dma0","","Dma1","","Dma2","","Dma3","",    "IMIA0","IMIB0","OVI0","", "IMIA1","IMIB1","OVI1","",    "IMIA2","IMIB2","OVI2","", "IMIA3","IMIB3","OVI3","",    "IMIA4","IMIB4","OVI4","",    "Ser0Err","Ser0Rx","Ser0Tx","Ser0TE",    "Ser1Err","Ser1Rx","Ser1Tx","Ser1TE",    "ParityEr","A/D conv","","","Watchdog","DRAMRefr"};reserve_interrupt (          0);reserve_interrupt (          1);reserve_interrupt (          2);reserve_interrupt (          3);default_interrupt (GII,      4);reserve_interrupt (          5);default_interrupt (ISI,      6);reserve_interrupt (          7);reserve_interrupt (          8);default_interrupt (CPUAE,    9);default_interrupt (DMAAE,   10);default_interrupt (NMI,     11);default_interrupt (UB,      12);reserve_interrupt (         13);reserve_interrupt (         14);reserve_interrupt (         15);reserve_interrupt (         16); /* TCB #0 */reserve_interrupt (         17); /* TCB #1 */reserve_interrupt (         18); /* TCB #2 */reserve_interrupt (         19); /* TCB #3 */reserve_interrupt (         20); /* TCB #4 */reserve_interrupt (         21); /* TCB #5 */reserve_interrupt (         22); /* TCB #6 */reserve_interrupt (         23); /* TCB #7 */reserve_interrupt (         24); /* TCB #8 */reserve_interrupt (         25); /* TCB #9 */reserve_interrupt (         26); /* TCB #10 */reserve_interrupt (         27); /* TCB #11 */reserve_interrupt (         28); /* TCB #12 */reserve_interrupt (         29); /* TCB #13 */reserve_interrupt (         30); /* TCB #14 */reserve_interrupt (         31); /* TCB #15 */default_interrupt (TRAPA32, 32);default_interrupt (TRAPA33, 33);default_interrupt (TRAPA34, 34);default_interrupt (TRAPA35, 35);default_interrupt (TRAPA36, 36);default_interrupt (TRAPA37, 37);default_interrupt (TRAPA38, 38);default_interrupt (TRAPA39, 39);default_interrupt (TRAPA40, 40);default_interrupt (TRAPA41, 41);default_interrupt (TRAPA42, 42);default_interrupt (TRAPA43, 43);default_interrupt (TRAPA44, 44);default_interrupt (TRAPA45, 45);default_interrupt (TRAPA46, 46);default_interrupt (TRAPA47, 47);default_interrupt (TRAPA48, 48);default_interrupt (TRAPA49, 49);default_interrupt (TRAPA50, 50);default_interrupt (TRAPA51, 51);default_interrupt (TRAPA52, 52);default_interrupt (TRAPA53, 53);default_interrupt (TRAPA54, 54);default_interrupt (TRAPA55, 55);default_interrupt (TRAPA56, 56);default_interrupt (TRAPA57, 57);default_interrupt (TRAPA58, 58);default_interrupt (TRAPA59, 59);default_interrupt (TRAPA60, 60);default_interrupt (TRAPA61, 61);default_interrupt (TRAPA62, 62);default_interrupt (TRAPA63, 63);default_interrupt (IRQ0,    64);default_interrupt (IRQ1,    65);default_interrupt (IRQ2,    66);default_interrupt (IRQ3,    67);default_interrupt (IRQ4,    68);default_interrupt (IRQ5,    69);default_interrupt (IRQ6,    70);default_interrupt (IRQ7,    71);default_interrupt (DEI0,    72);reserve_interrupt (         73);default_interrupt (DEI1,    74);reserve_interrupt (         75);default_interrupt (DEI2,    76);reserve_interrupt (         77);default_interrupt (DEI3,    78);reserve_interrupt (         79);default_interrupt (IMIA0,   80);default_interrupt (IMIB0,   81);default_interrupt (OVI0,    82);reserve_interrupt (         83);default_interrupt (IMIA1,   84);default_interrupt (IMIB1,   85);default_interrupt (OVI1,    86);reserve_interrupt (         87);default_interrupt (IMIA2,   88);default_interrupt (IMIB2,   89);default_interrupt (OVI2,    90);reserve_interrupt (         91);default_interrupt (IMIA3,   92);default_interrupt (IMIB3,   93);default_interrupt (OVI3,    94);reserve_interrupt (         95);default_interrupt (IMIA4,   96);default_interrupt (IMIB4,   97);default_interrupt (OVI4,    98);reserve_interrupt (         99);default_interrupt (REI0,   100);default_interrupt (RXI0,   101);default_interrupt (TXI0,   102);default_interrupt (TEI0,   103);default_interrupt (REI1,   104);default_interrupt (RXI1,   105);default_interrupt (TXI1,   106);default_interrupt (TEI1,   107);reserve_interrupt (        108);default_interrupt (ADITI,  109);/* reset vectors are handled in crt0.S */void (*vbr[]) (void) __attribute__ ((section (".vectors"))) = {    /*** 4 General Illegal Instruction ***/    GII,    /*** 5 Reserved ***/    UIE5,    /*** 6 Illegal Slot Instruction ***/    ISI,    /*** 7-8 Reserved ***/    UIE7,UIE8,    /*** 9 CPU Address Error ***/    CPUAE,    /*** 10 DMA Address Error ***/    DMAAE,    /*** 11 NMI ***/    NMI,    /*** 12 User Break ***/    UB,    /*** 13-31 Reserved ***/    UIE13,UIE14,UIE15,UIE16,UIE17,UIE18,UIE19,UIE20,UIE21,UIE22,UIE23,UIE24,UIE25,UIE26,UIE27,UIE28,UIE29,UIE30,UIE31,      /*** 32-63 TRAPA #20...#3F ***/    TRAPA32,TRAPA33,TRAPA34,TRAPA35,TRAPA36,TRAPA37,TRAPA38,TRAPA39,TRAPA40,TRAPA41,TRAPA42,TRAPA43,TRAPA44,TRAPA45,TRAPA46,TRAPA47,TRAPA48,TRAPA49,TRAPA50,TRAPA51,TRAPA52,TRAPA53,TRAPA54,TRAPA55,TRAPA56,TRAPA57,TRAPA58,TRAPA59,TRAPA60,TRAPA61,TRAPA62,TRAPA63,      /*** 64-71 IRQ0-7 ***/     IRQ0,IRQ1,IRQ2,IRQ3,IRQ4,IRQ5,IRQ6,IRQ7,      /*** 72 DMAC0 ***/       DEI0,        /*** 73 Reserved ***/    UIE73,    /*** 74 DMAC1 ***/     DEI1,        /*** 75 Reserved ***/    UIE75,    /*** 76 DMAC2 ***/     DEI2,        /*** 77 Reserved ***/    UIE77,    /*** 78 DMAC3 ***/     DEI3,        /*** 79 Reserved ***/    UIE79,       /*** 80-82 ITU0 ***/      IMIA0,IMIB0,OVI0,        /*** 83 Reserved ***/    UIE83, 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -