【notes1】VMware,linux命令,samba服务器,pip/office/pi/版本/dts

2024-05-07 01:44

本文主要是介绍【notes1】VMware,linux命令,samba服务器,pip/office/pi/版本/dts,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1.VMware/CRT:netstat -nal | grep 22
    • 1.1 VMware:netstat -anp|grep ssh,vi /etc/ssh/sshd_config放开Port 22,service sshd restart,chkconfig可将sshd加入到系统服务中开机后sshd将自动启动:chkconfig sshd on
    • 1.2 CRT:改注册信息要打开CRT客户端在最上端Help栏中Enter License Data
  • 2.linux命令:tcpdump数据包获取,nc网络调试,vmstat进程信息和内存使用
    • 2.1 用户管理及权限:p是指管道文件,chmod 777
    • 2.2 find:找文件
    • 2.3 grep:找文件中内容
    • 2.4 cat/more:查看文件全部内容
    • 2.5 head/tail:查看文件部分内容
    • 2.6 iNode:磁盘中块和扇区
    • 2.7 打包和解压:tar命令必须和-f命令连用, 选项f后的文件档名.tar,如果加z选项,则以.tar.gz或.tgz
    • 2.8 正则:\d,?* +这些是[a-z]{m,n}这些的简写
    • 2.9 sed:管道过滤(替换,删除),sed -i 's/\r//g' 文件(删除从txt复制来代码的换行符)
    • 2.10 awk:-F指定分隔符,-V设置变量,NF列数,$NF是一行数据最后一列的值,多用于对字段(像数据库中的字段)
  • 3.Samba服务器:利用文件传输协议:ftp,http,SMB(Samba)
    • 3.1 隐藏共享和拒绝访问:无法在网上邻居看到我们所共享的文件夹,但是通过unc路径做具体指定,我们可以访问到该文件夹下
    • 3.2 别名:别名配置文件要自己建立
    • 3.3 免登陆名:启用share级别(安全性最低,不需要通过用户名认证)
    • 3.4 linux访问windows共享目录:mount
  • 4.pip/ffmpeg/office/pi:su直接切换root,需输入root密码。sudo su/-i:当前用户暂时申请root权限,需输入当前用户密码
    • 4.1 pip换源:curl ipinfo.io 查公网出口ip,ctrl + H 显示隐藏文件
    • 4.2 shapely:https://www.lfd.uci.edu/~gohlke/pythonlibs/ 或pypi网
    • 4.3 ffmpeg压缩并拼接音频:.wav到.mp3
    • 4.4 office:下载visio:http://www.itellyou.cn/用迅雷复制链接下载,https://smallpdf.com/pdf-to-jpg
    • 4.5 双系统安装:Ubuntu镜像网站http://mirrors.ustc.edu.cn/ubuntu-releases/16.04/
    • 4.6 版本:os-release.bb,classes/openbmc_version.bbclass(version = "...")
    • 4.7 cdc模块:cycle cpu时,usb0设备会注册,如果去除cdc相关驱动,ifconfig usb0会有device not found 报错
    • 4.8 dts:tree /sys/class/i2c-dev/,查看系统有多少I2C的Adapter
  • 8.设备树:dts=device,of_api读取dts中属性,参考include/linux/of.h


1.VMware/CRT:netstat -nal | grep 22

1.1 VMware:netstat -anp|grep ssh,vi /etc/ssh/sshd_config放开Port 22,service sshd restart,chkconfig可将sshd加入到系统服务中开机后sshd将自动启动:chkconfig sshd on

VMware15和CentOS6.9:链接:https://pan.baidu.com/s/1HV6WqUTAwlOSjWkLXVrCRw ,提取码:1x8e 。VMware15【CG392-4PX5J-H816Z-HYZNG-PQRG2】直接下一步安装,右击图标属性 - 兼容性 - 更改所有用户的设置 - 勾上以管理员身份运行此程序。
在这里插入图片描述
点击创建新的虚拟机:自定义(高级)-稍后安装操作系统-linux-版本centos6 64位-D:\vm.\cent0s6-使用仅主机模式网络-将虚拟磁盘存储为单个文件(动态分配20G硬盘)。

