玩openwrt的基础
玩openwrt的基础
参考
名词解释
openwrt
openwrt就是一个基于linux的系统,可以运行在路由器上,可以安装软件,实现不同的功能,例如认证校园网,ftp,挂pt做种。。。。优点多 https://zh.wikipedia.org/wiki/OpenWrthttp://baike.baidu.co m/item/openWRT
固件
固件就是操作系统啦,和windows10/8/7.。。。。的一样,路由器等设备上称他们的系统为固件,固件的版本叫发行版,就像windows10/8/7就是不同的“发行版”吧,肯定就有稳定版,测试版/开发版(嗯,叫啥不重要,我也不知道具体叫啥,意会吧)
源
源就类似于手机的应用商店,我们可以在这里下载软件和固件,还可以获取源代码自己编译软件,系统
boot loader
路由器开机过程 上电+略略略+boot loader加载---》引导系统----》略略略。。。。。boot loader就是个引导程序,像电脑的BIOS,现在路由器上使用的boot loader有第三方的breed ,uboot,还有就是路由器自带的。boot loader也可以帮助我们给路由器装系统,备份系统之类的路由器开机前按住reset键,通电,一会会就进入boot load的操作环境(breed,uboot提供网页端操作,网件自带boot loader提供tftp刷机通道)具体boot loader和路由器型号不同存在差异
恢复系统时推荐保留原有bootloader (我没保留,出现意外,bootload没有了,只得编程器刷机)如果bootload没有了,可使用,ttl刷机或者把flash拿下来用编程器刷机,不同的flash类型针脚不一样,编程器不通用
cpu
路由器也有cpu,也有不同的类型,例如ar71xx,略
内存
就类似计算机的内存,略
flash
Flash内存,也叫闪存,是路由器当中常用的一种内存类型。它是可读写的存储器,在系统重新启动或关机之后仍能保存数据。
openwrt的网站
首先从这个网站https://downloads.openwrt.org/开始,是openwrt的官方下载站,也有镜像站如https://openwrt.proxy.ustclug.org这个网站很像一个文件夹,一层层的目录,我们要进去找东西
固件发行版
我们看到第一个就是最新的Chaos Calmer 15.05.1系统,还有历史的Barrier Breaker 14.07,Attitude Adjustment 12.09版本
网站目录
点击最新版本Chaos Calmer 15.05.1,依次选择自己路由器对应的CPU类型(例如ar71xx),Flash类型(例nand)
该目录下的重要文件
packages 软件仓库,软件ipk和它们的源代码OpenWrt-ImageBuilder-15.05.1-ar71xx-nand.Linux-x86_64.tar.bz2 openwrt的源代码,我们可以用这个根据自己路由器来编译合适的固件官方支持的路由器的固件 可以ctrl+f搜索自己路由器的类型,找到适合自己路由器的固件img的格式是在bootload界面刷机用的,tar格式是在路由器web界面升级用的有的还有bin格式的,里面是二进制,可以通过编程器刷机,breed和uboot好像也支持此格式
路由器选购
玩openwrt首先得有个路由器是吧话说怎么挑路由器我也不懂,cpu的性能,内存说不清楚,只能有些建议
1.CPU需要openwrt支持2.flash,入门8M,可玩16M,我现在用的NETGEAR WNDR3700v4 128M ,使用到现在我刚使用12.4M3.内存,大内存在路由器挂pt做种时很有利,我的128M内存做种时利用率达98%4.型号相同,版本不同的路由器可能缩水了flash和内存,注意版本 如3700v4 还是 3700v1,5.flash和cpu的型号相同,教程也一样,不要纠结于型号不同,买贵得就好了呀(ノ゚∀゚)ノ6.usb接口,当然得要,拓展功能,flash小了还可以把软件装在usb拓展的U盘/硬盘里7.最后建议淘宝,可让淘宝店主升级内存和flash,最好是店主帮忙刷好了openwrt或者不死uboot/breed(当然,NETGEAR这种自身bootloader可以tftp刷机就很优秀的不用刷)
需要的技能点
简单的linux命令
vi,cd,mv,cp
远程管理
Xshell或类似软件用于ssh,telnet登录openwrt或者ubuntu等Linux系统WinSCP或类似软件支持ssh就可以使用scp协议连接路由器,用户名密码为ssh的用户名和密码 用于使用scp或者ftp协议登录openwrt或者ubuntu等Linux系统进行文件修改可以在很大程度上减少vi cd mv cp等Linux有关文件操作的命令,而且图形化界面操作方便
推荐的网站
https://www.google.com/openwrt官网openwrt的开源代码仓库可以获得openwrt及软件的源代码openwrt官方下载站(源)科大的镜像开源下载站清华的镜像开源下载站仅含chaos_calmer版本恩山无线论坛我遇到问题都google了,发现很多问题这个论坛都有,但我从没有专门看这个论坛
如何为SD卡与NAND Flash的uboot加上menu菜单
亲爱的卡友们,如果看完文章之后还是有疑惑或不懂的地方,请联系我们,自己去理解或猜答案是件很累的事,请把最麻烦的事情交给我们来处理,术业有专攻,闻道有先后,深圳市雷龙发展专注存储行业13年,专业提供小容量存储解决方案。 【SD NAND】用ok6410进行烧写时,每次都需要敲一大堆命令,又费时又费力。 记得以前用TQ2440时,u-boot启动时会有一个菜单,只按一个数字键就把内核烧好了,非常方便。 现在这张SD卡功能就很全面了,不仅能够直接从SD卡启动,而且还可以烧写NAND Flash中的u-boot zImage rootfs,呵呵。 下面就把这个功能加到ok6410的u-boot 中去。 一、修改SD卡的u-boot1.1.6 1. common/main.c中 void main_loop (void) { …… if(bootdelay>=0&&s&&!abortboot(bootdelay)){ } //如果在启动过程中有按键,打断了执行过程的话 run_command("menu",0); //如果menu返回的话,就进入u-boot的shell中 #ifdef CFG_HUSH_PARSER parse_file_outer(); …… } 2. 执行menu的过程 run_command("menu", 0),最终会执行do_menu. do_menu 开始时先打印出命令菜单,然后根据不同的选择,执行不同的命令。 所以添加的文件 common/cmd_menu.c,如下: #include #include #include #include void print_menu_usage(void) { printf("rn##### SD boot Menu#####rn"); printf("[1] Download u-boot bootloader to Nand Flashrn"); printf("[2] Download Linux Kernel to Nand Flashrn"); printf("[3] Download CRAMFS image to Nand Flashrn"); printf("[4] Download YAFFS image to Nand Flashrn"); printf("[5] Boot the systemrn"); printf("[6] Format the Nand Flashrn"); printf("[0] Set the boot parametersrn"); printf("[a] Download User Program (eg: uCOS-II or TQ2440_Test)rn"); printf("[b] Download LOGO Picture (。bin) to Nand Flash rn"); printf("[q] quit from menurn"); printf("Enter your selection: "); } intdo_menu(cmd_tbl_t*cmdtp,intflag,intargc,char*argv[]) { intc; char cmd_buf[200]; while(1) { print_menu_usage(); c=getc(); printf("%cn",c); switch(c) { case'1': { strcpy(cmd_buf,"fatload mmc 0:1 50008000 u-boot.bin_nand; nand erase 0 100000; nand write.uboot 50008000 0 10000"); run_command(cmd_buf,0); break; } case'2': { strcpy(cmd_buf,"fatload mmc 0:1 50008000 zImage_nand; nand erase 100000 500000; nand write.e 50008000 100000 500000"); run_command(cmd_buf,0); break; } case'3': { //strcpy(cmd_buf,"fatload mmc 0:1 50008000 u-boot.bin; nand erase 0 100000; nand write.uboot 50008000 0 10000"); //run_command(cmd_buf,0); break; } case'4': { //strcpy(cmd_buf,"fatload mmc 0:1 50008000 rootfs.yaffs; nand erase 600000 4A4000; nand write.yaffs2 50008000 600000 4A4000"); //strcpy(cmd_buf,"fatload mmc 0:1 50008000 rootfs.yaffs; nand erase 600000 $(filesize); nand write.yaffs2 50008000 600000 $(filesize)"); //注意:nand erase 600000 $(filesize),假设有坏块的话,这样会有数据不能写入, 所以这个地方可以固定一个较大值,如 // 0x1400000=20M,所以rootfs.yaffs的大小不能超过20M, //考虑此处是不是要加上NAND Flash分区: nand erase root,把整个的root分区全部擦除,这样就不必担心是否有坏块的问题了 strcpy(cmd_buf,"fatload mmc 0:1 50008000 rootfs.yaffs; nand erase 600000 1400000; nand write.yaffs2 50008000 600000 $(filesize)"); run_command(cmd_buf,0); break; } case'5': { strcpy(cmd_buf,"bootm 50008000"); run_command(cmd_buf,0); break; } case'q': return; default: printf("command not foundn"); break; } } } U_BOOT_CMD( menu,5,1,do_menu, "menu - manipulate BMP image datan", "menu long help: TNND mu you" ); 3. 添加到Makefile中 最后在common/Makefile中添加一行 COBJS+=cmd_menu.o 注意:在组合命令时,如NAND write不知道烧写的大小怎么办? 没关系,有变量 $(filesize), 只要加上这个任何问题都不再困难。 上面的50008000是从SD卡启动时,要读到的内存地址; 若是从Nand Flash启动要把上面的50008000改为C0008000 二。 测试一下 2.1 sd卡 a. 因为都是从SD卡和第一个分区读数据,所以将SD卡分区时第一个分区格式必须为FAT32. b. 编译u-boot.bin: 代码要用光盘中带的u-boot,这个支持从NAND Flash 启动 make forlinx_nand_ram256_config, 后生成 u-boot.bin 复制到SD卡的第一个分区, 并改名为 u-boot.bin_nand(要与u-boot代码中的名称保持一致) c. 编译zImage 代码要用光盘中带的linux-3.0.1, make后生成zImage 复制到SD卡的第一个分区, 并改名为 zImage_nand(要与u-boot代码中的名称保持一致) d. 生成rootfs.yaffs 可以用光盘中带的FileSystem-Yaffs2.tar.gz, 解压后,嫌太大,把不需要的删掉, 里面的busybox好像是动态链接的,自己编个静态的busybox,最后生成rootfs.yaffs sudo /opt/6410/4.3.2/bin/mkyaffs2image-nand2g FileSystem-Yaffs2 rootfs.yaffs NAND Flash 是2G的所以要用命令 mkyaffs2image-nand2g 将rootfs.yaffs复制到SD卡的第一个分区(要与u-boot代码中的名称保持一致) 注意: 如果不确定rootfs本身有没有问题,可以先从nfs启动,看是否正常。 如果正常再用mkyaffs2image-nand2g,做成yaffs镜像烧入到NAND Flash中。 亲爱的卡友们,如果看完文章之后还是有疑惑或不懂的地方,请联系我们,自己去理解或猜答案是件很累的事,请把最麻烦的事情交给我们来处理,术业有专攻,闻道有先后,深圳市雷龙发展专注存储行业13年,专业提供小容量存储解决方案。
相关问答
Uboot 设备树如何移植?移植方法:你只能通过NandFlash控制器访问NandFlash,即是只要知道Nand控制器的寄存器地址即可。NandFlash不是一个RamLike的器件。Uboot放入nand中,在nand...
cpu的spl是什么?SPLSPL是uboot第一阶段执行的代码.主要负责搬移uboot第二阶段的代码到内存中运行.SPL是由固化在芯片内部的ROM引导的.我们知道很多芯片厂商固化的ROM支持...