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

📄 ahbarb.c

📁 ARM7系统IP核的VHDL语言源代码
💻 C
字号:
#include <tmki.h>
#include "ahbarb.h"

ahbarb *ahbarb_create() {
  ahbarb *m;
  
  m = (ahbarb *) ti_alloc(sizeof(ahbarb));
  if (!m) { return 0; }
  
    ti_print_err("\
Create ahbarb model (0x%x):\n\
Max slaves : %i\n\n",
m,AHBARB_MAXSLAVE);
    
  return m;
}

ahbarb *ahbarb_add(ahbarb *m,ahb_write w,ahb_read r, unsigned int start, unsigned int end) {
  int i;
  for (i = 0;i < AHBARB_MAXSLAVE;i++) {
    if (m ->slaves[i].start == 0 && 
	m ->slaves[i].end == 0) {
      m ->slaves[i].start = start;
      m ->slaves[i].end = end;
      m ->slaves[i].read = r;
      m ->slaves[i].write = w;
    }
  }
}

int ahbarb_read(ahbarb *m,unsigned int addr, unsigned int *data) {
  int i;
  for (i = 0;i < AHBARB_MAXSLAVE;i++) {
    if (m ->slaves[i].start <= addr && 
	m ->slaves[i].end > addr) {
      return m ->slaves[i].read(addr,data);
    }
  }
  return 0;
}

int ahbarb_write(ahbarb *m,unsigned int addr, unsigned int data) {
  int i;
  for (i = 0;i < AHBARB_MAXSLAVE;i++) {
    if (m ->slaves[i].start <= addr && 
	m ->slaves[i].end > addr) {
      return m ->slaves[i].write(addr,data);
    }
  }
  return 0;
}

⌨️ 快捷键说明

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