打印

我的dsp的成长之路------此贴只赠给我自己

[复制链接]
楼主: meng219902
手机看帖
扫描二维码
随时随地手机跟帖
41
meng219902|  楼主 | 2012-5-4 21:23 | 只看该作者 |只看大图 回帖奖励 |倒序浏览
此时此刻我是非常发晕的,因为我刚才在网上一顿神找“算法”有很多前辈都说DSP核心的就是“算法”了,对于C2000来说,它应用的领域无非就是那几块,电机控制、逆变器、、、(完了说大了,初学者的水平,说错了前辈们勿喷)算法应该完善了把???我就有一个疑问。比如SVPWM 这方面 编出来的算法不是都一样吗? 我想知道是不是我们可以拿别人的算法用?比如TI的(等着以后工作了好像要付钱了)很晕啊

使用特权

评论回复
42
meng219902|  楼主 | 2012-5-4 22:16 | 只看该作者
今天一直做外围的中断的学习(我以为ZONE0、6、7是外部中断呢,原来他是外部接口,我的板子用来接外设RAM,FLASH)我看了两个程序,第一个我没有看到他到底想干什么,ZONE7的配置,剩下的都是就没有什么了吧?其实我错了,重点不是在ZONE7 上而是在
#pragma CODE_SECTION(cpu_timer0_isr,"xintffuncs");
#pragma CODE_SECTION(cpu_timer1_isr,"xintffuncs");   
   xintffuncs       : LOAD = RAML1,
                      RUN = ZONE7A,
                      LOAD_START(_XintffuncsLoadStart),
                      LOAD_END(_XintffuncsLoadEnd),
                      RUN_START(_XintffuncsRunStart),
                      PAGE = 0
xintffuncs这个存储空间刚开始我没找到,到了中午我才无意中发现,原来这个存储空间与zone7有关(还有RAM),我一下子意识到很多东西!第一我的CMD模块我没有学好(主要是在我没看手把手之前我看书上的CMD了,感觉好乱,都不知道写的什么,后来看了手把手之后,感觉好简单,原来就是MEMORY和SECTIONS啊,知道今天下午上课我把书上的CMD过了一遍才知道关于CMD的一些知识【说这句话的是我都不知道我要说什么了,因为我现在实在是太晕了】)  刚开始我还以为ZONE7的存储空间是在外设RAM里呢
(ZONE7叫外部存储器,而外设RAM呢?他俩有什么关系吗?我猜想是。。。。。请前辈们指点!)
MemCopy(&XintffuncsLoadStart, &XintffuncsLoadEnd, &XintffuncsRunStart);   
关于这个DMA,刚开始学的时候我还以为是CMD呢,就当CMD学的,老板讲得视频还有函数,就是跟这个差不多的,后来看手把手 也没有啊,是不是老板讲错了或者讲得太难了?答案是我看错了,要不是这个程序,到现在我都不知道CMD与DMA不是一回事!

使用特权

评论回复
43
meng219902|  楼主 | 2012-5-4 22:40 | 只看该作者
找了半天ZONE与外设RAM、FLASH的没有找到答案 我脸也洗了 还是不行啊

使用特权

评论回复
44
czdo| | 2012-5-5 11:30 | 只看该作者
路过支持一下。上进好学的楼主

使用特权

评论回复
45
liwsx| | 2012-5-5 11:41 | 只看该作者
楼主加油,、
会成功的

使用特权

评论回复
46
meng219902|  楼主 | 2012-5-5 21:46 | 只看该作者
在这里 我对那些支持我的人说一声对不起 这几天不知道怎么的 学不进去了(很大程度上是我快抗不住了,成天想疯了一样学习,没有假期,没有上不上课,上什么课都是在学DSP,上课看书,下课了看视频)  这两天我就看了几个程序,第一个感觉就是我必须把DMA模块学会!我的那些程序都是关于他的!其次就是跟着进度走ADC模块,但是我意识到外设接口的程序(关于DMA的)我还没有看懂,得继续看。。。现在我就好好休息,养足精神啊,身体是革命的本钱嘛,我得好好照顾好他

