搜索
bottom↓
回复: 0

nios 的dma中断问题

[复制链接]

出0入0汤圆

发表于 2010-11-25 09:03:11 | 显示全部楼层 |阅读模式
我在做一个nios+vga显示的东东。
配置文件已经烧写到配置芯片中。
但是写的程序。在第一次上电或复位后可以进入dma中断一次,之后就无法进入了。而且这时再重新启动一次调试也无法进入中断。这是为什么?可以知道程序在运行,我外接二极管在走跑马灯。
程序如下;
#include <stdio.h>
#include "sys/alt_dma.h"
#include "../inc/sopc.h"
#include <system.h>
#include <alt_types.h>
#include "altera_avalon_dma.h"
#include "sys/alt_irq.h"
#include "altera_avalon_dma_regs.h"
#define VGA_WIDTH 640
#define VGA_HEIGHT 480
static volatile unsigned char *P_VGA = (unsigned char *)(VGA_CONTROLLER_STREAM_0_BASE);
static volatile unsigned char *P_VGA_RAM = (unsigned char *)(SDRAM_BASE + 0x300000);
const unsigned long TLENGTH = VGA_WIDTH * VGA_HEIGHT;
//void clear_bk(unsigned int left, unsigned int top, unsigned int width, unsigned int height, unsigned char color);
//void init_dma(void);
//void DMA_interrupts(void * context, alt_u32id);
void clear_bk(unsigned int left, unsigned int top, unsigned int width, unsigned int height, unsigned char color)
{
    unsigned long addr;
    unsigned int i,j;
    for(i=0; i<height; i++)
    {
        for(j=0;j<width;j++)
        {
            addr = (VGA_WIDTH * (top + i)) + left + j;
            if(addr > TLENGTH)
                addr %= TLENGTH;
                P_VGA_RAM[addr] = color;
        }
    }
}
void DMA_interrupts(void * context, unsigned int id)
{
    int si = IORD_ALTERA_AVALON_DMA_STATUS(DMA_0_BASE);
    if(si & 0x1)
    {
        IOWR_ALTERA_AVALON_DMA_CONTROL(DMA_0_BASE,0);
        IOWR_ALTERA_AVALON_DMA_STATUS(DMA_0_BASE,0);
        IOWR_ALTERA_AVALON_DMA_CONTROL(DMA_0_BASE,0);
        IOWR_ALTERA_AVALON_DMA_LENGTH(DMA_0_BASE,TLENGTH);
        IOWR_ALTERA_AVALON_DMA_RADDRESS(DMA_0_BASE,(int)P_VGA_RAM);
        IOWR_ALTERA_AVALON_DMA_WADDRESS(DMA_0_BASE,(int)P_VGA);
         
        IOWR_ALTERA_AVALON_DMA_CONTROL(DMA_0_BASE,
                            ALTERA_AVALON_DMA_CONTROL_WORD_MSK  |
                            ALTERA_AVALON_DMA_CONTROL_GO_MSK    |
                            ALTERA_AVALON_DMA_CONTROL_I_EN_MSK  |
                            ALTERA_AVALON_DMA_CONTROL_WCON_MSK  |
                          //  ALTERA_AVALON_DMA_CONTROL_WEEN_MSK  |
                            ALTERA_AVALON_DMA_CONTROL_LEEN_MSK
                            );
       IOWR_ALTERA_AVALON_DMA_STATUS(DMA_0_BASE,0);
       alt_dma_txchan_open("/dev/dma_0");
    }
}
void init_dma(void)
{
    if(alt_irq_register(DMA_0_IRQ,0,DMA_interrupts)==0)
    {
        printf("irq ok!\n");
    }
    IOWR_ALTERA_AVALON_DMA_CONTROL(DMA_0_BASE,0);
    IOWR_ALTERA_AVALON_DMA_STATUS(DMA_0_BASE,0);
   
    IOWR_ALTERA_AVALON_DMA_LENGTH(DMA_0_BASE,TLENGTH);
    IOWR_ALTERA_AVALON_DMA_RADDRESS(DMA_0_BASE,(int)P_VGA_RAM);
    IOWR_ALTERA_AVALON_DMA_WADDRESS(DMA_0_BASE,(int)P_VGA);
    IOWR_ALTERA_AVALON_DMA_CONTROL(DMA_0_BASE,
                    ALTERA_AVALON_DMA_CONTROL_WORD_MSK  |
                    ALTERA_AVALON_DMA_CONTROL_GO_MSK    |
                    ALTERA_AVALON_DMA_CONTROL_I_EN_MSK  |
                    ALTERA_AVALON_DMA_CONTROL_WCON_MSK  |
                 //   ALTERA_AVALON_DMA_CONTROL_WEEN_MSK  |
                    ALTERA_AVALON_DMA_CONTROL_LEEN_MSK
                    );
    alt_dma_txchan_open("/dev/dma_0");
}
int main()
{
    clear_bk(0,0,VGA_WIDTH,VGA_HEIGHT,0x3);
    init_dma();
    while(1)
    {
        int i;
        for(i=0; i<3; i++)
        {
            LED->DATA = 1<<i;
        }
    }
    return 0;
}

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 17:31

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表