• <div id="0yoao"><tr id="0yoao"></tr></div>
    <dl id="0yoao"></dl>
  • <sup id="0yoao"></sup>
    <div id="0yoao"><tr id="0yoao"></tr></div>
  • <div id="0yoao"><tr id="0yoao"></tr></div>
  • tty驱动分析

    作者:callme_friend 发布于:2018-4-20 18:02 分类:TTY子系统

    分析背景:xilinx_uartps.c (drivers\tty\serial)----linux-4.9内核

    以具体驱动为例,描述了驱动的注册、打开和读写过程;梳理了相关数据结构间的关系。最后给出了一个模拟tty驱动实例。

    阅读全文>>

    标签: Linux tty 模拟串口

    评论(24) 浏览(8505)

    ftrace时间精度issue修复

    作者:linuxer 发布于:2018-4-16 19:07 分类:Linux内核分析

    在调试ATMEL SAMA5D3 ?#31995;膄trace功能的时候,发现了一个时间精度的问题,本文主要记录这个issue修复的过程,方便后续查阅。linux内核版本是4.4.19,当然,最新的内核中仍然存在这个issue。

    阅读全文>>

    标签: ftrace sched_clock

    评论(0) 浏览(5018)

    致驱动工程师的一封信

    作者:smcdef 发布于:2018-4-14 21:00 分类:统一设备模型

    作为一个算是合格的驱动工程师,总是有很多话想说。代码看的多了总是有些小感悟。可能是吧。那就总结一下自己看的代码的一些感悟和技巧。如何利用你看的这些代码?如何体现在工作的调试中。作为驱动工程师,主要的工作就是移植各种驱动,接触各种?#24067;?#25509;触最多的就是dts、中断、gpio、sysfs、proc fs。如何利用sysfs、proc fs及内核提供的接口为我们降低调?#38405;?#24230;,快速解决问题呢?

    阅读全文>>

    评论(10) 浏览(14855)

    SLUB DEBUG原理

    作者:smcdef 发布于:2018-2-22 21:49 分类:内存管理

    1. 前言
    在工作中,经常会遇?#25509;?#20110;越界导致的各种奇怪的问题。为什么越界访?#23454;?#33268;的问题很奇怪呢?在工作差不多半年的时间里我就遇到了很多越界访?#23454;?#33268;的问题(不得不吐槽下IC厂商提供的driver,总是隐藏着bug)。比如说越界访?#23454;?#33268;的死机问题,这种问题的出现一般需要长时间测试才能发现,而且发现的时候即使有panic log。你也没什么头绪。这是为什么呢?

    阅读全文>>

    标签: slub 内存管理

    评论(12) 浏览(10026)

    图解slub

    作者:smcdef 发布于:2018-2-22 21:02 分类:内存管理

    1. 前言

    Linux中,伙伴系统(buddy system)是以页为单位管理和分配内存。但是现实的需求却以字节为单位,假如我们需要申请20Bytes,总不能分配一页吧!那岂不是?#29616;?#28010;费内存。那么该如何分配呢?slab分配器就应运而生了,专为小内存分配而生。slab分配器分配内存以Byte为单位。但是slab分配器并没?#22411;?#31163;伙伴系统,而是基于伙伴系统分配的大内存进一步细分成小内存分配。

    前段时间学习了下slab分配器工作原理。因为自己本身是做手机的,发现现在好像都在使用slub分配器,想想还是再研究一下slub的工作原理。之前看了代码,感觉挺多数据结构?#32479;?#21592;的。成员的意思是什么?数据结构之间的关系是什么?不知道你是否感觉?#35780;?#38654;里。既然代码阅读起来晦涩难懂,如果有精美的配图,不知是否有助于阁下理解slub的来龙去脉呢?我想表达的意思就是文章图多,图多,图多。我们只说原理,尽量不看代码。因为所?#20889;?#30721;中包含的内容我都会用图来说明。你感兴趣绝对有助于你看代码。

    说明:slubslab中的一种,slab也是slab中的一种。有时候用slab来统称slab, slubslobslab, slubslob仅仅是分配内存策略不同。本篇文章中说的是slub分配器工作的原理。但是针对分配器管理的内存,下文统称为slab缓存池。所以文章中slubslab会混用,表?#23601;?#19968;个意思。

    注:文章代码分析基于linux-4.15.0-rc3

    阅读全文>>

    标签: slub 内存管理

    评论(13) 浏览(12016)

    Deadline调度器之(二)?#21512;?#33410;和使用方法

    作者:linuxer 发布于:2018-2-22 18:23 分类:进程管理

    Linux内核的DL调度器是一个全局EDF调度器,它主要针对有deadline限制的sporadic任务。注意:这些术语已经在本系列文章的第一部分中说明了,这里不再赘述。在这本文中,我们将一起来看看Linux DL调度器的细节以及如?#38382;?#29992;它。另外,本文对应的英文原文是https://lwn.net/Articles/743946/,感谢lwn和Daniel Bristot de Oliveira的分享。

    阅读全文>>

    标签: scheduler Deadline

    评论(1) 浏览(6225)

    KASAN实现原理

    作者:smcdef 发布于:2018-2-11 22:32 分类:内存管理

    1. 前言

    KASAN是一个动态检测内存错误的工具。KASAN可以检测全局变量、栈、堆分配的内存发生越界访?#23454;?#38382;题。功能比SLUB DEBUG功能齐全并且支持实时检测。越界访问的?#29616;?#24615;和危害性通过我之前的文章(SLUB DEBUG技术)应该有所了解。正是由于SLUB DEBUG缺陷,因此我们需要一种更加?#30475;?#30340;检测工具。难道你不想吗?KASAN就是其中一种。KASAN的使用真的很简单。但是我是一个追求刨根?#23454;?#30340;人。仅仅止步于使用的层面,我是不愿意的,只有更清楚的了解实现原理才能更加熟练的使用工具。不只是KASAN,其他方面我也是这么认为。但是,说实话,写这篇文章是有点底气不足的。因为从我查阅的资料来说,国内没有一篇文章说KASAN的工作原理,国外也是没有什么文章关注KASAN的原理。大家好像都在说How to use。由于本人水平有限,就根据现有的资料以及自己阅读代码揣摩其中的意思。本文章作为抛?#23478;?#29577;,如果有不合理的地方还请指正。
    注:文章代码分析基于linux-4.15.0-rc3。

    阅读全文>>

    标签: KASAN原理

    评论(25) 浏览(14482)

    deadline调度器之(一):原理

    作者:linuxer 发布于:2018-1-31 19:20 分类:进程管理

        关于deadline调度器的文档有两篇,本篇简单介绍了实时调度及其背后的一些理论。另外一篇将专门讨论Linux系?#25345;?#30340;Deadline调度器。另外,本文主要?#30446;?#26550;和思想来自Deadline scheduling part 1 — overview and theory,但经过作者的翻译、整理和演绎。

    阅读全文>>

    标签: deadline调度器

    评论(0) 浏览(7192)

    Meltdown论文翻译

    作者:linuxer 发布于:2018-1-19 20:18 分类:基础学科

    本文是作者阅读meltdown论文随手翻译的一些文字记录,希望能帮助到那些对meltdown感兴趣,但英文不是那么好的同学。水平有限,欢迎指正。

    阅读全文>>

    标签: Meltdown

    评论(3) 浏览(9657)

    统一设备模型:kobj、kset分析

    作者:callme_friend 发布于:2018-1-9 18:37 分类:统一设备模型

    kobj/kset作为统一设备模型的基础,?#38477;?#25552;供了哪些功能,在具体应用过?#35752;校?#22914;devicebus甚至platform_device等是如?#38382;?#29992;kobj/kset的,这是本文的主要阐述内容。

    阅读全文>>

    标签: kset kobj

    评论(3) 浏览(6836)

    Copyright @ 2013-2015 蜗窝科技 All rights reserved. Powered by emlog
    连码三全中是什么
  • <div id="0yoao"><tr id="0yoao"></tr></div>
    <dl id="0yoao"></dl>
  • <sup id="0yoao"></sup>
    <div id="0yoao"><tr id="0yoao"></tr></div>
  • <div id="0yoao"><tr id="0yoao"></tr></div>
  • <div id="0yoao"><tr id="0yoao"></tr></div>
    <dl id="0yoao"></dl>
  • <sup id="0yoao"></sup>
    <div id="0yoao"><tr id="0yoao"></tr></div>
  • <div id="0yoao"><tr id="0yoao"></tr></div>