云栖梦泽
林渡
Blog
  • 首页
  • 我的视界
    • 人世间
      • 世间风声
      • 人间烟火
    • 壹句话
    • 云外光影
      • 动物与植物
      • 美食
      • 生活气息
      • 人物
    • 文章归档
      • 技术分享
      • 视频类型
      • 音频类型
      • 图文类型
      • 图片类型
  • 「内核宇宙」
    • 灵感工坊
      • 灵感风暴
    • 底层漫游
      • Android稳定性
      • Linux内存管理
      • Linux进程调度
      • Linux内核
      • ARM体系架构
      • LRDP2
      • 技术分享
  • 璀璨星河
    • 公告
    • 应用舱
    • 众星
    • 豆瓣
    • 足迹
    • 走心评论
    • 林渡的网盘
  • 留言板
  • 关于
    • 捐赠者名单
    • 关于我
    • 一些声明
      • 站点声明
      • 隐私政策
    • 网站看板
  • 欢迎订阅!

欢迎来到云栖梦泽,为您导读全站动态
  • 林渡 2日前前留言 工具我更新了,但是小米在线解析的,那个只支持小米内网的
  • ktxck 2日前前留言 确实都打不开,但你文章里提到的那个小米解析网站也打不开,实在没办法了,我现在正试着用pcat看看
  • 林渡 2日前前留言 你说的是minidump_linux_unzip 和 拆分脚本吧?这两个你应该用不到的,这个是我们客户定制的,应该不会适用于你们项目
  • 林渡 2日前前留言 哪里呀?不是这篇文章里的吧?
  • ktxck 2日前前留言 26年4月,文章提到的工具链全部失效了,想问一下这里面有hv层的详细日志吗光靠搜索没乱码的地方只能读到 ... (正常hv层内容启动) ... 4 344.470102 WDT bite: now_ticks 4915389, last_pat 3932438, from VM 3 4 344.471089 Abort: Watchdog bite from PC 0xffffffd6c6e3802c, FP 0xffffff97c0050eb0 4 344.471148 WDT: Triggering NS Watchdog Bite
  • 林渡 1周前前留言 有时候会直接修改page cache页数据,不走页表,那写保护就无效了。回写线程清除 PG_dirty 时,它赌的是:这个页在回写期间不会被修改。如果这个赌注输了(即 PG_dirty 在 I/O 完成前又被设置了),内核需要在 I/O 完成后重新入队回写。关键就在 redirty_page_for_writeback:这个函数会重新设置 PG_dirty + PAGECACHE_TAG_DIRTY,让这个页重新出现在下次回写的队列里。这样就能兜住 GUP 或 do_wp_page 产生的并发脏写。
  • Melokc 1周前前留言 回写这块我之前一直对一些细节很疑惑,就某个细节谈一下疑惑&看法。之前最疑惑的一点就是,为什么是在回写之前把dirty标志清掉?为什么不等待完全回写完毕之后,页面真正干净了,再抹掉标志位呢。甚至在shrink流程下,writeback之前还会释放PG_locked,摆明着在回写过程中卸下防备,等着页面被更改。现在的理解是,页在wb场景下,虽然设置了pte写保护,但仍旧有可能触发do_wp_page(),让这个页变脏,这时候回写之前抹掉dirty的好处就体现了,回来之后又发现自己是dirty的,说明又被改写了。甚至可能不是用户态触发缺页导致的dirty,可能是内核直接GUP导致的dirty(这个隐约记得在哪个文件里看到过相关注释,但当时没有记录,在懊恼了)
  • 林渡 1周前前留言 其实方法已经给了,重要的就是利用AI,让claude code代替人去理解代码架构,你只需要把你的需求以自然语言告诉claude code。
  • 林渡 1周前前留言 哈哈,我也觉得付费阅读很反感,所以基本上不会考虑的,改成打赏支持,能够抵一部分服务器成本就可以了。这个博客主要还是分享以及让自己回顾一下自己的知识点。 打赏支持页面就是一个单独的html页面,没有使用插件
  • 寻境者·唐 1周前前留言 这种模式挺好,当然当你积累到一定能量的时候,能够输出更多高水平高质量的文章时,是可以结合付费阅读的,虽然我本人挺反感这样的模式。 另外你这个打赏支持页面功能很不错,用什么插件实现的吗?