使用特权

评论回复
47
gaga1| | 2012-5-6 14:30 | 只看该作者
楼主写的不错 楼主加油

使用特权

评论回复
48
gaga1| | 2012-5-6 14:30 | 只看该作者
会一直关注楼主的

使用特权

评论回复
49
meng219902|  楼主 | 2012-5-6 23:14 | 只看该作者
48# gaga1
谢谢

使用特权

评论回复
50
meng219902|  楼主 | 2012-5-6 23:22 | 只看该作者
今天恢复了体力 我回到了无限的学习之中,把DMA模块给学得差不多了,那几个函数,但是有一个问题我就那不明白了

QQ截图20120506232111.png (15.57 KB )

QQ截图20120506232111.png

使用特权

评论回复
51
meng219902|  楼主 | 2012-5-6 23:32 | 只看该作者
DMACH1WrapConfig(1,0,0,1);这个函数是指最大偏移量的 那么他等于1(源地址),还有目地地址设为0,这让我怎么理解啊?莫非只进行一个脉冲?回到源地址的起始地址吗?这个还说得过去 那么目标地址偏移的太大了吧?但是设置的最大目地地址设置为0,这个怎么解释呢?求前辈明示

使用特权

评论回复
52
meng219902|  楼主 | 2012-5-6 23:32 | 只看该作者
//###########################################################################
//
// FILE:   Example_2833xAdcToDMA.c
//
// TITLE:  DSP2833x ADC To DMA
// ASSUMPTIONS:
//
//    This program requires the DSP2833x header files.
//
//    Make sure the CPU clock speed is properly defined in
//    DSP2833x_Examples.h before compiling this example.
//
//    Connect the signals to be converted to channel A0, A1, A2, and A3.
//
//    As supplied, this project is configured for "boot to SARAM"
//    operation.  The 2833x Boot Mode table is shown below.
//    For information on configuring the boot mode of an eZdsp,
//    please refer to the documentation included with the eZdsp,
//
//       $Boot_Table:
//
//         GPIO87   GPIO86     GPIO85   GPIO84
//          XA15     XA14       XA13     XA12
//           PU       PU         PU       PU
//        ==========================================
//            1        1          1        1    Jump to Flash
//            1        1          1        0    SCI-A boot
//            1        1          0        1    SPI-A boot
//            1        1          0        0    I2C-A boot
//            1        0          1        1    eCAN-A boot
//            1        0          1        0    McBSP-A boot
//            1        0          0        1    Jump to XINTF x16
//            1        0          0        0    Jump to XINTF x32
//            0        1          1        1    Jump to OTP
//            0        1          1        0    Parallel GPIO I/O boot
//            0        1          0        1    Parallel XINTF boot
//            0        1          0        0    Jump to SARAM            <- "boot to SARAM"
//            0        0          1        1    Branch to check boot mode
//            0        0          1        0    Boot to flash, bypass ADC cal
//            0        0          0        1    Boot to SARAM, bypass ADC cal
//            0        0          0        0    Boot to SCI-A, bypass ADC cal
//                                              Boot_Table_End$
//
//
// DESCRIPTION:
//
// ADC is setup to convert 4 channels for each SOC received, with  total of 10 SOCs.
// Each SOC initiates 4 conversions.
// DMA is set up to capture the data on each SEQ1_INT.  DMA will re-sort   
// the data by channel sequentially, i.e. all channel0 data will be together
// all channel1 data will be together.
//
// Code should stop in local_DINTCH1_ISR when complete
//
// Watch Variables:
//      DMABuf1
//
//###########################################################################
//
// Original source by: M.P.
//
// $TI Release: DSP2833x/DSP2823x Header Files V1.20 $
// $Release Date: August 1, 2008 $
//###########################################################################

#include "DSP28x_Project.h"     // Device Headerfile and Examples Include File