编辑虚拟机设置:选中网络适配器添加-CD/DVD使用CentOS6的iso文件(开启此虚拟机出问题:控制面板-卸载程序-Microsoft Visual C++的两个x64和x86文件右击卸载,不点卸载,点修复再重启计算机)。

开启虚拟机安装操系:默认第一个install,方向键选择红色的Skip(跳过)回车。两个网卡注意要配置网络自动连接。使用所有空间-将修改写入磁盘-Basic Server。鼠标退出虚拟机用ctrl+alt,将一个小窗口移至虚拟机前就可以用QQ截图。
在这里插入图片描述

1.2 CRT:改注册信息要打开CRT客户端在最上端Help栏中Enter License Data

ssh客户端软件SecureCRT8.5:链接:https://pan.baidu.com/s/1Y74YVz2ysQ3rFjGjnthb1Q ,提取码:l8gb 。解压后如下所示:
在这里插入图片描述
右击以管理员身份运行上图的scrt…exe文件,安装完后桌面出现图标先不要点击运行,将上图注册机文件夹里的keygen.exe复制到下图默认安装路径文件夹中,并右击以管理员打开keygen.exe出现如下图黄色窗口。
在这里插入图片描述
在如下License中不用去除中括号,写入SecureCRT.exe中去除,Patch连到SecureCRT.exe和LicenseHelper.exe。
在这里插入图片描述
第一次打开下图进行填写注册信息按照上图黄色窗口对应写入,上面patch到就是下面这个.exe文件。
在这里插入图片描述
在这里插入图片描述
配置会话的属性,在会话上点击属标右键,选择Properties的Terminal。每30秒向服务器发送一次心跳。SSH2。Hostname:192…。Port:22。Username:root
在这里插入图片描述
修改Centos的字符集,增加对中文的支持: 登录服务器,输入 su – root 回车后再输入密码,切换到root用户(超级用户,有的远程服务器没权限)。修改字符集:echo LANG="zh_CN.gbk" > /etc/sysconfig/i18nexport LANG="en_US";export LANGUAGE="en_US";export LC_ALL="en_US";

修改时区为亚州上海时间,在root下执行并输入y:
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime。date (不是data)查看系统时间:date -s修改时间,date -s 2019/07/31,date -s 10:24:00 。date -s ‘2020-01-01 11:11:11’。
在这里插入图片描述
https://www.usb-drivers.org/ft232r-usb-uart-driver.html。
在这里插入图片描述

2.linux命令:tcpdump数据包获取,nc网络调试,vmstat进程信息和内存使用

2.1 用户管理及权限:p是指管道文件,chmod 777

在这里插入图片描述
在这里插入图片描述

nohup java -jar a.jar & ( jobs命令查看这个后台任务的编号 )netstat -ntlp查看运行程序的端口。
kill -9 %1(这个1就是jobs命令的1编号)。
top -d/n 1
内存条:dmidecode |grep -P -A5 "Memory\s+Device"|grep Size|grep -v Range
ps -ef | grep memtester | grep -v grep | cut -c 9-16 | xargs kill -9

2.2 find:找文件

过滤一下看文件大小:-print0将如上三行打印为1行并用null即‘\0’隔开,再用xargs -0即用‘\0’再分开(原因是默认管道到下一个里面空格会出错)。
在这里插入图片描述
如上/是整个系统搜索慢,如下是当前路径搜索快。
在这里插入图片描述
日志文件没清空非常大,要找到删除,如下找系统中大文件,超过10M。
在这里插入图片描述
如下查找文件夹,文件夹有相应名字或大小属性。
在这里插入图片描述
如下基于修改时间,time是天。-1:今天一天之内。1:1天前这一天。+1:1天前。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
如下指定最大文件深度。
在这里插入图片描述
如下是find指令总结。
在这里插入图片描述

2.3 grep:找文件中内容

在这里插入图片描述
如下* 可换成 * .txt
在这里插入图片描述
-r:递归子路径,-n:显示行号。-i:忽略大小写。
在这里插入图片描述
如下用于java日志文件非常大,要grep出某个异常如ioexception,且需要打印出exception下面几行看什么出了错。
在这里插入图片描述
在这里插入图片描述
如下.中的\是转义符,.168这样重复3次(注意168前面有.,不是168,而是数字)。
在这里插入图片描述
在这里插入图片描述

2.4 cat/more:查看文件全部内容

cat的文件非常大,非常占用cpu和内存,这时候可以每次读取一小部分。
在这里插入图片描述
如下通过空格往后翻页。
在这里插入图片描述
如下指定从第四行开始读。
在这里插入图片描述
如下查看前后10行。
在这里插入图片描述
在这里插入图片描述

2.5 head/tail:查看文件部分内容

在这里插入图片描述
如下打印文件最后两行,tail -f 阻塞监控。
在这里插入图片描述
df -h查看磁盘使用,占用率太高就需要使用前面find,grep指令并进行删除。
在这里插入图片描述
题目:输出当前路径及当前路径子路径下所有.txt文件,要求大小超过1M,并且按照从大到小顺序进行排序输出前10个?
先通过find . -name '*.txt' -size +1M -type f 查看是否有大于1M的txt文件,没有的话就不用继续了。
再通过find . -name '*.txt' -size +1M -type f -print0|xargs -0 du -m|sort -nr|head -10

2.6 iNode:磁盘中块和扇区

linux文件系统中iNode用来存储文件原数据信息,不存储文件内容原数据信息包括:
类型:这个文件是个目录还是普通文件。
拥有者:这个文件是owner还是group owner。
时间ctime:上次inode变动时间。atime:上次访问时间。mtime:上次文件内容发生变动时间。
连接数:有多少文件名同时指向inode。一个文件名只对应一个inode,但一个inode可能被多个文件名同时指向。
文件内容所在的位置:文件真正内容所在磁盘块的标号。

1.文件系统fs在格式化好后,inode以什么样格式存储的呢?整个inode以数组形式存储,每个元素是一个inode,每个inode大小根据当前文件系统以及整个磁盘大小,inode会有一个固定128或256字节大小。

2.除了inode数组,fs初始化好后还会生成一个Map映射关系表(存储filename和inode index)。现在要读取/ect/1.txt,整个过程怎么样先根据文件名到Map中找到inode index,找到下标为假如是3的inode后拿出来如下图左边整个框。当前在读取/ect/1.txt,所以查看是否有读权限,如果有读权限就继续往下,找到文件内容所在位置(磁盘上块的下标)。
在这里插入图片描述
文件内容在磁盘中存储区域如下:以进行分隔,每个块大小也是根据当前fs和整个磁盘大小决定,并不是一个特定大小【扇区在磁盘生产时有多少个扇区,每个大小是定的,早期扇区512byte,现在4k】。文件系统fs在文件访问过程中不可能直接使用扇区,扇区是硬件的概念,所以抽象出一个概念:fs角度去看最小文件存储单元就是块,一个块可以有一个或多个扇区组成(2的幂次方即1,2,4…个扇区)。
在这里插入图片描述
一个块采用多少扇区也是有权衡的,比如一个块有好几兆,存一个1k文件也要占一个文件块,造成磁盘空间浪费。块选择过小的话也不好,如果一个块大小1bit,导致一个文件假如是1kb,它所在的块由1千个块组成,在inode中存储文件内容所在位置这个字段时候造成存1千个块信息(1千个块下标),一个inode(存1千个块下标)不可能128/256字节大小了,一个inode会很大,进而导致inode数组会很大,整个inode区大,这样导致磁盘损耗大量空间存储inode信息,较少的空间存储真正文件内容。

即使进行权衡,目前存在问题,如经常听到inode用完了即inode数组初始化大小用完了,声明完数组大小后不能增加或减少了。inode数组用完了即使磁盘还有额外空间也不能存储文件了,常见特别零碎文件数量又特别多占据磁盘大量inode导致整个inode用完。如早期docker采用overlay文件存储格式导致镜像的碎文件很多,导致inode用尽这样问题,后面采用overlay2文件存储格式一定程度上解决了这问题。

查看linux系统中inode数组以及每个文件所对应inode标号:df -i(inode),查看当前文件夹下文件所在的inode标号是什么ls -il。访问1.txt先查文件名和inode标号映射即Map,1.txt能找到270306这个标号。根据这个标号到1183200这个数组中拿取第270306个标号的inode。根据这个inode信息查看权限,最终找到1.txt在磁盘中存储位置,最后把这些磁盘块进行读取,最终读取到1.txt这个文件。
在这里插入图片描述
在这里插入图片描述
如果是一块移动硬盘,在其他设备上创建了文件,把这个移动硬盘拿到linux上面,有没有inode呢?
1.os可以支持多种fs。2.inode是在ext2/3/4等linux支持的文件系统(fs)有的。所以移动硬盘看是什么文件系统了,如果是ntfs或者exfat、fat32等等就是另一种访问形式了,inode其实是文件系统里的概念,而不是linux的概念。
在这里插入图片描述

