windows上下载github上的linux内核项目遇到的问题

问题一:clone的时候报错

Cloning into 'G:\github\linux'...

POST git-upload-pack (gzip 27925 to 14032 bytes)

remote: Counting objects: 6012062, done.

remote: Compressing objects: 100% (1031/1031), done.

remote: Total 6012062 (delta 893), reused 342 (delta 342), pack-reused 6010689

Receiving objects: 100% (6012062/6012062), 2.06 GiB | 3.62 MiB/s, done.

Resolving deltas: 100% (4997555/4997555), done.

error: unable to create file drivers/gpu/drm/nouveau/nvkm/subdev/i2c/aux.c: No such file or directory

error: unable to create file drivers/gpu/drm/nouveau/nvkm/subdev/i2c/aux.h: No such file or directory

error: unable to create file include/soc/arc/aux.h: No such file or directory

Checking out files: 100% (61359/61359), done.

fatal: unable to checkout working tree

warning: Clone succeeded, but checkout failed.

You can inspect what was checked out with 'git status'

and retry the checkout with 'git checkout -f HEAD'

一看文件目录,一大堆的红叉叉,git status查看有一大堆的修改,可是我啥也没动啊,郁闷。于是按照建议执行了 git

checkout -f HEAD。

问题二:执行git checkout -f HEAD后还有文件修改

执行git checkout -f HEAD后,红叉叉没了,但还有几个红叹号。

git status查看

搞了好几个钟头还是这个样子,郁闷死了。最后发现原来是linux和windows不兼容的原因。

windows上有些文件名是无法创建文件的,比如aux,com1等,这些是系统保留的设备名。这就是第一个问题为什么clone失败的原因。

第二问题的原因是linux文件名区分大小写,而windows不区分。而linux内核工程里恰好有一些只有大小写不同的文件,在windows下只能创建其中的一个。这导致了git工具的错误。如果把这个文件删除了,git status查看你会发现少了两个大小写不同的文件。

解决方法就是修改文件名。但是这样怎么提交代码呢?还有一直有红叹号看着真不爽。最后得出的结论是想要参与linux内核的开发,还是要用linux操作系统啊,这是不是就是大牛创建这些不兼容文件的原因呢。

相关推荐
2501_912784081 分钟前
Taocarts全链路反向海淘系统实战拆解:一个人+一台服务器,如何做到日处理200单?
运维·服务器·跨境电商·taocarts
程序猿追4 分钟前
在轻量服务器上部署商汤SenseNova U1轻量版全记录
运维·服务器
biter down25 分钟前
5:GUI自动化等待机制
运维·python·自动化
明志数科26 分钟前
数据标注质量评估:从指标体系到自动化质检的完整方案
运维·自动化
青天喵喵32 分钟前
Linux Wi-Fi 实战指南:AP / STA 实战用例(实战篇一)
linux·网络·架构·智能路由器·嵌入式·wi-fi
光影少年35 分钟前
前端浏览器自动化
运维·前端·前端框架·自动化
运维老郭1 小时前
Kubernetes Pod 从创建到运行全流程拆解:5 个阶段 + 排错实录
运维·云原生·kubernetes
广州灵眸科技有限公司1 小时前
瑞芯微(EASY EAI)RV1126B ubuntu系统SDK源码获取
linux·运维·ubuntu
Irissgwe1 小时前
二、Socket编程UDP
linux·网络·网络协议·udp·socket·socket编程
Web打印1 小时前
web打印控件,打印模板分散部署在各客户端本地,修改后需逐台更新,能否统一部署至服务器实现集中维护
运维·服务器