u-boot1.1.5的移植二

二。nand可以读写,但参数不能修改
http://blog.lupaworld.com/blog/htm/do_showone/tid_4343.html
http://bbs2.chinaunix.net/viewthread.php?tid=855860
1.在nand_legacy中加入nand低层的读写函数
//add
#include <s3c2410.h>
/*typedef enum{
NFCE_LOW,
NFCE_HIGH
} NFCE_STATE;
*/
static inline void NF_Conf(u16 conf)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
nand->NFCONF = conf;
}
static inline void NF_Cmd(u8 cmd)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
nand->NFCMD = cmd;
}
static inline void NF_CmdW(u8 cmd)
{
NF_Cmd(cmd);
udelay(1);
}
static inline void NF_Addr(u8 addr)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
nand->NFADDR = addr;
}
static inline void NF_SetCE(int s)   //static inline void NF_SetCE(NFCE_STATE s)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
switch (s) {
case NFCE_LOW:
  nand->NFCONF &= ~(1<<11);
  break;
case NFCE_HIGH:
  nand->NFCONF |= (1<<11);
  break;
}
}
static inline void NF_WaitRB(void)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
while (!(nand->NFSTAT & (1<<0)));
}
static inline void NF_Write(u8 data)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
nand->NFDATA = data;
}
static inline u8 NF_Read(void)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
return(nand->NFDATA);
}
static inline void NF_Init_ECC(void)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
nand->NFCONF |= (1<<12);
}
static inline u32 NF_Read_ECC(void)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
return(nand->NFECC);
}

extern ulong nand_probe(ulong physadr);
static inline void NF_Reset(void)
{
  int i;
  NF_SetCE(NFCE_LOW);
  NF_Cmd(0xFF); /* reset command */
  for(i = 0; i < 10; i++); /* tWB = 100ns. */
  NF_WaitRB(); /* wait 200~500us; */
  NF_SetCE(NFCE_HIGH);
}
static inline void NF_Init(void)
{
#if 0 /* a little bit too optimistic */
#define TACLS   0
#define TWRPH0 3
#define TWRPH1 0
#else
#define TACLS   0
#define TWRPH0 4
#define TWRPH1 2
#endif
  NF_Conf((1<<15)|(0<<14)|(0<<13)|(1<<12)|(1<<11)|(TACLS<<8)|(TWRPH0<<4)|(TWRPH1<<0));
  /*nand->NFCONF = (1<<15)|(1<<14)|(1<<13)|(1<<12)|(1<<11)|(TACLS<<8)|(TWRPH0<<4)|(TWRPH1<<0); */
  /* 1 1   1   1,   1     xxx, r xxx,   r xxx */
  /* En 512B 4step ECCR nFCE=H tACLS   tWRPH0   tWRPH1 */
  NF_Reset();
}

void nand_init(void)
{
S3C2410_NAND * const nand = S3C2410_GetBase_NAND();
NF_Init();

printf("NAND flash probing at 0x%.8lX/n", (ulong)nand);

printf ("%4lu MB/n", nand_probe((ulong)nand) >> 20);
}
//endadd

2。在fft2410.h中加入。。  并打开  CFG_CMD_NAND 宏
#define CFG_NAND_LEGACY 1
#define CFG_NAND_BASE 0x4E000000

// enum {NFCE_LOW,NFCE_HIGH} NFCE_STATE;
#define NFCE_LOW 0
#define NFCE_HIGH 1
#define NAND_ChipID_UNKNOWN     0x00

//add2
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
#define CFG_MAX_NAND_DEVICE 1 /* Max number of NAND devices */
#define SECTORSIZE 512
#define ADDR_COLUMN 1
#define ADDR_PAGE 2
#define ADDR_COLUMN_PAGE 3
#define NAND_ChipID_UNKNOWN 0x00
#define NAND_MAX_FLOORS 1
#define NAND_MAX_CHIPS 1
#define NAND_WAIT_READY(nand)  NF_WaitRB()
#define NAND_DISABLE_CE(nand)   NF_SetCE(NFCE_HIGH)
#define NAND_ENABLE_CE(nand)    NF_SetCE(NFCE_LOW)

