<?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>MSR on 大飞的博客</title>
    <link>https://www.dafei.me/tags/msr/</link>
    <description>Recent content in MSR on 大飞的博客</description>
    <generator>Hugo</generator>
    <language>zh-cn</language>
    <lastBuildDate>Wed, 06 May 2026 10:00:00 +0000</lastBuildDate>
    <atom:link href="https://www.dafei.me/tags/msr/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>从零写OS（十）：系统调用，用户和内核的边界</title>
      <link>https://www.dafei.me/posts/os-10-syscall/</link>
      <pubDate>Wed, 06 May 2026 10:00:00 +0000</pubDate>
      <guid>https://www.dafei.me/posts/os-10-syscall/</guid>
      <description>&lt;p&gt;前几章的&amp;quot;进程&amp;quot;其实是假的——它们直接跑在内核态，和内核同等权限，可以随意读写任何内存、操作任何硬件。&lt;/p&gt;
&lt;p&gt;真实的操作系统里，用户程序跑在&lt;strong&gt;用户态&lt;/strong&gt;（Ring 3），权限受限，不能直接操作硬件。需要内核帮忙时，必须通过&lt;strong&gt;系统调用&lt;/strong&gt;这扇受控的门进入内核，做完事再回去。&lt;/p&gt;
&lt;p&gt;这一章实现 &lt;code&gt;syscall&lt;/code&gt; / &lt;code&gt;sysret&lt;/code&gt;：用户态和内核态之间最快速的切换机制。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id=&#34;两种特权级&#34;&gt;两种特权级&lt;/h2&gt;
&lt;p&gt;x86-64 有 4 个特权级（Ring 0～3），操作系统只用两个：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Ring 0（内核态）&lt;/strong&gt;：可以执行任何指令，访问任何地址，操作 CR3、MSR 等特权寄存器&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Ring 3（用户态）&lt;/strong&gt;：不能执行特权指令，访问不属于自己的内存会触发 #GP 或 Page Fault&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;CS 段寄存器的低 2 位（&lt;strong&gt;CPL&lt;/strong&gt;，Current Privilege Level）表示当前特权级。&lt;code&gt;syscall&lt;/code&gt; 指令把 CPL 从 3 切到 0，&lt;code&gt;sysret&lt;/code&gt; 把 CPL 从 0 切回 3。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id=&#34;为什么用-syscall-而不是中断&#34;&gt;为什么用 syscall 而不是中断&lt;/h2&gt;
&lt;p&gt;早期 Linux 用 &lt;code&gt;int 0x80&lt;/code&gt; 触发系统调用——软件中断，要保存完整的中断栈帧，走 IDT 查表，开销大。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;syscall&lt;/code&gt; / &lt;code&gt;sysret&lt;/code&gt; 是专门为系统调用设计的快速路径：不走 IDT，入口地址直接写在 MSR 里，省去了大量压栈操作。现代 x86-64 系统全部用这对指令。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id=&#34;配置-msr&#34;&gt;配置 MSR&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;MSR&lt;/strong&gt;（Model Specific Register，型号特定寄存器，CPU 内部的一组控制寄存器，用 &lt;code&gt;rdmsr&lt;/code&gt; / &lt;code&gt;wrmsr&lt;/code&gt; 访问）控制 &lt;code&gt;syscall&lt;/code&gt; 的行为。需要配置 4 个：&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