#include <stdio.h>
#include <dirent.h>int main() {DIR *dir;struct dirent *node;dir = opendir("."); // 打开当前目录if (dir == NULL) {printf("无法打开目录\n");return 1;}while ((node = readdir(dir)) != NULL) {  // 遍历目录, node->d_name是文件或目录名if (node->d_type == DT_REG) {printf("文件: %s,%d\n", node->d_name, DT_REG);    // DT_REG:8} else if (node->d_type == DT_DIR) { printf("目录: %s,%d\n", node->d_name, DT_DIR);    // DT_DIR:4} else if (node->d_type == DT_LNK) { printf("符号链接: %s,%d\n", node->d_name,DT_LNK); // DT_LNK:10} else {printf("其他类型: %s\n", node->d_name);}}closedir(dir);return 0;
}

2.7 打包和解压:tar命令必须和-f命令连用, 选项f后的文件档名.tar,如果加z选项,则以.tar.gz或.tgz

tar只是打包,并不压缩或解压。
-c: 建立压缩档案
-x:解压
-t:查看内容
-j, --bzip2
-z, --gzip, --gunzip --ungzip
-v, --verbose 详细列出处理过的文件
-f, --file ARCHIVE 使用存档文件或设备存档(指定存档文件),切记,这个参数是最后一个参数,后面只能接档案名。

在这里插入图片描述

2.8 正则:\d,?* +这些是[a-z]{m,n}这些的简写

^[]$:中括号内部只匹配一个字符。
在这里插入图片描述
\d:相等于[0- 9],中括号里是什么或什么。\D:相等于[^0- 9],除了0到9外的任意字符。如下匹配数字\d 数字外任意字符\D(也就是匹配任意字符)。
在这里插入图片描述
\w:字母,数字或下划线,常用于用户名的命名上。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
组group:如上只想获取@前面的用户名,上面中括号,大括号都出现了,就差如下小括号。first就是组名,右边是js语法,underfined因为没命名。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.9 sed:管道过滤(替换,删除),sed -i ‘s/\r//g’ 文件(删除从txt复制来代码的换行符)

如下将逗号替换为空格。s表示替换,g表示全局,即行中所有匹配项都被替换。sed -i ‘s/sys_led/sys_url/g’ /home/sysfs1/s3ip_sysfs_frame/sysurl_sysfs.c。
在这里插入图片描述
^匹配行首,$匹配行尾,如下d删除空行或只包含空格的行(因为行首行尾中间为空)。
在这里插入图片描述
sed常用于管道过滤,如下把x替换成y。
在这里插入图片描述
如下-r打开扩展正则,将逗号换成TAB。sed -n ‘60,70p’ a.txt :查看文件第60-70行。
在这里插入图片描述

2.10 awk:-F指定分隔符,-V设置变量,NF列数,$NF是一行数据最后一列的值,多用于对字段(像数据库中的字段)

如下按逗号分隔并打印分割后的第三列和第四列,默认用空格/制表符/换行符作为字段分隔符。
在这里插入图片描述
如下BEGIN指定了处理文本之前需要执行的操作。END指定了处理完所有行之后所需要执行的操作。
在这里插入图片描述
如下按逗号分隔并打印最后一列内容。
在这里插入图片描述
在这里插入图片描述
对比上面,如下一行一行读取并打印,列数>0打印。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
如下-c统计个数。
在这里插入图片描述
如下2是个数,不是序号。
在这里插入图片描述
在这里插入图片描述

3.Samba服务器:利用文件传输协议:ftp,http,SMB(Samba)

win下更改ip:本地连接右击属性,更改适配器。@market指market组。
在这里插入图片描述
在这里插入图片描述
如下将本地用户转变为samba用户即共享用户。通过如下转变可实现该用户通过客户端访问服务器时提供验证标准了。
在这里插入图片描述
如下都是在文件末尾新添加的内容,都是逗号,writeable=no指除了下行外都不能写。[manager]是共享名即对方能看到的网络文件夹名称,comment是可共享目录的描述信息(可加可不加),valid_users指谁可以访问。
在这里插入图片描述
在这里插入图片描述