#define WRITE_NAND_COMMAND(d, adr)       NF_Cmd(d)
#define WRITE_NAND_COMMANDW(d, adr)   NF_CmdW(d)
#define WRITE_NAND_ADDRESS(d, adr)        NF_Addr(d)
#define WRITE_NAND(d, adr)                              NF_Write(d)
#define READ_NAND(adr)                                    NF_Read()
/* the following functions are NOP's because S3C24X0 handles this in hardware */
#define NAND_CTL_CLRALE(nandptr)
#define NAND_CTL_SETALE(nandptr)
#define NAND_CTL_CLRCLE(nandptr)
#define NAND_CTL_SETCLE(nandptr)
/* #define CONFIG_MTD_NAND_VERIFY_WRITE 1 */
/* This definition above is commented by Lu Xianzi. 2006.05.28
  Because there's no definition of a macro called __mem_pci,
  there will be a link error.
*/
//#define CONFIG_MTD_NAND_ECC_JFFS2 1
#endif /* CONFIG_COMMANDS & CFG_CMD_NAND */
//end add2

3.加入自己的 Nand Flash 芯片型号
  在 include/linux/mtd/ nand_ids.h 中的对如下结构体赋值进行修改:
static struct nand_flash_dev nand_flash_ids[] = {
      ......
    {"Samsung K9F1208U0B",    NAND_MFR_SAMSUNG, 0x76, 26, 0, 4, 0x4000, 0},
      .......
}

4.在nand_legacy中修改
/*    for (i=0; i<CFG_MAX_NAND_DEVICE; i++) {
        if (nand_dev_desc[i].ChipID == NAND_ChipID_UNKNOWN)
                    {
            nand = &nand_dev_desc[i];
            break;
        }
    }
*/
用nand = &nand_dev_desc[0]; 代替
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: alsa-plugins-1.1.5.tar.bz2是一个压缩文件,用于安装和更新ALSA(Advanced Linux Sound Architecture)插件。ALSA是一种在Linux操作系统上提供音频支持的软件架构。 这个压缩文件包含了ALSA插件的源代码,可以在Linux系统上进行编译和安装。通过安装这些插件,用户可以获得更多的音频功能和选项。这些插件包括不同类型的音频效果、数据转换和输入/输出设备支持。 为了安装alsa-plugins-1.1.5.tar.bz2,首先需要解压缩该文件。在终端中使用以下命令可以完成解压缩操作: tar -xvf alsa-plugins-1.1.5.tar.bz2 然后,在解压后的文件夹中执行以下命令来编译和安装插件: ./configure make sudo make install 这将会在系统中安装ALSA插件,并使其可用于音频应用程序。安装完成后,用户可以根据自己的需要配置和使用这些插件。 总而言之,alsa-plugins-1.1.5.tar.bz2是一个用于安装和更新ALSA插件的压缩文件,用户可以通过编译和安装这些插件来增强Linux系统的音频功能。安装过程中需要解压缩文件并执行编译和安装命令。 ### 回答2: alsa-plugins-1.1.5.tar.bz2是一种软件压缩包,其中包含了alsa-plugins软件的版本1.1.5的安装文件。alsa-plugins是一个用于Advanced Linux Sound Architecture (ALSA)的插件集合,它提供了许多音频处理的功能和特性。 该软件包的.tar.bz2后缀表示它使用了tar和bzip2两种压缩算法。tar是一种文件归档工具,可以将多个文件和目录打包成一个文件。而bzip2是一种压缩工具,可以将文件压缩成较小的尺寸以节省存储空间。因此,alsa-plugins-1.1.5.tar.bz2可以解压缩成一个目录,其中包含了alsa-plugins软件的所有源代码和相关文件。 要安装alsa-plugins-1.1.5.tar.bz2,首先需要解压缩该文件。可以使用以下命令在终端中解压缩该文件: tar -xjf alsa-plugins-1.1.5.tar.bz2 解压缩后将得到一个名为alsa-plugins-1.1.5的目录。在该目录中,可能会包含一些安装说明或配置文件,可以阅读这些文档以了解如何编译和安装alsa-plugins。 一般来说,编译和安装软件需要在终端中使用一系列命令。通常的步骤包括配置软件、编译软件和安装软件。具体步骤可能因软件的不同而有所不同,所以建议参考安装说明或官方文档以获得详细指导。 安装成功后,alsa-plugins将被安装在系统中,并且可以在相关的应用程序或设置中使用。alsa-plugins提供了丰富的音频处理插件,可以用于音频播放、录制和处理等多种场景。通过这些插件,用户可以增强音频性能、改善音质、添加音效等。 总之,alsa-plugins-1.1.5.tar.bz2是alsa-plugins软件版本1.1.5的压缩包,解压缩后即可获取该软件的源代码和文件。安装该软件可以提供丰富的音频处理插件,以改善Linux操作系统中的音频功能和体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值