zxnmsk 发表于 2009-11-18 09:05

8686 wifi spi

各位老大好:
我是使用   模组型号是USI的WM-G-MR-09,模组使用的芯片是Marvell 8686. 我自己在移植到freescale mx31上时候,读不出wifi模块的id,但是我使用FPGA去模拟SPI时序的时候是可以读取到ID的,chip id =0x0b, 当我使用arm连续的读写ID寄存器(0x0002)的时候,出现这样的波形,各位老大帮忙看一下,有什么问题吗?,
图中的黄线是ARM输出mosi,绿色是clk   蓝色是片选 ss0,我的程序是这样的
int gspi_read_data_direct(gspi_card_rec_p cardp,
   u8 *data, u16 reg, u16 size)
{
int      ret;

gspihost_info_p gspiinfop;
ENTER();
if(!cardp) {
ret = -EINVAL;
goto error;
}
gspiinfop = cardp->ctrlr;
if((ret = gspi_acquire_io(gspiinfop)) != GSPI_OK){
GSPI_DEBUG("gspi_acquire_io failed\n");
goto error;
}
   GSPI_DEBUG("gspi_acquire_io ok\n");

gpio_set_low(WIFI_CS);
mcbsp_set_transmitter();
mcbsp_set_receiver();
    ///CPU model
    {
      int i;
GSPI_DEBUG("begin to read\n");
      ///Process the data
      {
            u16 *dat = (u16 *) rx;//定义的临时数组
            //u16 c;
            
            wmb();
            spi_write16(reg);   //写寄存器地址
            spi_read16(dat);
   //udelay(10);
   dat++;
   for (i = 0; i < size; i++) {
                spi2_write16(0); //dummy clk或者是激活读时钟
                udelay(10);
                spi2_read16(dat);    // 读取数据
udelay(10);
                dat++;
             }

             GSPI_DEBUG("end to read %x\n",*dat);
         }
      rmb();
         
    }
gspiinfop -> d.dma_rxack = 0;

mcbsp_reset_receiver();
mcbsp_reset_transmitter();
gpio_set_high(WIFI_CS);
memcpy(data,rx + (dummy_clk + 1) * 2,    //把读到的前2个字节丢掉
   (2*size - (dummy_clk + 1) * 2) );

gspi_release_io(gspiinfop);
ret = 0;
error: LEAVE();
return ret;
}
这个是读取寄存器的函数;各位老大有调试过的 指导一下 给点意见

dreamice 发表于 2009-11-18 11:14

你这个图贴的太猛了
页: [1]
查看完整版本: 8686 wifi spi