JuanA1的专栏

金字塔最底层之IT民工的技术点滴

Linux驱动的platform机制

最近在看SPI、I2C这样简单点的总线驱动程序,从Linux2.6起,内核引入了一套新的驱动管理和注册机制:Platform_device和Platform_driver。现在Linux中大部分的设备驱动都可以使用这套机制,总线为platform_bus,设备用platform_device表示,...

2011-11-10 22:56:10

阅读数:5516

评论数:1

Linux内核初始化过程的源码分析疑点记录+好书推荐(附下载)

这个对基于PowerPC的Linux内核源码剖析的文章已经写了三篇了(见前三篇博文),由于可以找到的关于PowerPC E300处理器的Linux文章基本没有,这些都是一点点摸索的,可能存在不少的错误,特别是第3篇,自我感觉很差,开始计划写这个系列的时候,自以为已经很了解PowerPC的内部体系了...

2011-11-03 21:25:30

阅读数:9498

评论数:4

基于PowerPC的Linux内核之旅:第2站-__secondary_start(start_here)-下

上篇中介绍了基于PowerPC的Linux第二阶段启动过程的一部分,由于MMU的初始化涉及的内容较多,而且代码量很大,所以这部分分为上下两部。本部分继续阐述MMU硬件的初始化和最终真正使能MMU的过程。     在开始之前,先指出前面文章出现的一个错误,在对mmu_off函数中的RFI指令的介绍...

2011-11-03 21:07:45

阅读数:13181

评论数:2

基于PowerPC的Linux内核之旅:第2站-__secondary_start(start_here)-上

前面一篇的early_init执行完成后,CPU启动早期的基本初始化工作算是做完了,这时内核会开始重定向并复制运行,代码如下: bl reloc_offset mr r26,r3 addis r4,r3,KERNELBASE@h /* current address of _start ...

2011-10-31 21:22:20

阅读数:8480

评论数:3

基于PowerPC的Linux内核之旅:第1站-early_init

很早之前就有写基于PowerPC架构的Linux源代码分析的文章的想法,但无奈于Linux源码量太大,逻辑也很复杂,再加上本身对PowerPC汇编了解不多,闲暇时间也没有太多,一直都没有什么机会。上个月,工作上的事情因为硬件的耽误稍微少了些,再加上自己之前分析U-Boot的源码时学了不少Power...

2011-10-26 22:16:33

阅读数:10044

评论数:0

Linux内核特性之VDSO

这段时间看Linux内核源码的时候,经常碰到vdso这个东西(像在Feature-fixup中,获取时间等操作时),网上搜了一下,才知道了含义,原来这是Linux为了解决和glibc兼容而想出的绝招啊。下面是从Fedora中文邮件列表转过来的,和大家分享一下。     往往内核添加了一个功能,g...

2011-10-25 18:55:58

阅读数:18070

评论数:0

U-Boot源码分析之Makefile

之前用过两个版本u-boot,分析过它的Start.S文件(PowerPC、ARM)源代码,也移植过内部的各部分硬件驱动及组件(串口、I2C、SPI、Flash文件系统、USB、DMA等)源码,自我感觉比较熟悉了。但最近逛CSDN论坛发现有不少人在问U-Boot中的Makefil

2011-10-15 15:26:44

阅读数:7912

评论数:0

FatFS文件系统详解-附移植建议

最近做的spi flash,本打算弄个文件系统,由于之前用过了JFFS、YAFFS和TrueFFS,代码量都相当的大,这次想找款代码量不那么吓人的,学习一下,听说配置会相对复杂一些。选来选去,最终选定了FatFS,代码量足够的小,最新的R0.09版本只有1个.c文件(当然,还有一

2011-10-12 21:05:41

阅读数:30882

评论数:8

FreeScale mpc8xxx + vxWorks平台下spi flash驱动开发三步走

最近在弄PowerPC平台上的spi flash的驱动程序,总体比较简单,在借鉴了U-Boot中的相关源码后,花了两周左右的时间搞定了,对于spi总线之前一直都有了解,但未能实际接触,这次在vxWorks上尝试了一下,确实有不小的收获。由于网上关于vxWorks平台的资料稀少,就

2011-10-12 20:23:01

阅读数:9321

评论数:5

GNU C中不为人知的特色:__attribute__机制

十一放假放的不亦乐乎啊,今天才静下来看看技术,偶然碰到了__attribute__,虽然之前在看Linux内核代码时见过很多次,但还是对它熟视无睹,罪过啊,下面的文章是从源码网上转载的,原文在这里:http://www.yuanma.org/data/2006/0625/arti

2011-10-07 18:20:27

阅读数:22387

评论数:20

vxWorks中USB驱动栈-1

USB模块可以分为多端口主机(MPH)模块和双角色(DR)模块,它们都能够连接一个或者二个外部端口,这些模块和外部端口总称为USB接口。Mpc8379的USB模块采用的是DR,它的寄存器和数据结构均基于Intel的EHCI(Enhanced Host Controller Int

2011-09-11 09:44:16

阅读数:6545

评论数:1

堵塞与非堵塞IO模式详解

在网络编程中对于一个网络句柄会遇到阻塞IO 和非阻塞IO 的概念, 这里对于这两种socket 先做一下说明: 阻塞IO:socket 的阻塞模式意味着必须要做完IO 操作(包括错误)才会返回。     非阻塞IO:非阻塞模式下无论操作是否完成都会立刻返回,需要通过其他方式来

2011-09-03 22:57:16

阅读数:3147

评论数:0

PCI-E配置MSI中断流程解析

在调试PCI-E的MSI中断前,需要先保证将传统中断调通,然后再调试这个。MSI中断究其本质,就是一个存储器读写事件。将MSI Address设置为内存中的某个地址(可以为64位),产生MSI中断时,中断源会在MSI Address所在的地址写入MSI Data。也就是说,如果有

2011-09-03 20:52:57

阅读数:27708

评论数:8

基于Newlib库的PowerPC交叉编译器制作详解

对PowerPC的交叉编译工具的介绍确实不像ARM那么多,之前用ELDK费了好大的力气,但是它太大了,使用不方便。所以转载下这篇文章,使用的东西较小,留着以后学习。    如果有需要转载,请在使用的地方,随手附上我的空间地址,谢谢。 http://blog.csdn.n

2011-08-30 22:57:24

阅读数:3138

评论数:1

Linux下中断处理程序源码分析

之前调试vxworks下PCIE的中断程序,都封装好了,所以只用了个intConnect,感觉没学到东西,就再看了下Linux的源码。     下面是最近调试中断时额外研习了一下Linux的内核代码,下面就直接贴代码和注释了,大量借鉴了网上牛人的见解,还望海涵!! int m

2011-08-26 22:24:36

阅读数:3482

评论数:1

U-boot源代码全分析系列(基于PowerPC)-3

这里首先更正下上一篇中的一个错误,最后一步中的跳转代码当时一时仓促贴错了,先改正如下: 7、跳转到Stage2入口处     这也是Stage1的最后一步,程序在执行到这一步后,基本的硬件初始化工作也就完成了,下面是跳转的代码: clear_bss: /* 执行清空bs

2011-08-21 14:03:51

阅读数:5314

评论数:1

U-boot源代码全分析系列(基于PowerPC)-2

3、初始化CPU相关     下面为初始化CPU的代码,实现的功能依次为屏蔽watchdog、初始化中断控制寄存器、清空Cache、关闭MMU等。 .globl init_e300_core init_e300_core: /* time t 10 */ /* Ini

2011-08-18 22:55:16

阅读数:5540

评论数:4

U-boot源代码全分析系列(基于PowerPC)-1

一、概述     U-Boot,全称Universal Boot Loader,是遵循GPL条款的开放源码项目,是从FADSROM、8xxROM、PPCBOOT逐步发展演化而来的。其源码目录、编译形式与Linux内核很相似,事实上,不少U-Boot源码就是相应的Linux内核源

2011-08-18 22:17:16

阅读数:7524

评论数:3

Linux中PowerPC的中断原理分析

在了解中断处理机制前,先看一下PowerPC的中断源,这里使用的是e300c3的内核,从E300核的角度,中断源可分为异常和外部中断,异常是e300内核产生的,如出现非法指令,或者是访问存储器时出现TLB Miss等情况。这种情况太复杂了,没有深究,这里所说的中断为外部中断。所谓

2011-08-11 19:27:59

阅读数:9417

评论数:0

PowerPC的PCI总线的dts配置

这段时间要弄下PCI Express的相关调试和驱动开发工作,老规矩,先在网上找找资料,这类的东西还蛮少的,已经买了本书,打算边学边自己总结吧,这篇文章是PowerPc下对PCI总线的配置方法。     powerpc使用称为FDT 扁平设备描述树的机制传递给内核硬件配置参数,

2011-08-06 09:26:55

阅读数:8286

评论数:1

提示
确定要删除当前文章?
取消 删除
关闭
关闭