// ADC start parameters
#if (CPU_FRQ_150MHZ)     // Default - 150 MHz SYSCLKOUT
  #define ADC_MODCLK 0x3 // HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 150/(2*3)   = 25.0 MHz
#endif
#if (CPU_FRQ_100MHZ)
  #define ADC_MODCLK 0x2 // HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 100/(2*2)   = 25.0 MHz
#endif
#define ADC_CKPS   0x1   // ADC module clock = HSPCLK/2*ADC_CKPS   = 25.0MHz/(1*2) = 12.5MHz
#define ADC_SHCLK  0xf   // S/H width in ADC module periods                        = 16 ADC clocks
#define AVG        1000  // Average sample limit
#define ZOFFSET    0x00  // Average Zero offset
#define BUF_SIZE   40    // Sample buffer size

// Global variable for this example
Uint16 j=0;

#pragma DATA_SECTION(DMABuf1,"DMARAML4");
volatile Uint16 DMABuf1[40];

volatile Uint16 *DMADest;
volatile Uint16 *DMASource;
interrupt void local_DINTCH1_ISR(void);

void main(void)
{
   Uint16 i;
// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
   InitSysCtrl();

// Specific clock setting for this example:
   EALLOW;
   SysCtrlRegs.HISPCP.all = ADC_MODCLK;        // HSPCLK = SYSCLKOUT/ADC_MODCLK
   EDIS;

// Step 2. Initialize GPIO:
// This example function is found in the DSP2833x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio();  // Skipped for this example

// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts
   DINT;

// Initialize the PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.
// This function is found in the DSP2833x_PieCtrl.c file.
   InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
   IER = 0x0000;
   IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt
// Service Routines (ISR).
// This will populate the entire table, even if the interrupt
// is not used in this example.  This is useful for debug purposes.
// The shell ISR routines are found in DSP2833x_DefaultIsr.c.
// This function is found in DSP2833x_PieVect.c.
   InitPieVectTable();

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file.
   EALLOW;        // Allow access to EALLOW protected registers
   PieVectTable.DINTCH1= &local_DINTCH1_ISR;
   EDIS;   // Disable access to EALLOW protected registers
      
   IER = M_INT7 ;                                     //Enable INT7 (7.1 DMA Ch1)
   EnableInterrupts();
   
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
// InitPeripherals(); // Not required for this example
   InitAdc();  // For this example, init the ADC

// Specific ADC setup for this example:
   AdcRegs.ADCTRL1.bit.ACQ_PS = ADC_SHCLK;
   AdcRegs.ADCTRL3.bit.ADCCLKPS = ADC_CKPS;
   AdcRegs.ADCTRL1.bit.SEQ_CASC = 0;        // 0 Non-Cascaded Mode
   AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 0x1;
   AdcRegs.ADCTRL2.bit.RST_SEQ1 = 0x1;
   AdcRegs.ADCCHSELSEQ1.bit.CONV00 = 0x0;
   AdcRegs.ADCCHSELSEQ1.bit.CONV01 = 0x1;
   AdcRegs.ADCCHSELSEQ1.bit.CONV02 = 0x2;
   AdcRegs.ADCCHSELSEQ1.bit.CONV03 = 0x3;
   AdcRegs.ADCCHSELSEQ2.bit.CONV04 = 0x0;
   AdcRegs.ADCCHSELSEQ2.bit.CONV05 = 0x1;
   AdcRegs.ADCCHSELSEQ2.bit.CONV06 = 0x2;
   AdcRegs.ADCCHSELSEQ2.bit.CONV07 = 0x3;
   AdcRegs.ADCMAXCONV.bit.MAX_CONV1 = 3;   // Set up ADC to perform 4 conversions for every SOC
   
//Step 5. User specific code, enable interrupts:
  // Initialize DMA
        DMAInitialize();

        // Clear Table
   for (i=0; i<BUF_SIZE; i++)
   {
     DMABuf1[i] = 0;
   }

       
// Configure DMA Channel
    DMADest   = &DMABuf1[0];              //Point DMA destination to the beginning of the array
        DMASource = &AdcMirror.ADCRESULT0;    //Point DMA source to ADC result register base
        DMACH1AddrConfig(DMADest,DMASource);
        DMACH1BurstConfig(3,1,10);
        DMACH1TransferConfig(9,1,0);
        DMACH1WrapConfig(1,0,0,1);
        DMACH1ModeConfig(DMA_SEQ1INT,PERINT_ENABLE,ONESHOT_DISABLE,CONT_DISABLE,SYNC_DISABLE,SYNC_SRC,
                         OVRFLOW_DISABLE,SIXTEEN_BIT,CHINT_END,CHINT_ENABLE);





        StartDMACH1();

   

   // Start SEQ1
   AdcRegs.ADCTRL2.bit.SOC_SEQ1 = 0x1;
   for(i=0;i<10;i++){
            for(j=0;j<1000;j++){}
        AdcRegs.ADCTRL2.bit.SOC_SEQ1 = 1;    //Normally ADC will be tied to ePWM, or timed routine
   }                                             //For this example will re-start manually                  

}