3.1 隐藏共享和拒绝访问:无法在网上邻居看到我们所共享的文件夹,但是通过unc路径做具体指定,我们可以访问到该文件夹下

windows里只需在共享文件夹名后面加一个$符号就能实现隐藏共享了。linux的samba中需修改主配置文件。如下将manager目录做一个隐藏。
在这里插入图片描述

3.2 别名:别名配置文件要自己建立

在这里插入图片描述

3.3 免登陆名:启用share级别(安全性最低,不需要通过用户名认证)

在这里插入图片描述

3.4 linux访问windows共享目录:mount

在这里插入图片描述
在这里插入图片描述
如上操作后share文件夹就有读写权限了。如下设置win账号,因为默认禁止空密码登录。
在这里插入图片描述

4.pip/ffmpeg/office/pi:su直接切换root,需输入root密码。sudo su/-i:当前用户暂时申请root权限,需输入当前用户密码

4.1 pip换源:curl ipinfo.io 查公网出口ip,ctrl + H 显示隐藏文件

pip install速度慢,用pip换源:进入python,看os在哪个py脚本里即python工作路径在1下,所以在1下建pip文件夹可以执行。
在这里插入图片描述
在桌面新建pip文件夹再拖进1,在pip里新建.txt,再改为.ini文件,点击打开输入下面代码保存。
在这里插入图片描述
apt install python3-pip --fix-missing(断开vpn,cp /etc/apt/sources.list /etc/apt/sources.list.bak,python3 -m pip install --upgrade pip,apt-get update,pip install 包名 -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com)
在这里插入图片描述
三个源:https://pypi.tuna.tsinghua.edu.cn/simple,https://pypi.douban.com/simple,https://mirrors.aliyun.com/pypi/simple
upgrade升级下numpy,看下载速度:pip install numpy -U

以上为windows换源,下面为ubuntu换源同理:cd ~mkdir .pipcd .pipgedit pip.conf,将以下内容复制到pip配置文件pip.conf中,保存退出即可。

[global]
index-url = http://mirrors.aliyun.com/pypi/simple/
[install]
trusted-host = mirrors.aliyun.com (上面http地址中间一部分,这行为了获取ssl证书,不然会报错)

4.2 shapely:https://www.lfd.uci.edu/~gohlke/pythonlibs/ 或pypi网

在这里插入图片描述
到所在文件夹:pip install Shapely-1.6.4.post1-cp37-cp37m-win_amd64.whlconda install python==3.7
No module named ‘numpy.core._multiarray_umath’:pip install numpy -U -i https://pypi.tuna.tsinghua.edu.cn/simple/
No module named 'cv2.cv2:pip install opencv-python 出错:如上面下载对应版本再pip install,python -V pip -V
在这里插入图片描述
在这里插入图片描述

4.3 ffmpeg压缩并拼接音频:.wav到.mp3

ffmpeg压缩软件链接为:链接:https://pan.baidu.com/s/1Pn1y76_HQULm9c7xaTrMXw 提取码:uvg4。
压缩:将解压后的ffpeg软件和录音文件放在同一文件夹下,并在当前文件夹cmd,在cmd中输入命令并运行:ffmpeg -i "1.wav" -b:a 64k -acodec mp3 -ar 44100 -ac 1 "1.mp3"
-i "1.wav"表示输入,后面的文件名必须要用双引号
-b:a 64k表示音频的码率为64kb/s,即8kB/s
-acodec mp3表示设定声音编解码器为mp3
-ar 44100表示设定采样率为44100
"1.mp3"表示输出保存的文件名
在这里插入图片描述
拼接:新建文本list.txt,复制下内容到其中

file '1.mp3'
file '2.mp3'
file '3.mp3'

cmd输入:ffmpeg -f concat -i list.txt -c copy "all.mp3",产生all.mp3即拼接好了。
在这里插入图片描述

4.4 office:下载visio:http://www.itellyou.cn/用迅雷复制链接下载,https://smallpdf.com/pdf-to-jpg

