搜索
高级检索
高级搜索
书       名 :
著       者 :
出  版  社 :
I  S  B  N:
文献来源:
出版时间 :
现代嵌入式系统开发专案实务
0.00    
图书来源: 浙江图书馆(由图书馆配书)
  • 配送范围:
    全国(除港澳台地区)
  • ISBN:
    9787121088384
  • 作      者:
    邱毅凌编著
  • 出 版 社 :
    电子工业出版社
  • 出版日期:
    2009
收藏
编辑推荐
  《现代嵌入式系统开发专案实务》不是某个CPU、某个系统或某种产品的“使用手册”,于轻松的行文风格中,讲述嵌入式系统的本质与正确的观念。以项目管理的角度,详细介绍电子产品开发从启动到上市之后的每一个流程、相关的业界现状、以及嵌入式系统工程师在每一个阶段的工作性质与角色定位;全书共十三章,以一个完整的电子产品开发案的流程贯穿全书,于适当的时间点,穿插真实发生的实例以及解决方式,藉此推导出嵌入式系统开发的相关技术。
展开
内容介绍
  市面上的电子产品琳琅满目,业界正在使用的CPU与IC多如繁星,嵌入式系统开发的技巧也数不胜数,书店里讲授嵌入式系统的书籍繁杂如过江之鲫,更不要说您在Google搜寻“embedded system”会出现多少相关网页……嵌入式系统是计算机产业中非常特殊的一个领域,几乎没有一个电子产品或嵌入式系统开发项目是完全一样的,身为这个产业链中的一员,面对排山倒海而来的信息,您该如何制定自己的学习目标呢?所谓“一法通,万法通”,嵌入式系统开发也是如此。如果只专注于研究某个CPU的功能或某个产品的特性,其实际意义并不大,因为下个产品开发方案可能是完全不同领域的应用!《现代嵌入式系统开发专案实务》希望能将作者自身的经验与见闻整理成真正有用的观念,借着轻松的行文风格,传达给想加入嵌入式系统这一产业的读者,希望《现代嵌入式系统开发专案实务》可以让对嵌入式系统开发有兴趣的读者少走一些冤枉路。
展开
精彩书摘
  第1章 嵌入式系统开发项目的生命周期(上)——项目激活与规划阶段
  1.1 嵌入式系统专案简介
  1.1.1 设计产品
  很多项目之所以会失败或陷入似乎永远逃不出的泥沼,不全是管理或技术的问题,有时候事后分析,才发现某些产品根本就不该做,或某些项目根本就不该接。难道这些做决策的人都是笨蛋吗?电子产品因为具有高时效性、生命周期短、竞争强度高的特性,很容易会让决策者昏了头,因此做出错误的决定。所以市场上永远不乏“自杀”的产品,就像旅鼠迁徙一样,一只一只前仆后继地跌入水里。
  产品设计定案之前,一定要做好市场调查和评估,marketing是另一门高深的学问,并不是本书的重点。在此笔者要点出一个业界真实的状况:即使做过详尽的市场研究,许多产品依旧卖不出去,但有些成功的产品仅是基于一瞬间的简单创意而来的。现在世界电子产品的市场变动如此快速,要定义一个保证可以符合未来需求的产品相当困难,特别是消费性电子产品,“未来”二字指的可能只是短短三个月或半年。这也是为什么嵌入式系统开发团队接到项目的日程总是那么紧,而不合理的流程肯定会对往后的管理与开发工作造成极大的影响。
  所以产品设计不能仅考虑时效性及市场需求,也要就技术可行性做基本的分析评估,一个根本无法如期达成的目标只能是空中楼阁而已,而且强迫开发团队执行一个不可能的任务,除了耽误商机之外,还会造成资源的浪费与人员士气的低落。
  产品设计结束后要写下详细的产品规格,这个规格可以用以估计技术层次、需要的配合单位与人员、开发费用以及产品造价等。因为接下来的人力配置以及系统设计的工作都会依照这个规格来展开。要更动任何产品规格都必须经过严格的审查流程,越到开发后期更改规格对项目的影响越大。例如,某手机产品已经接近批量生产,客户才说应该要加上插卡的功能,这影响不只是软件的系统架构,CPU能不能支持插卡也不知道(当然可以外加芯片来解决这件事情,但是因为最初没有这个需求,CPU的所有PIN引脚可能都已经用完了),更不用提机构设计了,不仅会造成“兵慌马乱”,整个进度也不可避免地要往后延迟,如图1.1所示。
展开
目录
第0章 系统、嵌入、硬件
0.1 Welcomeonboard
0.2 嵌入式系统开发团队
0.3 老调重弹——什么是嵌入式系统
0.3.1 嵌入式系统本质(I)——计算机系统
0.3.2 嵌入式系统本质(II)——特殊应用
0.3.3 什么是嵌入式系统
0.4 限制.限制.限制
0.4.1 产品规格设计的限制
0.4.2 人力分配的限制
0.4.3 进度管理的限制——测不准原理
0.4.4 硬件设计的限制
0.4.5 软件系统设计的限制
0.5 基本职能——老鸟也曾是菜鸟
0.6 读书计划
0.7 工作内容——做工程师,而非程序工人

第1章 嵌入式系统开发项目的生命周期(上)——项目激活与规划阶段
1.1 嵌入式系统专案简介
1.1.1 设计产品
1.1.2 管理项目
1.1.3 开发系统
1.2 初期规划——该不该接这个项目
1.2.1 没规划,一定挂
1.2.2 不可能的任务
1.3 进度规划——ASAP
1.4 规格——请接受这个不完美的世界
1.5 人力规划——营级组织,连级人力
1.6 一切都为了costdown

第2章 嵌入式系统开发项目的生命周期(下)——设计、执行与结案
2.1 设计阶段——拟定作战计划
2.2 产品规格设计
2.3 硬件设计
2.4 系统设计
2.5 测试计划设计
2.6 品质系统设计
2.7 风险评估
2.8 设计文件的重要性
2.9 实作阶段——执行所有设计
2.1 0冲突不断——协同作战有多难
2.1 1产品化
2.1 2无间道——项目可有结案的一天

第3章 震撼教育——第一个嵌入式系统
3.1 开发环境
3.2 无痛起步——善用samlecode
3.2.1 计算机系统激活流程
3.2.2 中断向量表
3.2.3 boot程序(激活程序)
3.2.4 main( )
3.2.5 驱动程序1——timer
3.2.6 驱动程序2——LED
3.3 如何确定程序在执行
3.4 标准Clibrary可以用吗?
3.5 总结:嵌入式HelloWorld

第4章 嵌入式系统平台实作
4.1 系统与平台
4.2 系统架构设计
4.2.1 产品规格review
4.2.2 系统架构——从粗略到逐渐精细的方块图
4.2.3 资料流
4.2.4 硬件相关与硬件无关——可重用性&可移植性
4.2.5 systemconfiguration——可扩充性&可调整性
4.3 API与程序风格设计
4.3.1 系统程序风格
4.3.2 应用程序风格
4.3.3 API
4.4 嵌入式操作系统——OS在哪里
4.4.1 操作系统
4.4.2 嵌入式操作系统
4.4.3 实时系统
4.4.4 嵌入式操作系统的特性
4.4.5 嵌入式系统task架构实例
4.5 仿真器
4.6 sourcetree设计
4.6.1 整合时的重要观念
4.6.2 sourcetree设计原则
4.7 程序风格典范

第5章 构建嵌入式系统开发环境
5.1 开发工具
5.1.1 IDE(集成开发环境)
5.1.2 crosstools
5.1.3 make
5.2 makefile&批处理文件(.BAT)
5.2.1 makefile
5.2.2 非文件名称的target
5.2.3 人工撰写对比automaketools
5.2.4 debug版与release版
5.3 linkscript
5.3.1 程序段与数据段
5.3.2 linkscript的内容
5.3.3 定义在linkscript中的常数
5.3.4 mapfile或symboltable
5.4 ROMMaker
5.4.1 makeROM
5.4.2 constantCarray
5.4.3 filesystembinary
5.5 下载&执行
5.6 版本控制server
5.7 说故事时间

第6章 上电之后——bootloader
6.1 第一行程序
6.2 基本硬件测试
6.2.1 确认functioncall可否正常运行
6.2.2 确认中断系统可否正常运行
6.2.3 内存测试
6.2.4 CPU初始化
6.3 加载程序段与数据段初始化
6.3.1 加载data段
6.3.2 设定bss段
6.3.3 加载程序段
6.4 实例:从NANDFlash加载

第7章 驱动程序
7.1 莫恐惧
7.2 准备工作
7.2.1 检查可用的资源
7.2.2 用C语言写驱动程序
7.2.3 新世纪汇编语言实务
7.2.4 driverAPI设计
7.2.5 软硬之争——这板子真的可以动吗
7.3 控制CPU
7.3.1 内部缓存器
7.3.2 memorymapping缓存器
7.3.3 中断处理器
7.3.4 clock
7.3.5 bus&chipselect
7.3.6 GPIOport
7.3.7 NOP与实作精确的时间区段
7.3.8 省电功能控制
7.3.9 初始化
7.3.1 0CPU内部还有什么
7.4 memory
7.5 控制其他芯片
7.6 ISR写作注意事项
7.7 驱动程序除错
7.8 结论

第8章 内存管理
8.1 内存空间配置
8.2 stack
8.2.1 stack的用途
8.2.2 stackoverflow
8.2.3 stack&RTOS
8.2.4 contextswitch
8.3 heap——动态内存配置
8.3.1 allocate&free
8.3.2 API
8.3.3 碎块处理
8.3.4 保护heap
8.4 烧录器

第9章 模拟器
9.1 模拟器概论
9.2 emulatorVSsimulator
9.3 模拟器对项目开发的贡献
9.3.1 开发环境
9.3.2 测试
9.4 实战篇
9.4.1 模拟器实作的基本观念——仿真LCD
9.4.2 模拟器与系统状态
9.4.3 其他功能的仿真
9.4.4 模拟器其他功能——loggingandprofiling

第10章 系统整合
10.1 第一次整合
10.1.1 最佳时间点
10.1.2 导致整合失败的原因
10.2 全功能整合
10.2.1 schedule检讨——该是面对现实的时候了
10.2.2 全功能整合会碰到的问题
10.2.3 porting的原则
10.3 发行第一个版本
10.3.1 第一个正式版本之前的“版本
10.3.2 送测——激活BUG管制系统

第11章 testing.debugging和tuning
11.1 测试
11.1.1 测试VS品质系统
11.1.2 嵌入式系统测试——crosstest
11.1.3 测试计划
11.1.4 测试的种类
11.2 bugsheet管理
11.2.1 填写bugsheet的注意事项
11.2.2 非RD人员使用bug管理系统的注意事项
11.2.3 bug的等级
11.2.4 bug的生命周期
11.2.5 后话:白天不懂夜的黑
11.3 debug基本技法
11.3.1 直觉与经验
11.3.2 案例——无俚头死机事件
11.3.3 莫非定律——量产才出现的bug
11.3.4 offiinetools开发与slzeof( )的陷阱
11.4 tuning
11.4.1 执行时间测量
11.4.2 找出热区
11.4.3 在较快的内存中执行程序或操作资料

第12章 结案前的煎熬
12.1 版本发行——兵荒马乱的日子
12.1.1 版本发行流程
12.1.2 正式版与内部测试版
12.2 自动测试程序
12.2.1 一般使用者VS生产线作业人员
12.2.2 自动测试程序的功能
12.2.3 自动测试程序会影响产能与组装成本
12.3 决定量产版本
12.4 出货≠结案
12.4.1 runningchange版本
12.4.2 costdown版
12.4.3 出货之后——你以为就没事了吗
12.5 项目结案
12.6 期许下一个项目

附录A 没有执行专案管理的专案
附录B CallbackFunction
附录C 用C语言来实作面向对象的概念
附录D 有效率的画斜线算法
附录E 电子产品设计导论
展开
加入书架成功!
收藏图书成功!
我知道了(3)
发表书评
读者登录

请选择您读者所在的图书馆

选择图书馆
浙江图书馆
点击获取验证码
登录
没有读者证?在线办证