// INT7.1
interrupt void local_DINTCH1_ISR(void)     // DMA Channel 1
{
  
  // To receive more interrupts from this PIE group, acknowledge this interrupt
   PieCtrlRegs.PIEACK.all = PIEACK_GROUP7;

  // Next two lines for debug only to halt the processor here
  // Remove after inserting ISR Code
   asm ("      ESTOP0");
   for(;;);
}

使用特权

评论回复
53
meng219902|  楼主 | 2012-5-6 23:33 | 只看该作者
这是原文件

使用特权

评论回复
54
cooran| | 2012-5-7 14:18 | 只看该作者
现在看到这个帖子一周过去了,楼主一周的收获是不是又可以总结下了?

使用特权

评论回复
55
meng219902|  楼主 | 2012-5-8 00:22 | 只看该作者
55# cooran
嗯。。。其实我每天都作总结,要是总结这一周的话,回顾一下,
  这一周来,是我对dsp实质性的前进,从第一个工程的建立,到GPIO的学习,CPU中断,和外部中断(我感觉PIE模块是这两个中断的中介,我所看到的程序都需要PIE),然后就是DMA模块了(CMD这个肯定是在他之前学了),上周应该就学到这里。
  具体点,GPIO呢 就没得说了 那几个控制器控制是什么IO口,方向,还有怎么设置高低电平。CPU定时器就不用说了,注意入口怎么配置 PieVectTable.TINT0 = &cpu_timer0_isr; (timer1/2不是我们不可以使用吗?只有timer0可用),还有就是记住那个函数ConfigCpuTimer 剩下的就是使能了!什么CPU的IER 还有PIE的 还有总使能EINT 还有实时。。。我感觉这个模型就是中断的结构框架了。外部中断呢,有八个(7+1你懂的)外设中断选择IO口 还有IO口怎么配置!!(老板说了,如果配置错了很可能烧坏板子的),出发方式,对了我在PIE那里忘说了,就是清ACK! (并不是只清他,他只是代表一类置位的寄存器),什么使能了,配置进入口(哦,我想起来了,这个学名叫中断服务子函数)

使用特权

评论回复
56
meng219902|  楼主 | 2012-5-8 00:31 | 只看该作者
那些我都不用说了把?最后就是DMA了,DMA呢?一个是源地址,一个是目的地址。把地址配置好
#pragma DATA_SECTION(DMABuf1,"DMARAML4");
#pragma DATA_SECTION(DMABuf2,"DMARAML5");‘
然后就是一下函数了,你学一遍基本就了解了
DMADest   = &DMABuf1[0];
        DMASource = &DMABuf2[0];
           DMACH1AddrConfig(DMADest,DMASource);
        DMACH1BurstConfig(31,2,2);      
        DMACH1TransferConfig(31,2,2);     
        DMACH1WrapConfig(0xFFFF,0,0xFFFF,0);