在这里插入图片描述
安装到了D盘里:D/office/Office15/VISIO.EXE。KMspico工具安装成功后,Visio同时也正常使用了,不需要任何操作。链接:https://pan.baidu.com/s/1hRGadTjU7cPqMTqaghVFSQ 提取码:e49y

如下关于office2013,mathtype,Axmath:链接:https://pan.baidu.com/s/1XJ9KBQeKxPqjIA692f1J9Q 提取码:tyi5 ,点下图红框标出进行安装:
在这里插入图片描述
复制下图文件到上图文件夹位置进行替换。
在这里插入图片描述
win10关闭更新:此电脑-管理-服务-双击windows update。
在这里插入图片描述
选择文件夹右击"授权访问权限",选择"特定用户",添加"所有人",权限改为"读取与写入",以共享方式访问,就可删除文件夹了,还有删除里面文件就可删除文件夹了。
在这里插入图片描述
1.内存卡插入读卡器再插入电脑的usb接口,将u盘格式化为FAT32格式。如果右击格式化没有FAT32则用格式化fat32工具:http://www.ridgecrop.demon.co.uk/guiformat.exe。树莓派系统官网:https://www.raspberrypi.org/downloads/raspbian/。下载系统(1.9G)用写盘工具(https://www.balena.io/etcher/或win32diskimager)将系统写入u盘,写完后不要格式化其他盘。

2.树莓派插上内存卡,接上网线(网络认证)或连上wifi(连wifi,eth0信息为空,因为没有连接网线,wlan0显示内网ip)用ifconfig查看网络。service ssh start开启ssh服务,树莓派默认用户名pi,密码raspberry,sudo netstat -antp可查看到当前有22端口即ssh端口被监听,这时可关闭显示器。如果忘了树莓派内网ip,可用win下cmd中输入arp -a查看局域网下所有ip和mac对应。本电脑就可以ssh连接树莓派再通过picocom -b 115200 /dev/ttyUSB0(有实际的线连)连接到机器终端,minicom -D /dev/ttyUSB0 登不上时进入/var/lock,删除lockfile,minicom又可正常启动。
在这里插入图片描述

4.5 双系统安装:Ubuntu镜像网站http://mirrors.ustc.edu.cn/ubuntu-releases/16.04/

在这里插入图片描述
如下图先删除所有,再在驱动1即固态上新建满存再应用,默认被分成4个区,选中分区4安装win10。
在这里插入图片描述
此电脑右击管理到磁盘管理(或搜索磁盘管理选择创建并格式化分区),右击删除卷(或压缩卷)到未分配,右击新建简单卷再命名。压缩卷C盘分出50G装ubuntu,ubuntu自动识别未分配空间。

软碟通Ultraiso将从itellyou下载的win10镜像(用户customer版64位,复制链接迅雷下载)或ubuntu镜像写入U盘,Boot设置为UEFI启动U盘,legacy为老版本不用。下面两图都为f2。注意f12选择UEFI OPTIONS:USB1…启动,进入安装界面会提示与其他系统共存。
在这里插入图片描述

4.6 版本:os-release.bb,classes/openbmc_version.bbclass(version = “…”)

在这里插入图片描述

build$ strings ./tmp/deploy/images/obmc-hq/flash-obmc-hq  | grep U-Boot 
U-Boot 2016.07 v1.0a.00 (Mar 07 2024 - 06:54:47 +0000)build$ cat ./tmp/work/obmc_hq-fb-linux-gnueabi/obmc-hq-image/1.0-r0/rootfs/etc/issue 
OpenBMC Release v1.0a.00# sv restart sensor-mon,  ./sy..sh生成yocto文件夹# 如下aliases.sh(在rootfs/etc/procfile.d, 参考环境变量章节)同init.d/setup_*.sh上电启动脚本。
alias ls='ls --color=auto'
alias i="ip addr show | grep 'inet '| grep ' eth0' | grep -v '240.1.1.1' | awk '{print $2}'|awk -F "/" '{print $1}'"
alias a="python3 /usr/local/bin/board_setup_routes.py"
PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin    #在脚本中只能对这行下面的执行脚本的路径生效,不能对外面的shell窗口生效,在shell窗口命令行下PATH=,echo $PATH才生效。# if [ -f /sys/bus/i2c/devices/48-0058/mfr_id ]; then ln -snf /sys/bus/i2c/devices/48-0058/mfr_id /sys_switch/psu/psu1/model_name;fi 
# model_name 必须不存在,相当于快捷方式# ln -s $(find /sys/bus/i2c/devices/i2c-42/42-0048/hwmon -name "hwmon*" | tail -n 1)/name /sys_switch/temp_sensor/temp2/alias# pwm:0%(cpld的0即0x0),   50%(cpld的127即0x7f),   100%(cpld的255即0xff)

