嵌入式系统开发经验谈:Windows CE开发都做些什么

2024-01-01 13:48

本文主要是介绍嵌入式系统开发经验谈:Windows CE开发都做些什么,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我在博客的个人简介里说过我目前在从事基于Windows CE的BSP开发,这方面的文章到现在连一篇都没写过,似乎有些说不过去。老板肯定在犯嘀咕了,这小子不干正事儿,整天玩什么外啊挂啊的。接下来,我得整 两篇。以前我都想把文章写的跟论文似的,枯吧干燥,累人累己,以后我就胡乱侃了,一家之言,对不对的凑合着看吧。
Windows CE的文章前面写过几篇,看的人不多,可能是因为搞嵌入式系统相比桌面软件和WEB开发的人少的多,搞基于Windows CE的嵌入式系统的更少。当然更大的可能是我的文章写得不好,枯燥,太细节化。
进入现在这家公司之前我一直在做Windows平台的桌面软件开发,什么后台数据处理、中间件、界面,甚至外挂都做过,对嵌入式系统所知甚少,仅有的记忆 是在本科做毕业设计时玩过的一点儿东西:Windows CE 3.0,还有Motorola的什么PPSM和DragonBall。硬件方面,不要说USB协议分析仪、硬件仿真器、温湿度实验箱这些高级玩意儿,我连 逻辑分析仪、脉冲发生器都没听说过;软件方面,Windows CE长什么样子基本上没概念,嵌入式系统开发包含哪些方面也一无所知。记得面试的笔试题中有一道是让画出Windows CE的虚拟内存布局,我当然不会,就按照自己对XP的理解画了一个(不过回过头来看,我当时画的可是现在新鲜出炉的CE6的内存布局啊,哈哈)。更好笑的 是面谈的时候老板介绍工作内容时频频提到BSP一词,我完全不知道是什么意思,还虚心请教了一把。你看我这个嵌入式白痴稀里糊涂的就这么搞起了嵌入式开 发,而且还是嵌入式系统的底层开发。
嵌入式系统开发入门难不难,从桌面软件开发转入嵌入式系统开发容不容易?我想这可能是很多桌面软件开发程序员想问的问题,我当年也深受其扰。人在涉及自己 不熟悉的领域时总是感觉不自信,这个很正常。现在这一步跨过去了,回过头来再看,发现桌面软件开发也好,嵌入式系统开发也好,其实并无多大区别。有一种说 法讲得好:程序=数据+算法。在嵌入式系统里,数据还是那些数据,算法也还是那些算法,不同的只是细节。有些人说,搞嵌入式系统,要会数字电路、模拟电 路,要学会看原理图,等等。说实话,这些东西自从大学毕业还给老师后,我到现在也没学会,没感觉到有什么障碍。当然搞懂这些也不是什么问题,只是我觉得没 有必要-有专门的硬件工程师负责,何必操这心呢你说是不是。废话一大堆,我的意思是说,桌面软件开发和嵌入式系统软件开发并无太大区别,对于熟手来说互相 转行很容易。当然,要想做底层开发的话,C/C++熟练是必须的,少数情况下还要懂汇编。老板可以招一个嵌入式白痴,但肯定不会招C/C++白痴。所幸的 是之前我的C/C++以及汇编能力都还不错-R/E(逆向工程)搞多了汇编不熟练都不行啊wuhaha。
在我看来,基于Windows CE的嵌入式系统开发(其他的基于通用嵌入式操作系统如VxWorks、Embedded Linux等的软件开发我想也差不多)可以分成四类。
第一类是应用程序开发。这在Windows CE上几乎就和桌面Windows没差别,什么C runtime/MFC/.NET framework/COM/DCOM/SOCKET/SOAP/SQL/MSMQ全都有,不过好像没有JRE(Java Runtime Environment),呵呵。所以如果你入了桌面Windows开发的门也就等于入了Windows CE开发的门。
第二类是驱动程序开发。这也容易理解,比如说你们家做网卡的,得给它写驱动吧。编程语言自然是C/C++。Windows CE下的设备驱动程序和桌面Windows不一样,不过特简单,就是普通的运行在用户态的WIN32 DLL(CE6开始驱动程序也可以运行在核心态)。所以按我说,CE下的设备驱动程序开发不用入门,你会写桌面Windows的DLL程序的话CE的驱动 开发就已经入了门。
第三类是CSP(Chipset Support Package)开发。和通用CPU不同的是,嵌入式CPU的芯片上除了CPU核外,一般还会根据CPU的市场定位集成一些外围电路,比如LCD controller、USB host controller等,所以很多嵌入式CPU如Intel的PXA27x系列其实是SoC(System on Chip)。既然是CPU核加上一些外围设备(peripherals),CPU厂商就得为这些外围设备提供相应的代码支持,包括完整的驱动程序或操作原 语集(primitives)。这些代码集合起来就是CSP。
第四类是BSP开发,就是我目前在做的。BSP全称叫Board Support Package,Board可以理解成PC的主板。一般来说嵌入式系统的主板都是根据产品需要定制的,比如说可能有定制的键盘、某个厂商的LAN chip,802.11b/g chip等等,不一而足。BSP的目标是让嵌入式操作系统能够在你自己定制的板子上稳定运行,并支持所有你要的外围设备。具体开发又可以分为三块: boot loader、OAL(OEM Adaptation Layer)和设备驱动程序的集成。boot loader相当于PC的BIOS加XP的ntldr(NT loader),负责引导操作系统内核。OAL相当于Windows XP的HAL(硬件抽象层),主要任务是初始化硬件、中断处理和实现OEM特定的IOCTL(比如数字签名机制)。最后一块是设备驱动的集成,注意我这里 说的是集成不是开发。做BSP开发会接触到很多类硬件,光CPU的开发者手册就有上千页,我目前为止玩过的外围设备不完全统计就有:PCMCIA/CF、 USB(包括OHCI、UHCI、EHCI,前两个是USB 1.1后一个是USB 2.0)、PS/2、LCD controller、SD/SDIO、Flash memory、802.11b/g、I2C、AC97等等。这些硬件规范随便哪个都有几百上千页的,把这些SPEC统统研究一遍再自己写driver,那 黄花菜都凉了,没法做,即使做出来也很难保证有Product Quality。所以一般的做法是驱动程序由专门的外围设备厂商提供,BSP开发者结合具体的板子、参考相关SPEC做一些修改。当然如果你想用FPGA 鼓捣个printer controller,那只好自己写驱动了。 

这篇关于嵌入式系统开发经验谈:Windows CE开发都做些什么的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/559436

相关文章

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs