<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>路径解析 on 大飞的博客</title>
    <link>https://www.dafei.me/tags/%E8%B7%AF%E5%BE%84%E8%A7%A3%E6%9E%90/</link>
    <description>Recent content in 路径解析 on 大飞的博客</description>
    <generator>Hugo</generator>
    <language>zh-cn</language>
    <lastBuildDate>Thu, 04 Jun 2026 08:00:00 +0000</lastBuildDate>
    <atom:link href="https://www.dafei.me/tags/%E8%B7%AF%E5%BE%84%E8%A7%A3%E6%9E%90/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>从零写OS（五十一）：三个崩溃，三个修复</title>
      <link>https://www.dafei.me/posts/os-51-robust/</link>
      <pubDate>Thu, 04 Jun 2026 08:00:00 +0000</pubDate>
      <guid>https://www.dafei.me/posts/os-51-robust/</guid>
      <description>&lt;p&gt;性能优化之后，跑 &lt;code&gt;ls | grep foo&lt;/code&gt; 时发现三类崩溃，分别来自三个不同的地方。&lt;/p&gt;
&lt;h2 id=&#34;崩溃一内核栈溢出&#34;&gt;崩溃一：内核栈溢出&lt;/h2&gt;
&lt;p&gt;&lt;code&gt;ls | grep foo&lt;/code&gt; 在 busybox sh 里需要同时运行三个进程：&lt;code&gt;sh&lt;/code&gt;、&lt;code&gt;ls&lt;/code&gt;、&lt;code&gt;grep&lt;/code&gt;，加上 fork 的中间状态，进程数量一下上来了。&lt;/p&gt;
&lt;p&gt;运行时随机崩溃，串口输出乱码。通过 QEMU 调试发现是内核栈溢出——某个进程的内核栈被覆盖了。&lt;/p&gt;
&lt;p&gt;原来内核栈只有 4KB：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-c&#34; data-lang=&#34;c&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;#define STACK_SIZE   4096
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;p&lt;span style=&#34;color:#f92672&#34;&gt;-&amp;gt;&lt;/span&gt;stack &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; (&lt;span style=&#34;color:#66d9ef&#34;&gt;uint8_t&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;*&lt;/span&gt;)&lt;span style=&#34;color:#a6e22e&#34;&gt;pmm_alloc&lt;/span&gt;();   &lt;span style=&#34;color:#75715e&#34;&gt;// 只有 1 个物理页
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;busybox 的调用链比较深（sh → fork → exec → elf_load → ext2_read → bcache_get → &amp;hellip;），4KB 撑不住。&lt;/p&gt;
&lt;p&gt;改成 8KB，用 &lt;code&gt;kmalloc&lt;/code&gt; 分配（&lt;code&gt;pmm_alloc&lt;/code&gt; 只能分配 4KB）：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-c&#34; data-lang=&#34;c&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;#define STACK_SIZE   8192
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;p&lt;span style=&#34;color:#f92672&#34;&gt;-&amp;gt;&lt;/span&gt;stack &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; (&lt;span style=&#34;color:#66d9ef&#34;&gt;uint8_t&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;*&lt;/span&gt;)&lt;span style=&#34;color:#a6e22e&#34;&gt;kmalloc&lt;/span&gt;(STACK_SIZE);
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h2 id=&#34;崩溃二cd--跳到根目录&#34;&gt;崩溃二：&lt;code&gt;cd ..&lt;/code&gt; 跳到根目录&lt;/h2&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;/ # mkdir -p /usr/bin
/ # cd /usr/bin
/usr/bin # cd ..
/ #   ← 应该到 /usr，结果跳到 /
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;路径解析遇到 &lt;code&gt;..&lt;/code&gt; 时，原来直接跳回根目录：&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
