久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区

以文本方式查看主題

-  曙海教育集團論壇  (http://www.rfoamep.cn/bbs/index.asp)
--  嵌入式硬件技術討論專區  (http://www.rfoamep.cn/bbs/list.asp?boardid=15)
----  net_config_t數據結構:  (http://www.rfoamep.cn/bbs/dispbbs.asp?boardid=15&id=1479)

--  作者:wangxinxin
--  發布時間:2010-11-19 9:09:17
--  net_config_t數據結構:
 SkyEye支持網絡模擬,目前描述網絡配置的數據結構是net_config_t,它的具體內容如下:

typedef struct {
   int state;
   unsigned char macaddr[6];
   unsigned char  hostip[4];
   int ethmod;
   int fd;                    
   int hubindex;
   int (*net_init)(int index, unsigned char *macaddr, unsigned char *hostip);
   unsigned char (*net_output)(int if_fd, ARMul_State *state,\\
                   unsigned char startpage,unsigned short packet_len);
   void  (*net_input)(int if_fd, ARMul_State *state);
}net_config_t;

     其中各個field的含義描述如下:
●state:是一個布爾變量,為1表示網絡芯片工作,為0表示網絡芯片不工作
●macaddr:用來保存網絡芯片的mac地址
●hostip:用來保存主機上與SkyEye進行網絡通信所用的IP地址


●ethmod:表示與主機的模擬網絡交互的方式,目前定義的交互方式有:
#define NET_MOD_LINUX 0
#define NET_MOD_TUNTAP 1
#define NET_MOD_WIN 2
#define NET_MOD_VNET 3
目前可以使用的兩種方式有 NET_MOD_VNET(與SkyEye提供的vnet.o內核模塊進行網絡交互)和 NET_MOD_TUNTAP(與linux的tun.on內核模塊進行網絡交互)。
●fd:表示SkyEye用于與主機進行網絡交互的設備文件描述符
●hubindex:用于NET_MOD_VNET方式,表示所處的是第幾個虛擬hub網段。如果它的值是i,則處于第i個hub網段中。
●net_init/net_input/net_output:這三個函數與具體的模擬網絡交互方式有關,分別完成初始化操作和與主機網絡的輸入輸出操作。相關的實現在文件skyeye_net_*.c中。
    有關8019AS模擬芯片(NE2000兼容)的具體配置與實現位于文件skyeye-ne2k.[ch]中。

6、ARMul_State數據結構:
    上面講述的是與SkyEye的硬件配置相關的數據結構,可以理解為一種靜態硬件配置的數據結構,這些數據結構中的域基本不隨著SkyEye模擬硬件的運行而改變。而ARMul_State描述的是一種動態硬件配置的數據結構,它保存了隨著SkyEye模擬硬件的運行而時刻改變的硬件數據。

ARMul_State中的域數量繁多,大體分為:
與CPU模擬相關的域、與協處理器模擬相關的域、與內存和MMU/CACHE相關的域
、與統計相關的域、與具體開發板相關的io部分。


這里只描述其中關鍵的部分:
●與CPU模擬相關的域 :
ARMword Reg[16]:CPU當前模式下的寄存器值
ARMword RegBank[7][16]:CPU所有七種模式下的寄存器值
ARMword Cpsr:CPU的當前程序狀態寄存器
ARMword Spsr[7]:CPU所有七種模式下的程序狀態保存寄存器
ARMdword Accumulator:40bit的累加寄存器,目前用于xscale體系結構中
ARMword NFlag, ZFlag, CFlag, VFlag, IFFlags, Sflag,TFlag:各種狀態位
ARMword Bank:CPU對應模式寄存器組的索引值
ARMword Mode:CPU模式索引值
ARMword instr, pc:pc是目前正在執行的程序指針,instr是pc所指地址的內容
ARMword loaded, decoded:loaded是正在加載的指令,decoded是正在解碼的指令
unsigned NfiqSig:FIQ信號
unsigned NirqSig:IRQ信號


●    與協處理器模擬相關的域:
ARMul_CPInits *CPInit[16]:16個協處理器的初始化函數
ARMul_CPExits *CPExit[16]:16個協處理器的退出函數
ARMul_LDCs *LDC[16]:16個協處理器的LDC指令函數
ARMul_STCs *STC[16]:16個協處理器的STC指令函數
ARMul_MRCs *MRC[16]:16個協處理器的MRC指令函數
ARMul_MCRs *MCR[16]:16個協處理器的MCR指令函數
ARMul_CDPs *CDP[16]:16個協處理器的CDP指令函數
ARMul_CPReads *CPRead[16]:16個協處理器的讀CP寄存器函數
ARMul_CPWrites *CPWrite[16]:16個協處理器的寫CP寄存器函數
unsigned char *CPData[16]:16個協處理器的數據指針
ARMword CP14R0_CCD:在xscale體系結構的CP14協處理器中,用于統計時鐘周期


●與內存和MMU/CACHE相關的域:
mmu_state_t mmu:mmu/cache的數據結構,在armmmu.h中定義,詳解請參考"SkyEye的MMU/CACHE和Memory模擬實現"一節
mem_state_t mem:memory的數據結構,在armmem.h中定義,詳解請參考"SkyEye的MMU/CACHE和Memory模擬實現"一節
與統計相關的域
unsigned long NumScycles, NumNcycles, NumIcycles, NumCcycles, NumFcycles:用于統計不同狀態下的周期數
unsigned long NumInstrs:當前執行的指令數
其它與特定CPU和開發板相關的各種io寄存器的定義放到了各個與開發板相關的文件中,如skyeye_mach_at91/ep7312/pxa/sa.c等處,詳解請參考"SkyEye的開發板IO模擬實現"。

●與具體開發板相關的io部分:
ARMul_io mach_io;
其中ARMul_io的結構目前為

struct ARMul_io
{
ARMword *instr; //to display the current interrupt state
ARMword *net_flag;//to judge if network is enabled
ARMword *net_int; //netcard interrupt

ARMword *lcd_is_enable;       //turn lcd on?
ARMword *lcd_addr_begin;   //the begining display mem addr of lcd
ARMword *lcd_addr_end;     //the end      display mem addr of lcd
};

instr:是記錄當前的中斷狀態
net_flag:判斷網絡選項是否打開
net_int:用來記錄網絡中斷號
lcd_is_enable:來記錄LCD是否使能
lcd_addr_begin:記錄lcd顯存的起始位置
lcd_addr_end:記錄顯存的結束位置

7、SkyEye邏輯執行流程:
    了解SkEye的總體邏輯執行流程,對了解硬件的體系結構和軟件/硬件的接口有較大幫助。從總體上,可把SkyEye邏輯執行流程按執行的時間順序劃分為兩個階段:
1、SkyEye加載與配置處理過程
2、SkyEye模擬執行過程

    第一階段為第二階段的正常執行做了充分的準備,具體的執行內容包括:
●讀入帶調試信息的操作系統執行文件(由GDB完成)
●根據配置文件skyeye.conf的信息配置模擬硬件
●如果skyeye.conf中存在binary image格式文件,加載這些文件
●根據操作系統執行文件的內容加載調試信息(由GDB完成)
●根據操作系統執行文件信息加載執行文件中的代碼段和數據段等(由GDB完成)
●執行相關模擬硬件的初始化函數
    其中總的初始化函數是位于wrapper.c中的init函數,它調用如下函數完成整個模擬硬件的初始化工作:

ARMul_EmulateInit:初始化與執行機器指令相關的數據ARMul_ImmedTable和ARMul_BitList
ARMul_NewState:初始化結構為ARMul_State的全局變量state
skyeye_option_init:初始化全局變量skyeye_config
skyeye_read_config:讀取配置文件skyeye.conf并根據配置文件進行相關配置
nic_init:根據配置文件信息配置網絡模擬環境
skyeye_config.mach->mach_init(state, skyeye_config.mach):根據配置文件信息配置CPU和開發板的相關I/O函數
ARMul_Reset(state):進一步初始化全局變量state,并根據配置文件信息配置MMU/CACHE和memory
io_reset:初始化特定CPU和開發板的IO寄存器

第二階段根據特定硬件的配置描述,開始執行特定硬件模擬處理。整個過程圍繞CPU執行指令展開,根據模擬硬件可分為如下幾個階段:

●CPU執行三級流水線處理,即取指令、譯碼、執行指令,主要處理集中在armemu.c中的ARMul_Emulate32/26函數。
●在執行指令過程中,如果有中斷產生,CPU調整運行模式,并改變指令指向中斷向量起始地址,主要處理集中在arminit.c中的函數ARMul_Abort函數、armemu.c中的ARMul_Emulate32/26函數。
●在執行指令過程中,如果指令是協處理器指令,則把指令轉交給協處理器模擬模塊進行進一步處理,主要處理集中在文件armcopro.c、xscale_copro.c等文件中。
●在執行指令過程中,如果發現指令是訪問內存/IO的指令,則根據SkyEye模擬的特定CPU是否有MMU/CACHE分別進行處理:
    如果CPU有MMU/CACHE,則進入MMU/CACHE模擬模塊,如果還需要內存訪問,則進入memory模擬模塊處理。如果訪問地址屬于IO地址空間,則轉到特定CPU和開發板的IO模擬模塊處理。
    如果CPU沒有MMU/CACHE,則直接進入memory模擬模塊處理。如果訪問地址屬于IO地址空間,則轉到特定CPU和開發板的IO模擬模塊處理。
    處理訪問內存/IO的指令的相關內容集中在armvirt.c;與MMU/CACHE處理、read/write buffer(用于StrongARM和XScale體系結構的模擬)處理相關的文件包括armmmu.[ch]、mmu/*.[ch];與訪問memory模擬有關的內容主要集中在armmem.[ch]中。
    如果要執行IO地址訪問,這具體的處理過程由特定CPU和開發板IO模擬模塊中的read/write_byte/halfword/word函數處理。
為了模擬外設的執行,在執行指令過程的每一個周期,會執行一個io_do_cycle函數,它會調用特定CPU和開發板的IO模擬模塊中的*_io_do_cycle函數,完成對時鐘、網絡輸入輸出、UART輸入輸出等的處理,并根據條件產生中斷信號。
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
91在线码无精品| 婷婷一区二区三区| 精品国产凹凸成av人导航| 欧美日韩视频不卡| 6080日韩午夜伦伦午夜伦| 91麻豆精品国产91久久久更新时间| 7777女厕盗摄久久久| 久久久久一区二区三区四区| 日本一区二区三区久久久久久久久不 | 99re成人精品视频| 国产一区二区不卡视频| 日韩午夜视频在线观看| 欧美精品免费视频| 国产嫩草影院久久久久| 午夜av区久久| 成人免费观看视频| 久久久久久久久久久久久久一区 | 精品婷婷色一区二区三区蜜桃| 视频一区视频二区视频| 欧美一级高清大全免费观看| 国产精品情趣视频| 免费成人你懂的| 91在线精品观看| 中文一区一区三区免费| 精品国产sm最大网站免费看| 亚洲激情图片qvod| 国产91精品一区二区麻豆网站| 不卡视频一区二区三区| 一区高清视频| 久久久久久久综合| 青青草视频一区| 国产v亚洲v天堂无码| 在线看视频不卡| 久久精品网站免费观看| 日韩中文字幕一区二区三区| www.久久久久久久久| 一区二区三区四区五区视频| 久久毛片高清国产| 奇米888四色在线精品| 成人欧美一区二区| 欧美日韩情趣电影| 亚洲欧美激情一区二区| 成人性视频免费网站| 日本一区美女| 国产偷v国产偷v亚洲高清| 麻豆精品国产91久久久久久| 国产精品伊人日日| 日韩一级视频免费观看在线| 亚洲福利一二三区| 国产精品免费一区二区三区观看| 欧美三级韩国三级日本一级| 依依成人精品视频| 99精品欧美一区二区三区| 欧美精品九九99久久| 亚洲午夜影视影院在线观看| 欧美综合天天夜夜久久| 国产蜜臀97一区二区三区 | 国产一区二区不卡在线| 日韩免费一区二区三区| 国产喂奶挤奶一区二区三区| 久久激情综合网| 视频在线99| 一区二区中文视频| 99久久久精品| 欧美日韩精品免费观看视频 | 亚洲国产成人自拍| 国产99一区视频免费| 在线视频欧美一区| 国产精品久久影院| 91麻豆国产自产在线观看| 欧美日韩色一区| 毛片一区二区三区| 在线一区日本视频| 亚洲线精品一区二区三区| 精品久久久久久乱码天堂| 久久久久久麻豆| 成人av资源在线观看| 8v天堂国产在线一区二区| 美国十次综合导航| 在线免费观看视频一区| 日韩激情视频在线观看| 相泽南亚洲一区二区在线播放| 亚洲女同女同女同女同女同69| 国产精品大全| 亚洲国产成人午夜在线一区| 91视频免费在线观看| 久久久久久综合| 99r国产精品| 久久久久久久久久看片| 91视频91自| 欧美激情一区二区在线| 51国偷自产一区二区三区| 精品国产乱码久久久久久蜜臀| 成人免费看视频| 精品少妇一区二区三区日产乱码 | 欧美日韩一级二级三级| 久草热8精品视频在线观看| 日本道色综合久久| 韩国精品主播一区二区在线观看 | 欧美日韩国产在线观看| 国产一区二区三区免费| 日韩欧美激情四射| www.成人网.com| 欧美经典一区二区| 久久国产精品高清| 亚洲大片一区二区三区| 在线国产亚洲欧美| 国产精品夜夜嗨| 精品伦理精品一区| 国产亚洲欧美一区二区| 一区二区欧美在线观看| 在线视频中文字幕一区二区| 极品少妇xxxx精品少妇| 欧美成人精品福利| 精品国产综合久久| 日韩电影在线免费观看| 7777精品久久久大香线蕉| 99视频一区二区| 亚洲精品中文在线| 欧美视频你懂的| 91蜜桃传媒精品久久久一区二区| 亚洲日本在线看| 在线观看免费视频综合| av在线不卡电影| 亚洲美女一区二区三区| 欧洲精品视频在线观看| 97精品国产露脸对白| 亚洲一区二区偷拍精品| 在线不卡中文字幕| 国产精品久久久久久久天堂第1集 国产精品久久久久久久免费大片 国产精品久久久久久久久婷婷 | www 成人av com| 亚洲高清在线视频| 777午夜精品免费视频| 国产高清自拍99| 日韩黄色小视频| 久久久久久久久99精品| 亚洲精品中字| 99久久精品国产导航| 亚洲成人动漫一区| 精品国产乱码久久久久久久久| 免费一区二区三区| 国产老肥熟一区二区三区| 18欧美亚洲精品| 欧美日韩久久久久久| 国产综合第一页| 国产中文字幕一区| 亚洲精品高清在线| 日韩精品在线看片z| 日产精品久久久一区二区| 风流少妇一区二区| 性欧美大战久久久久久久久| 精品少妇一区二区三区日产乱码 | 一区精品在线| 999国内精品视频在线| 美国十次综合导航| 亚洲视频中文字幕| 欧美大片一区二区三区| 色婷婷综合久久久中文一区二区| 成人午夜电影免费在线观看| 国产一区中文字幕| 午夜伊人狠狠久久| 亚洲国产高清不卡| 717成人午夜免费福利电影| 日本一区二区久久精品| 99r国产精品视频| 国产一区二区三区日韩| 亚洲线精品一区二区三区| 亚洲国产精品成人综合色在线婷婷| 欧美在线观看你懂的| 日韩精品另类天天更新| 国产精品入口免费| 99视频国产精品| 国产伦理精品不卡| 免费在线视频一区| 亚洲自拍偷拍麻豆| 国产精品传媒视频| 久久精品一区二区三区不卡 | 亚洲精品久久久蜜桃| 国产亚洲欧洲997久久综合| 91精品福利在线一区二区三区| 日韩免费毛片| 免费亚洲一区二区| 国产伦视频一区二区三区| 99久久亚洲一区二区三区青草| 国产一区91精品张津瑜| 美国欧美日韩国产在线播放| 午夜精品一区在线观看| 一区二区三区精品在线观看| 1区2区3区欧美| 国产精品色婷婷久久58| 久久久不卡影院| 久久久久久**毛片大全| 精品久久久三级丝袜| 日韩午夜av电影| 日韩你懂的电影在线观看| 日韩一级二级三级| 欧美xxxx在线观看| 精品粉嫩超白一线天av| 2024国产精品| 国产日产精品一区|