资料
  • 资料
  • 专题
DM365的板子调试和测试程序
推荐星级:
时间:2020-01-02
大小:1.08MB
阅读数:169
上传用户:quw431979_163.com
查看他发布的资源
下载次数
0
所需E币
3
ebi
新用户注册即送 300 E币
更多E币赚取方法,请查看
close
资料介绍
详细说明:DM365的板子调试和测试程序,相信对使用该达芬奇芯片的人有用Last updated: 12/02/2008This file contains important notes for software developers porting code tothe DM365 EVM and using our production test cases. The main repository forour code is: http://support.spectrumdigital.com/boards/evmdm365 Username: evmdm365 Password: earlyaccessGEL Files - The evmdm365.gel file (0.90 and later) is targeted at FIB silicon with a 24MHz crystal. evmdm365-hd.gel is the same as evmdm365.gel but with the PLLs configured for HD video (you need this one to run the two HD video tests. The evmdm365-087-osc.gel file is for non-FIB parts and will eventually be phased out.NAND / OneNAND - SW5-1 is a selector switch that controls whether the NAND is active or not. The OFF position selects NAND, the ON position selects OneNAND.Ethernet - The MII signals pass through an on-board mux (U10) that controls whether the signals go to the Micrel KSZ8001 PHY or not. The mux selector is driven from the CPLD and defaults to the KSZ8001 PHY so you should no have to change it unless you modified the CPLD registers for some other purpose. The control bit is bit 3 of CPLD register #3 (0 = KSZ8001).Video port input path - The VPFE can be fed with data from the TVP5416 (SD video composite or S-Video), LCD or TVP7002 (HD component video). The input is selected through a pair of muxes (U17 and U21). To configure the muxes, set bits 2:0 of CPLD register #3 as follows: Video input = TVP5416, set CPLD3[2:0] to 0x5 Video input = Digital CCD, set CPLD3[2:0] to 0x2 Video input = TVP7002, set CPLD3[2:0] to 0x1CPLD Registers - The addresses of the CPLD control registers are: (Uint8 *)0x04000000, // Register 0(Uint8 *)0x04000008, // Register 1(Uint8 *)0x04000010, // Register 2 (controls the 8 user LEDs, good for test)(Uint8 *)0x04000018, // Register 3 (mux control)(Uint8 *)0x04000400, // Register 4(Uint8 *)0x04000408, // Register 5(Uint8 *)0x04000410, // Register 6(Uint8 *)0x04000418 // Register 7I2C - You must be aware of a couple of special issues when using the I2C on the DM365 EVM. First, the THS7303/THS7535 parts have a habit of not coming up in a clear reset state. They tend to draw I2C SDA low preventing normal I2C bus operation. The way to clear this is by pinmuxing SCL as GPIO20 and wiggling it up and down 9 times to act like a dummy I2C cycle, then pinmux the pin back to SCL. We do this in our BSL init (lib\bsl\evmdm365.c in EVMDM365_init()) so that it happens in the initialization phase of our test code before anything actually happens. Linux side developers should put this in U-Boot. The second issue with I2C timing is that one of the I2C devices on the board does not like clock back to back I2C cycles regardless of whether it is the device being addressed or not. Our experimental solution is to wait 30 micro- seconds after each I2C transaction, that seems to take care of things. The I2C device should only be run at speeds up to 100KHz, some devices are not fast enough to keep up after that. The THS7353 should be initialized before the TVP7002 as it is in the component video input path before the TVP7002. In our tests, we leave a delay of 50ms between the THS7353 configuration via I2C before initializing the TVP7002 to give it some time to sync to the video stream.MAC Address - The MAC address is stored at offset 0x7F00 in the I2C EEPROM (6 bytes).Software equivalence - The input and output video paths come from a DaVinci HD EVM and should be set up the same way. The input path consists of either a TVP5416 (SD) or TVP7002 through a THS7353 (HD). The output path goes through a THS7303 to the video DACs. For NTSC component video in, the VPSS ISIF silicon module handles the Y/C channels differently than DM355 silicon. Set ISIF_CCDCFG to 0x0810 (instead of 0x800) to swap the channels and get equivalent behavior. The EMAC module's interrupt wrapper registers are a little different than on previous devices. Look at the end of the emac_init() function in our test cases for settings to enable EMAC interrupts: /* 17. Enable the device interrupt in EWCTL. */ EMAC_CMEMCONTROL = 0x00000002; // Emulation free EMAC_CMRXINTEN = 0x000000ff; // Enable receive interrupts on channel 0 EMAC_CMTXINTEN = 0x000000ff; // Enable transmit interrupts on channel 0 EMAC_CMRXTHRESHINTEN = 0x000000ff; // Enable receive threshold interrupt enableEMAC_CMMISCINTEN = 0x0000000f; // Enable misc interrupts The DACSEL register description in SPRUFG9 does not match what I saw when I was playing with the registers. Only the 12 lower bits of the register could be set (3 DACs, not 4 as in the description). When XDMODE in the SYSTEM module VDAC_CONFIG register is set to 0, bits 11-8 of DACSEL control whats coming out on the TVOUT analog channel. When XDMODE is set to 1, bits 11-0 of DACSEL correspond to the COMPY/COMPPB/COMPPR component outputs (the 3 DACs). So bits 11-8 of DACSEL appear to be dual function based on the setting of XDMODE.Resource MapEMIF Async EMIF, Keypad secondary. Verify keypad muxing override in test caseMcBSP AIC3101SPI0 SPIROM (AT25640), Max clock 20MHz, 8KbytesSPI1 ExpSPI2 ExpSPI3 ExpSPI4 ExpUART0 RS-232 ConsoleUART1 ENETENET ENET - MII Mode to KS8001L PHYMDIO ENET / Video Port G0/G1ADC ADCVoice Voice CodecUSB Check power from USB_DRVVBUS, verify pin muxingSD0 SD Card 0SD1 SD Card 1VDAC Component OutVIDIN TVP5416 (SD) or TVP7002 (HD)Async EMIF DevicesNAND MT29F16G08FAAWC:A on CE0n/CE1nOneNAND KFG1G16U2B-DIB6000 on ONENAND_CE I2C Device0x18 AIC31010x25 MSP4300x2C THS73030x2E THS73530x50 CAT24C2560x5D TVP51460x5C TVP7002……
版权说明:本资料由用户提供并上传,仅用于学习交流;若内容存在侵权,请进行举报,或 联系我们 删除。
PARTNER CONTENT
相关评论 (下载后评价送E币 我要评论)
没有更多评论了
  • 可能感兴趣
  • 关注本资料的网友还下载了
  • 技术白皮书