DMACH1ModeConfig(DMA_TINT0,PERINT_ENABLE,ONESHOT_ENABLE,CONT_DISABLE,SYNC_DISABLE,SYNC_SRC,OVRFLOW_DISABLE,THIRTYTWO_BIT,CHINT_END,CHINT_ENABLE);
这是配置DMA的结构,但是我上面说了一个问题,我不明白,希望您能帮我解答一下 谢谢了

使用特权

评论回复
57
meng219902|  楼主 | 2012-5-8 00:42 | 只看该作者
对了外部接口ZONE0、6、7我忘说了!怎么说呢,ZONE的一些配置需要了解,什么写时序 读时序 时钟的配置,深度。。。。
MemCopy(&XintffuncsLoadStart, &XintffuncsLoadEnd, &XintffuncsRunStart);’
这个函数我一直以为是DMA的那几个函数中的一个呢,现在才发现不是啊,
还有PIE向量表,GPIOMUX表你都要有所了解

使用特权

评论回复
58
meng219902|  楼主 | 2012-5-8 00:51 | 只看该作者
今天我学了ADC模块 变了一个小程序 感觉就是我对CCS中的浮点型 整形 无符号整形、、、不太了解,导致我的电路真正的数值没有显示出来,而是。。。(怎么说呢,ADC不是分4095(右移四位)不移的话就是65520,对于那个数有了,就是转换没有弄清楚,我感觉就是数的类型有问题)
#include"DSP28x_project.h"

#define BUF_SIZE 256
Uint16 SampleTable[BUF_SIZE];
Uint16 *Xaddr=(Uint16 *)0x6100;
float32 Vinput;
void main(void)
{
        Uint16 i;
        Uint16 array_index;
        InitSysCtrl();
        EALLOW;
                SysCtrlRegs.HISPCP.all=0x3;
        EDIS;
        DINT;
        InitPieCtrl();
        IER=0x0000;
        IFR=0x0000;
        InitPieVectTable();
        InitAdc();
        AdcRegs.ADCTRL1.bit.ACQ_PS=0xf;
        AdcRegs.ADCTRL3.bit.ADCCLKPS=0x1;
        AdcRegs.ADCTRL1.bit.SEQ_CASC=1;
        AdcRegs.ADCTRL3.bit.SMODE_SEL=0;
        AdcRegs.ADCTRL1.bit.CONT_RUN=1;
        AdcRegs.ADCCHSELSEQ1.bit.CONV00=0x0;
        AdcRegs.ADCMAXCONV.bit.MAX_CONV1=0;
        for(i=0;i<BUF_SIZE;i++)
        {
                SampleTable[i]=0;
        }       
        AdcRegs.ADCTRL2.bit.SOC_SEQ1=1;
        while(1)
        {       
                array_index=0;
//                for(i=0;i<(BUF_SIZE/16);i++)
//                {
//                        while(AdcRegs.ADCST.bit.INT_SEQ1==0){}
//                        AdcRegs.ADCST.bit.INT_SEQ1_CLR=1;
                        SampleTable[array_index++]=((AdcRegs.ADCRESULT0)>>4);
                    Vinput=3*(SampleTable[0])/4095;
//                }       
         }
}
这个程序还是要改的,我都感觉有问题了,只是今天太仓促了 没时间了,初步性成果吧

使用特权

评论回复
59
meng219902|  楼主 | 2012-5-8 00:53 | 只看该作者
由于本人学校的实验室这几天断网,我只能学习完了,回寝室才能上网,导致我回复大家的时间有点晚,希望你们能够理解我

使用特权

评论回复
60
大秦正声| | 2012-5-8 11:49 | 只看该作者
本帖最后由 大秦正声 于 2012-5-8 11:51 编辑

28335 是加强的2812版本!
兼容2812的代码!
多了浮点运算硬件单元,I/O口功能更丰富灵活,可以设定各种中断方式!
我用外部总线成功操作读写擦除64G bit 的NAND flash !
1M byte SRAM,
16位的AD7656 模数转换芯片!
CAN 通信 波特率500Kb/s ,
而且工作温度在125度测试的!!!
我用的2812芯片。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则