📄 microblaze.c
字号:
/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * * 惧淡螟侯涪荚は·笆布の (1)×(4) の掘凤か·Free Software Foundation * によって给山されている GNU General Public License の Version 2 に淡 * 揭されている掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェア * を猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを·ライブラリ妨及など·戮のソフトウェア倡券に蝗 * 脱できる妨で浩芹邵する眷圭には·浩芹邵に燃うドキュメント∈网脱 * 荚マニュアルなど∷に·惧淡の螟侯涪山绩·この网脱掘凤および布淡 * の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを·怠达に寥み哈むなど·戮のソフトウェア倡券に蝗 * 脱できない妨で浩芹邵する眷圭には·肌のいずれかの掘凤を塔たすこ * とˉ * (a) 浩芹邵に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟 * 侯涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 浩芹邵の妨轮を·侍に年める数恕によって·TOPPERSプロジェクトに * 鼠桂することˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚およびTOPPERSプロジェクトを倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚お * よびTOPPERSプロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ * * @(#) $Id: microblaze.c,v 1.8 2003/12/11 04:52:44 honda Exp $ *//* * Microblaze 筛洁ペリフェラル脱ドライバ */#include <s_services.h>#include <microblaze.h>/* * UART Lite脱 词白ドライバ *//* * シリアルI/Oポ〖ト介袋步ブロック */const SIOPINIB siopinib_table[TNUM_SIOP] = {{}};/* * シリアルI/Oポ〖ト瓷妄ブロックのエリア */SIOPCB siopcb_table[TNUM_SIOP];/* * シリアルI/Oポ〖トIDから瓷妄ブロックを艰り叫すためのマクロ */#define INDEX_SIOP(siopid) ((UINT)((siopid) - 1))#define get_siopcb(siopid) (&(siopcb_table[INDEX_SIOP(siopid)]))Inline voiduart_ena_int(void){ sil_wrw_mem((VP)UARTLITE_CTREG, sil_rew_mem((VP)UARTLITE_CTREG) | UARTLITE_ENABLE_INTR);}Inline voiduart_dis_int(void){ sil_wrw_mem((VP)UARTLITE_CTREG, sil_rew_mem((VP)UARTLITE_CTREG) & ~UARTLITE_ENABLE_INTR);}/* * 矢机を减慨したか? */Inline BOOLuart_getready(SIOPCB *siopcb){ return((sil_rew_mem((VP)UARTLITE_SRREG) & UARTLITE_RX_FIFO_VALID_DATA) != 0);}/* * 矢机を流慨できるか? */Inline BOOLuart_putready(SIOPCB *siopcb){ return((sil_rew_mem((VP)UARTLITE_SRREG) & UARTLITE_TX_FIFO_FULL) == 0);}/* * 减慨した矢机の艰り叫し */Inline UBuart_getchar(SIOPCB *siopcb){ return((UB)sil_rew_mem((VP)UARTLITE_RXREG));}/* * 流慨する矢机の今き哈み */Inline voiduart_putchar(SIOPCB *siopcb, UB c){ sil_wrw_mem((VP)UARTLITE_TXREG, c);}/* * 流慨扩告簇眶 * UART Lite には流慨充哈みを改侍に敦贿钓材する怠墙はない * そのため·流慨姜位箕には涩ず1搀充哈みが掐る *//* * 流慨充哈み钓材 */Inline voiduart_enable_send(SIOPCB *siopcb){ }/* * 流慨充哈み敦贿 */Inline voiduart_disable_send(SIOPCB *siopcb){}/* * SIOドライバの介袋步ル〖チン * 1ポ〖トしかないため·あまり罢蹋はない */voiduart_initialize(){ SIOPCB *siopcb; UINT i; /* * シリアルI/Oポ〖ト瓷妄ブロックの介袋步 */ for (siopcb = siopcb_table, i = 0; i < TNUM_SIOP; siopcb++, i++) { siopcb->siopinib = &(siopinib_table[i]); siopcb->openflag = FALSE; siopcb->sendflag = FALSE; }}SIOPCB *uart_opn_por(ID siopid, VP_INT exinf){ SIOPCB *siopcb; const SIOPINIB *siopinib; siopcb = get_siopcb(siopid); siopinib = siopcb->siopinib; /* * 流减慨バッファクリア */ sil_wrw_mem((VP)UARTLITE_CTREG, UARTLITE_RST_RX_FIFO | UARTLITE_RST_TX_FIFO | UARTLITE_ENABLE_INTR); // sil_wrw_mem((VP)UARTLITE_CTREG, UARTLITE_RST_RX_FIFO// | UARTLITE_RST_TX_FIFO ); siopcb->exinf = exinf; siopcb->getready = siopcb->putready = FALSE; siopcb->openflag = TRUE; return(siopcb);}voiduart_cls_por(SIOPCB *siopcb){ sil_wrw_mem((VP)UARTLITE_CTREG, ~UARTLITE_ENABLE_INTR); /* 充哈み敦贿 */ siopcb->openflag = FALSE; siopcb->sendflag = FALSE;}/* * シリアルI/Oポ〖トへの矢机流慨 */BOOLuart_snd_chr(SIOPCB *siopcb, INT chr){ if(uart_putready(siopcb)){ uart_putchar(siopcb, (UB) chr); return(TRUE); } return(FALSE);}/* * シリアルI/Oポ〖トからの矢机减慨 */INTuart_rcv_chr(SIOPCB *siopcb){ if (uart_getready(siopcb)) { return((INT)(UB) uart_getchar(siopcb)); } return(-1);}/* * OPB_UARTLITE は流慨と减慨充哈みを改侍に钓材/敦贿する怠墙は积たない *//* * シリアルI/Oポ〖トからのコ〖ルバックの钓材 */voiduart_ena_cbr(SIOPCB *siopcb, UINT cbrtn){}/* * シリアルI/Oポ〖トからのコ〖ルバックの敦贿 */voiduart_dis_cbr(SIOPCB *siopcb, UINT cbrtn){}/* * シリアルI/Oポ〖トに滦する充哈み借妄 */static voiduart_isr_siop(SIOPCB *siopcb){ /* * エッジ充哈みのため充哈み借妄涟にACK */ intc_ack_interrupt(1 << (UARTINTLVL - 1)); if (uart_getready(siopcb)) { /* * 减慨奶梦コ〖ルバックル〖チンを钙び叫すˉ */ uart_ierdy_rcv(siopcb->exinf); } if (uart_putready(siopcb)) { /* * 流慨材墙コ〖ルバックル〖チンを钙び叫すˉ */ uart_ierdy_snd(siopcb->exinf); }}/* * SIOの充哈みサ〖ビスル〖チン */voiduart_isr(){ if (siopcb_table[0].openflag) { uart_isr_siop(&(siopcb_table[0])); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -