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操作系统啊,这是不是就是大牛创建这些不兼容文件的原因呢。

相关推荐
深紫色的三北六号3 小时前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash7 小时前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
ursazoo10 小时前
写了一份 7000字指南,让 AI 帮我消化每天的信息流
人工智能·开源·github
小兵张健14 小时前
Playwright MCP 截图标注方案调研(推荐方案1)
前端·javascript·github
哈基咪怎么可能是AI17 小时前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行1 天前
Linux和window共享文件夹
linux
九狼1 天前
Flutter URL Scheme 跨平台跳转
人工智能·flutter·github
逛逛GitHub2 天前
4 个热门的 GitHub 开源项目
github