以前做嵌入式试验,在PC下编译好可执行的二进制文件后,再用的FlashFXP完成文件的传输,一旦出错又要重复劳动,比较麻烦,最近想到了用文件挂载,这样在PC下编译好后可以直接做验证。我是参考下面这篇博客的:
http://blog.sina.com.cn/s/blog_9eff16cf010133k8.html。
下面是我的理解:
主要有以下关键词:NFS、端口映射服务portmap、mount、重启nfs和portmap
挂载关键指令:mount -o nolock -t nfs ip:/被挂载路径 挂载路径
关键文件:/etc/exports,即NFS的配置,该文件是存放被挂载的目录,文件的写法见下:
在文件最后加入如下内容:
nfs常用的参数有:
ro 只读访问
rw 读写访问sync 所有数据在请求时写入共享
async nfs在写入数据前可以响应请求
secure nfs通过1024以下的安全TCP/IP端口发送
insecure nfs通过1024以上的端口发送
wdelay 如果多个用户要写入nfs目录,则归组写入(默认)
no_wdelay 如果多个用户要写入nfs目录,则立即写入,当使用async时,无需此设置。
hide 在nfs共享目录中不共享其子目录
no_hide 共享nfs目录的子目录
subtree_check 如果共享/usr/bin之类的子目录时,强制nfs检查父目录的权限(默认)
no_subtree_check 和上面相对,不检查父目录权限
all_squash 共享文件的UID和GID映射匿名用户anonymous,适合公用目录。
no_all_squash 保留共享文件的UID和GID(默认)
root_squash root用户的所有请求映射成如anonymous用户一样的权限(默认)
no_root_squas root用户具有根目录的完全管理访问权限
anonuid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的UID
anongid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的GID
试验:hello_world.
我的NFS配置: /home/xiaock/feilingARM *(rw,sync,insecure,no_root_squash)
配置结束后重启nfs服务,在ubuntu下是:sudo /etc/init.d/nfs-kernel-server restart
我的挂载指令是: mount -o nolock -t nfs 192.168.1.100:/home/xiaock/feilingARM /mnt ip为和路径都是PC上的,mnt是开发板上的
在feilingARM路径下编写helloword并编译:
在开发板上运行得到结果:
root@ok335x:/mnt/OK335XD/project/hello_world# ./hello
Hello world