vscode连接远程服务器报XHR failed:https://update.code.visualstudio.com/commit:d037ac076cee195194f93ce6fe2bdfe2969cc82d/server-linux-x64/stable (切换浏览器下载),拷贝进远程服务器解压如下:
在这里插入图片描述
加载自己驱动如下打印,taints表示污染,在自己的驱动中加入MODULE_INFO(intree,“Y”) 欺骗内核本模块为树内模块解决,modinfo fcbcpld。
在这里插入图片描述

4.7 cdc模块:cycle cpu时,usb0设备会注册,如果去除cdc相关驱动,ifconfig usb0会有device not found 报错

修改148行和226行字符串,打印的CDC报错字符也会改变,定位到module_usb_composite_driver函数。
在这里插入图片描述
在这里插入图片描述

4.8 dts:tree /sys/class/i2c-dev/,查看系统有多少I2C的Adapter

8.设备树:dts=device,of_api读取dts中属性,参考include/linux/of.h

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

chosen { // 不是一个真实的设备,为了uboot向内核传递数据,重点是bootargs参数bootargs = "root=/dev/nfs rw nfsroot=192.168.1.1 console=ttyS0,115200";
};

在这里插入图片描述
如下在linux-aspeed/net/ipv6/addrconf.c中手动死循环,超时从备起。
在这里插入图片描述
用dd if=/dev/urandom of=/dev/mmcblk0 bs=1M count=8000随机写破坏ermmc文件系统后,/var/log里文件被清空,blkid信息为空,断电后从主启,如下脚本进行emmc文件系统格式化和挂载成功,没有卡死切备现象。
在这里插入图片描述
在这里插入图片描述

&spi1 {status = "okay";m25p,fast-read; #########pinctrl-names = "default";pinctrl-0 = <&pinctrl_spi1_default>;flash@0 {  # 不是eepromlabel = "BIOS_flash";status = "okay";};flash@1 {label = "spi1:1";status = "okay";};
};root@sr6115:~# gpioset gpiochip0 147=1
root@sr6115:~# echo spi1.0 > /sys/bus/spi/drivers/spi-nor/bind
[  162.807166] spi-nor spi1.0: w25q512jv (65536 Kbytes)
[  162.813579] ASPEED_FMC_SPI 1e630000.spi: freq: 50MHz
[  162.819234] ASPEED_FMC_SPI 1e630000.spi: read bus width: 2 [0x203c0641]
[  162.826697] ASPEED_FMC_SPI 1e630000.spi: write bus width: 1 [0x00120602]
root@sr6115:~#
root@sr6115:~# cat /proc/mtd
dev:    size   erasesize  name
mtd0: 04000000 00010000 "bmc"
mtd1: 000e0000 00010000 "u-boot"
mtd2: 00020000 00010000 "u-boot-env"
mtd3: 00900000 00010000 "kernel"
mtd4: 02000000 00010000 "rofs"
mtd5: 01600000 00010000 "rwfs"
mtd6: 08000000 00010000 "alt-bmc" 
mtd7: 000e0000 00010000 "alt-u-boot"
mtd8: 00020000 00010000 "alt-u-boot-env"
mtd9: 00900000 00010000 "alt-kernel"
mtd10: 02000000 00010000 "alt-rofs"
mtd11: 01600000 00010000 "alt-rwfs"
mtd12: 04000000 00010000 "BIOS_flash" #上面都是BMC,这行是bios
root@sr6115:~#

BMC升级BIOS失败,dmesg报IIC crash的错,且无法recover:
在这里插入图片描述
修改BIOS代码,修改IIC controller clock与BMC同步为100kHz。ME发出正常波形,升级BIOS时不报错,问题得到fix。
在这里插入图片描述
在这里插入图片描述

这篇关于【notes1】VMware,linux命令,samba服务器,pip/office/pi/版本/dts的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/965982

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念