2026 年 4 月
日一二三四五六
1234
567891011
12131415161718
19202122232425
2627282930
« 3 月  
最近文章
  • 2026-04-10 [linux内存管理] 第046篇 Page Cache脏页回写机制深入分析
  • 2026-04-01 AI时代笔记工作流:构建下一代知识管理引擎
  • 2026-03-24 认知加速度:AI时代最残酷的鸿沟,正在此刻拉开
  • 2026-03-20 Linux 内核崩溃分析报告 - AI
  • 2026-03-11 AI时代的思考:内核稳定性工程师离失业还有多久?
  • 2026-03-06 [linux内存管理] 第045篇 per-CPU变量的静态与动态分配
  • 2026-03-04 [linux内存管理] 第044篇 per-CPU基础知识以及per-CPU分配器的初始化
  • 2026-03-02 [Android稳定性] 第62篇 内核访问与tee共享的内存数据异常造成内存越界
  • 2026-02-28 [LRDP2] 解析插件之logcat
  • 2026-02-26 [linux内存管理] 第043篇 page cache 脏页跟踪机制
  • 2026-02-26 向 Linux 内核社区提交 patch 实操要点
  • 2026-02-06 基于 QEMU 与 VSCode 的 Linux 内核调试环境搭建指南
  • 2026-02-06 「纵朝生暮死,亦当惊鸿」
  • 2026-02-04 [linux内存管理] 第042篇 Linux内核Page Cache机制深入分析
  • 2026-02-03 [linux内存管理] 第041篇 缺页异常之 do_swap_page:从 swap entry 到完整 swap-in 全流程
  • 2026-02-03 [灵感风暴] GKI 升级不再靠人肉:Aegis 自动风险分级与测试建议生成
  • 2026-02-02 [linux内存管理] 第040篇 文件映射与匿名映射
  • 2026-01-31 [Android稳定性] 第61篇 UFS异常导致卡开机logo
  • 2026-01-30 [linux内存管理] 第039篇 用户态内存映射malloc和mmap详解
  • 2026-01-29 [linux内存管理] 第038篇 深入剖析AArch64架构下的do_page_fault缺页异常处理
热门文章
  • 2024-11-22 高通android启动代码流程分析(SBL->ABL)
  • 2025-07-21 高通以及MTK平台内核单独编译ko的原理
  • 2025-08-27 [Android稳定性] 第058篇 [方法篇] 高通平台使用QFIL回读分区
  • 2024-12-15 [Android稳定性] 第000篇 Android稳定性系列开篇
  • 2025-06-25 [Android稳定性] 第052篇 [方法篇] HMI项目中如何使用QCAP解析minidump?
  • 2025-06-18 [linux内存管理] 第027篇 Linux ARM64 虚拟地址布局
  • 2026-01-29 📢 致读者的一封信:关于运营、初心与一份邀请
  • 2025-06-09 【深入内核】linux ftrace详解
  • 2024-11-29 [linux内存管理] 第009篇 reserved-memory详解
  • 2025-08-23 [linux内存管理] 第029篇 谁把folio的函数定义“藏”起来了?
  • 2025-01-14 [Android稳定性] 第017篇 [方法篇] 高通watchdog分析流程
  • 2024-12-15 [Android稳定性] 第001篇 [方法篇] 高通Android平台稳定性分析介绍
  • 2025-06-04 [Android稳定性] 第045篇 [问题篇] Kernel panic - not syncing: Attempted to kill init! exitcode=0x00007f00
  • 2025-08-05 [Android稳定性] 第057篇 [方法篇] 高通平台使能ftrace的方法
  • 2025-11-03 [linux内存管理] 第000篇 Linux内存管理系列开篇
  • 2025-10-23 利用 Claude Code 探索 Linux 内核奥秘
  • 2024-12-18 [Android稳定性] 第004篇 [原理篇] minidump的原理介绍
  • 2025-08-19 【深入内核】ARM64下的内核栈
  • 2025-09-11 【深入内核】理解Linux Static Keys和jump label机制
  • 2025-07-30 [Android稳定性] 第054篇 [方法篇] 高通平台如何解析ADSP Crash?
热门标签
  • 内核线程 1
  • 价值观 1
  • 内核开发 3
  • 生产力工具 1
  • Linux内核 12
  • init进程 1
  • 理想与现实 1
  • 人生态度 1
  • 人生意义 1
  • 精神追求 1
  • 性能优化 1
  • 生活美学 1
  • 内核栈 1
  • 任务优先级 0
  • 反思 1
  • 个人成长 1
  • 时间管理 1
  • 自我认知 1
  • 烟火气 1
  • 任务管理 1
  • Static Keys 1
  • 进程调度 1
  • 动态分支 1
  • 寄存器 1
  • idle进程 1
  • 高效工作 1
  • 页面管理 1
  • minidump 3
  • kmalloc 2
  • 脏页 2
42750° 188 14 255
当您评论及浏览文章且浏览器未禁止COOKIE时,会为您显示最近10条回复及前20篇文章的浏览记录。
在万物之间穿行,也在自我之间渡过。

你好,
我是林渡

    • 1日前

      当AI替我写完代码、润色文案、整理思路,我差点忘了自己也曾能徒手解构问题,也曾深入底层逻辑去研究代码。而如今直到token额度用尽,屏幕显示额度“0%”,只能安静的等待着额度刷新,我在电脑前呆愣住——原来不知不觉间,我的能力已经悄悄托管给了AI。额度归零的那一刻,我突然不会“自己”干活了。 这场浪潮

    • 2026-03-17

      只是简单的创建了一下今日任务清单+沉淀一篇文章要点+探索obsidian插件 就花了5.87元,现在的api还是太贵了啊

    • 2026-03-03

      给博客增加了一个项目展示页,还是挺好看的了。 链接:应用舱

    • 2026-02-26

      “本来以为AI抢不走我分析内核宕机的活儿,毕竟得懂内核、会crash。 今天看到这个MCP服务……好了,感觉我的饭碗也开始‘宕机’了……AI 进化太快了,感觉离失业更近一步了......

    • 查看更多瞬间动态
  • linux源码解析05–ioremap原理 2024-11-21 评论 林渡
      Linux内存管理
      ioremap
    linux源码解析05–ioremap原理

    本文介绍了不同处理器架构对内存访问的方式,如x86架构通过I/O端口空间访问外设,而RISC架构如ARM/PowerPC则将I/O内存空间视为普通内存的一部分。文章重点讲解了ioremap映射函数,包括其定义和使用,以及如何通过ioremap_page_range函数将物理地址映射到虚拟地址,使应用程序能够通过虚拟地址访问寄存器地址。

    A64指令集学习 2024-11-21 评论 林渡
      ARM体系架构
      aarch64
    A64指令集学习

    本文档详细介绍了 Armv8-A 指令集架构,特别是 A64 指令集。A64 指令集是固定长度的 32 位指令集,用于 AArch64 执行状态。文档首先概述了指令集的基本格式、分类、助记符和条件码。接着,详细介绍了跳转指令、PC 相对寻址、系统操作指令、异常产生和返回指令、系统存储器指令、数据运算指令和 load/store 指令。最后,文档还介绍了内存屏障指令,包括 DMB、DSB 和 ISB。

    ARMv8内存地址翻译 2024-11-21 评论 林渡
      技术分享
      MMU内存屏障TLB
    ARMv8内存地址翻译

    Armv8-A 使用虚拟内存系统,通过内存管理单元 (MMU) 将虚拟地址转换为物理地址。MMU 使用存储在内存中的转换表进行地址转换,支持多个任务在各自的私有虚拟内存空间中运行。每个程序可以使用相同的虚拟内存地址空间,即使物理内存是碎片化的。MMU 还可以控制每个内存区域的访问权限、内存顺序和缓存策略。内核空间和用户空间的虚拟地址分离,内核使用固定映射,而应用程序使用可变映射。MMU 支持两种地址空间:安全地址空间和非安全地址空间。虚拟化引入了翻译的第二阶段,将虚拟地址转换为中间物理地址,再转换为最终物理地址。转换表配置包括颗粒尺寸、缓存配置、虚拟地址标记等。访问权限通过转换表条目控制,操作系统可以使用访问标志位跟踪页面的使用情况。安全性方面,NS 位和 NSTable 位控制虚拟地址是否转换为安全物理地址或非安全物理地址。翻译旁观缓冲区 (TLB) 缓存最近访问的页面翻译,提高性能。系统 MMU (SMMU) 允许设备看到与内核相同的中间物理地址空间,避免软件中昂贵的捕获需求。内存屏障指令用于确保内存操作的顺序,包括指令同步屏障 (ISB)、数据内存屏障 (DMB) 和数据同步屏障 (DSB)。

    ARMv8‑A 架构和处理器 2024-11-21 评论 林渡
      ARM体系架构
      armv8
    ARMv8‑A 架构和处理器

    ARM架构自1985年起不断发展,从早期的ARM内核逐步演进,增加了特性和功能。ARMv8-A架构是最新一代,支持32位和64位执行状态,引入了64位宽寄存器,同时保持与ARMv7软件的向后兼容性。它具备多项增强,如大物理地址、64位虚拟寻址、自动事件信号等,以及硬件加速密码学等功能。ARMv8-A架构的处理器包括Cortex-A53和Cortex-A57,分别针对中档、低功耗和高端计算需求,提供高性能和能源效率。

    armv8的寄存器 2024-11-21 评论 林渡
      ARM体系架构
      armv8
    armv8的寄存器

    AArch64执行状态提供了32个64位通用寄存器,每个寄存器都有32位形式。此外,还有几个特殊寄存器,如零寄存器、栈指针、程序计数器、异常链接寄存器、程序状态保存寄存器等。处理器状态PSTATE包含多个独立访问的字段,如ALU标志、执行状态、异常级别等。系统配置通过系统寄存器进行控制,使用MSR和MRS指令进行访问。字节序控制可以通过SCTLR_ELn寄存器中的EE位进行设置。在AArch64和AArch32之间切换时,AArch64寄存器映射到AArch32寄存器集,并保留状态。NEON和浮点寄存器提供128位浮点寄存器,用于保存浮点操作数和NEON操作的标量操作数和向量操作数。

    为什么需要虚拟内存 2024-11-21 评论 林渡
      技术分享
      memory
    为什么需要虚拟内存

    本文主要探讨了操作系统中虚拟内存的概念及其重要性。虚拟内存是一种内存管理技术,它为每个进程分配一套独立的虚拟地址空间,而操作系统负责将这些虚拟地址映射到物理内存地址。这样,进程之间的内存地址相互隔离,互不干扰,有效解决了多进程环境下的内存冲突问题。此外,虚拟内存还允许进程的运行内存超过物理内存大小,因为操作系统会将不常使用的内存页面换出到硬盘上,从而释放物理内存空间。虚拟内存的管理方式主要有内存分段和内存分页,两者各有优缺点。分段机制将程序划分为不同的逻辑段,但容易出现外部内存碎片和内存交换效率低的问题;而分页机制将内存空间划分为固定大小的页,解决了外部内存碎片问题,并提高了内存交换效率。为了解决简单分页产生的页表过大的问题,引入了多级页表和TLB技术。最后,本文还介绍了Linux操作系统的内存管理方式,主要采用分页管理,同时涉及分段机制。

    Git入门图文教程 2024-11-20 评论 林渡
      技术分享
      git
    Git入门图文教程

    Git 是一款先进的分布式版本控制系统,支持代码版本控制、跨区域多人协作等功能。本文介绍了 Git 的基本概念、安装配置、使用入门、远程仓库、分支、标签管理、撤销变更等,并结合实际工作中的 Git 实践,如 Git flow、stash、cherry-pick 等进行了详细讲解。通过本文的学习,读者可以掌握 Git 的基本操作和高级功能,更好地进行团队协作和代码管理。

    linux源码解析07–缺页异常之架构相关部分(ARM64为例)分析 2024-11-20 评论 林渡
      Linux内存管理
      memory
    linux源码解析07–缺页异常之架构相关部分(ARM64为例)分析

    本文详细介绍了缺页异常的原理和实现过程,涵盖了从异常向量表到通用代码处理的各个环节,并对主要缺页异常类型进行了分类说明。缺页异常是操作系统虚拟内存管理的重要机制,对于进程来说时透明的。文章中还涉及了匿名映射、文件映射、swap 缺页异常、写时复制缺页异常等概念,为理解虚拟内存管理提供了基础。

    linux源码解析06–常用内存分配函数kmalloc、vmalloc、malloc和mmap实现原理 2024-11-20 评论 林渡
      技术分享 / Linux内存管理
      mallockmallocvmallocmmap
    linux源码解析06–常用内存分配函数kmalloc、vmalloc、malloc和mmap实现原理

    围绕内核中的 kmalloc、vmalloc 和用户态 malloc 三种内存分配方式,从实现路径和底层机制进行对比分析。kmalloc 基于 slab 分配器,从各类 slab 缓冲区中按 size 选择合适 cache,通过 kmem_cache_alloc_trace/slab_alloc 分配物理上连续的内存,适合小块、频繁分配的场景。 vmalloc 则在 vmalloc 区域临时申请 vm_struct,计算所需页数后为其分配 struct page* 数组,再通过 alloc_pages_node 逐页(或成组)分配物理页,最后用 vmap_pages_range 建立虚拟地址

    linux内核源码解析04–用户进程页表创建 2024-11-20 评论 林渡
      Linux内存管理
      缺页异常
    linux内核源码解析04–用户进程页表创建

    科学边界发表的文章详细阐述了Linux内核中进程页表的创建、缺页异常处理以及进程切换时的内存管理机制。文章首先介绍了进程创建时页表的创建过程,包括fork时复制父进程的页表、分配pgd物理页面以及拷贝页表项。其次,描述了缺页异常导致的写时复制(COW)的处理流程,包括分配新页面、复制旧页面内容以及更新页表项。最后,文章解释了进程切换时如何通过更新ASID和页表基地址来实现地址空间的切换。这些内容对于理解Linux内存管理至关重要。

    1 … 16 17 18
  • 简述
    在万物之间穿行,也在自我之间渡过。
    liuqi20328@gmail.com
    生涯
  • 行业嵌入式
  • 职业Linux/Android内核工程师
  • 人生
  • 生活角色浪子、父母的娃、我夫人的老公
  • 社会角色公司职员、中华人民共和国公民
  • 类型
  • 星座 双子座
  • 生肖 猪
  • 血型O
  • 数据
  • 发表文章178篇
  • 发表评论66个
  • 星球加热38252度
  • 最近的心情能量
      愉快 沮丧
    • 愉快 ,当时发表在「linux源码解析05–ioremap原理」
    • 不喜不悲 ,当时发表在「A64指令集学习」
    • 不喜不悲 ,当时发表在「ARMv8内存地址翻译」
    • 不喜不悲 ,当时发表在「ARMv8‑A 架构和处理器」
    • 不喜不悲 ,当时发表在「armv8的寄存器」
  • 地图数据来源于高德地图
  • intj 建筑师
    intj 建筑师
    • 外向内向
    • 远见现实
    • 理性感受
    • 评判展望
    • 坚决起伏
  • 了解更多信息
今天是云栖梦泽·

2024-11-11

随机阅读「内核分析利器crash的编译指南」
阅读 crash是一款基于GDB、专为Linux内核崩溃转储文件分析而设计的开源工具,补足了GDB无法读取内核核心信息的不足。文章详解crash的手动编译安装流程,并重点介绍利用GitHub Action实现自动化编译和发布,极大简化部署环节,高效便捷,适合开发者快速上手与持续集成。
壹行随十人
  • 星风之痕
  • 轻雅阁
  • 问心斋
  • 南方嘉木
  • 菲兹克斯喵
  • 风记星辰
  • 秘柯絮语
  • 世上云川
  • 谜叶象限
  • 迷鹿屋
云栖梦泽版权所有 · 架构于Halo及为您增强体验的THYUU/星度主题
苏ICP备2025185582号-1 苏ICP备2025185582号-1 苏公网安备32060102321049号 苏公网安备32060102321049号 BlogsClub BlogsClub 笔墨迹 笔墨迹