跳至主要内容

【转】vxworks测试题及解答

关于vxworks的测试题很少,这里推荐一篇满不错的。

一. 闭卷考试(1小时30分钟)

(一)填空
1.假设tornado安装在c:\tornado ,那么如果要改一个pentium
目标板bootrom下载VxWorks的方式,请问该更改_____目录下的_____文件?

2.更改下面的bootline,从True Flash File System中下载VxWorks
"fd=0,0(0,0)host:/fd0/vxWorks.st h=90.0.0.3 e=90.0.0.50 u=target"
  改为:____________________________________________
3.使用缺省目录创建一个 BSP为ads860的bootable工程testProject,
工程组成文件prjconfig.c 在_____目录、syslib.c______目录、
生成的VxWorks在______目录

4.配置Image 时,出现红色的模块组件,原是 _________________

5.以void demo(int arg1)函数为入口,以10为参数创建一个任务运行,
shell下该键入_______


6.使用工具_______来观察中断向量表

7.调试ISR使用_______调试方式

8.列举任务间通讯的至少4种方式_______、_______、_______、_______

(二)选择
1.假设tornado 安装在c:\tornado,make.exe估计应该在什么目录?
a. c:\tornado\host\x86-win32\bin
b. c:\tornado\target\config
c. c:\tornado\target\lib
d. c:\tornado\target\proj\run\default

2. task1与task2都要以读写方式访问一个数组,应该使用什么semaphore(a.binary b.mutual c.counting);
task1与task2访问数组的代码应该为:
task1:
(a.semGive b.semTake)
访问数组
(a.semGive b.semTake)

task2:
(a.semGive b.semTake)
访问数组
(a. semGive b.semTake)

3.程序先后执行了如下代码
msgQId = msgQCreate (numMsg, sizeof (struct msg), MSG_Q_FIFO))
msgQSend (msgQId, (char *) &msg1, sizeof (struct msg),
WAIT_FOREVER, MSG_PRI_NORMAL))
msgQSend (msgQId, (char *) &msg2, sizeof (struct msg),
WAIT_FOREVER, MSG_PRI_URGENT))
msgQSend (msgQId, (char *) &msg3, sizeof (struct msg),
WAIT_FOREVER, MSG_PRI_NORMAL))

则再有任务执行两次
msgQReceive (msgQId, (char *) &consumedItem,
sizeof (consumedItem), WAIT_FOREVER)
得到的先后是
a. msg1,msg2
b. msg2,msg3
c. msg3,msg2
d. msg2,msg1
e. msg2,msg2
f. msg1,msg3

4.比较message queue 与pipe
有prioritization 管理的是(a.message b.pipe c.message 和pipe)
使用标准I/O接口的是(a.message b.pipe c.message 和pipe)
可以使用select 的是(a.message b.pipe c.message 和pipe)

5.exception用什么机制来处理
a. ISR
b. signal
c. task
d. watch dog


6.下列函数哪些可以在ISR中使用
a. printf
b. logmsg
c. taskSuspend
d. semGive
e. msgQReceive
f. wdStart

7.watch dog工作在什么方式
a. 中断方式
b. 任务方式

(三)问答题
1.在shell下要观察一个为"buffer "( 为不明确的内容)的字符串内容,该如何操作?


2.分析如下windview输出结果
tPhil1是为什么失去控制权,tPhil3是为什么失去控制权?


3.一旦在程序中使用了KernelTimeSlice(10);则不同优先级的任务间的调度方式为?
相同优先级的任务间的调度方式为?


4.以void test((char *)cp1,int num)为入口,创建一个优先级为100,堆栈为2000,
名称为"test_task",操作字为0,参数为pointer1和200的任务,写出实现函数和参数


5. 分析源码
在shell下分别执行-> sp countingSemDemo, 'c' 与-> sp countingSemDemo,
'b',分析两者的运行效果会有什么不同,为什么?

/* include files */

#include "vxWorks.h"
#include "wdLib.h"
#include "stdio.h"
#include "semLib.h"
#include "taskLib.h"
#include "usrLib.h"
#include "sysLib.h"

/* defines */

#define TASK_PRIORITY 101
#define TASK_STACK_SIZE 5000
#define TIME_BETWEEN_INTERRUPTS 1 /* 1 tick */
#define TASK_WORK_TIME 2 /* 2 ticks */
#define NUM_OF_GIVES 30

/* globals */

/* counting or binary semaphore ID */
LOCAL SEM_ID semId = NULL;

/* watchdog ID */
LOCAL WDOG_ID wdId = NULL;

/* tid of syncTask */
LOCAL int syncTaskTid = 0;

/* Number of times semGive is called */
LOCAL int numToGive = NUM_OF_GIVES;

/* forward declaratiuon */
void syncISR(int);/* ISR to unblock syncTask */
void cleanUp (); /* cleanup routine */
void syncTask (); /* task that needs to be synchronized
* with external events */

/******************************************
* countingSemDemo - demonstrates
task synchronization using counting
* semaphores. User can also select to
use binary semaphore instead of
* counting semaphore in this demonstration,
for comparision between the two
* semaphores.
*
* RETURNS: OK or ERROR
*
*/

STATUS countingSemDemo (
char semType /* counting semaphore type
'c' or binary semaphore
* type 'b'
*/)
{
switch (semType)
{
case 'c':
case 'C':
if ((semId = semCCreate(SEM_Q_PRIORITY,
0)) == NULL)
{
perror ("semCCreate");
return (ERROR);
}
break;

case 'b':
case 'B':
if ((semId = semBCreate(SEM_Q_PRIORITY,
SEM_EMPTY)) == NULL)
{
perror ("semBCreate");
return (ERROR);
}
break;

default:
printf ("Unknown semType-- must be 'c' or 'b'\n");
return (ERROR);
}

if ((wdId = wdCreate()) == NULL)
{
perror ("wdCreate");
cleanUp ();
return (ERROR);
}


if ((syncTaskTid = taskSpawn ("tsyncTask", TASK_PRIORITY,0,
TASK_STACK_SIZE,(FUNCPTR) syncTask,
0,0,0,0,0,0,0,0,0,0)) == ERROR)
{
perror ("taskSpawn");
cleanUp();
return (ERROR);
}

/* watchdog simulates hardware interrupts */
if (wdStart (wdId, TIME_BETWEEN_INTERRUPTS,
(FUNCPTR) syncISR, numToGive)
== ERROR)
{
perror ("wdStart");
cleanUp ();
return (ERROR);
}

/* arbitrary delay to allow
program to complete before clean up */
taskDelay (sysClkRateGet() +
((TASK_WORK_TIME + 2) * numToGive));

cleanUp();
return (OK);
}

/*************************************************
* syncTask - synchronizes with interrupts using
* counting or binarysemaphores.
*/

void syncTask (void)
{
int eventCount = 0;

FOREVER
{
if (semTake (semId, WAIT_FOREVER) == ERROR)
{
perror ("syncTask semTake");
return;
}

/* Do "work" */
taskDelay (TASK_WORK_TIME);
semShow (semId,1);

eventCount++;
printf ("semaphore taken %d times\n", eventCount);
}

}

/************************************************
* syncISR - simulates a hardware device
which generates interrupts very
* quickly and synchronizes with
syncTask using semaphores.
*/
void syncISR(int times)
{
semGive (semId);
times--;
if (times > 0)
wdStart (wdId, TIME_BETWEEN_INTERRUPTS,
(FUNCPTR) syncISR, times);
}

/********************************************
* cleanUP - deletes the syncTask, deletes the
* semaphore and the watchdog timer previously created
* by countingSemDemo./
void cleanUp ()
{
if (syncTaskTid)
taskDelete (syncTaskTid);
if (semId)
semDelete (semId);
if (wdId)
wdDelete (wdId);

}
(注:休息15分钟,准备上机环境)
二. 开卷部分

(一)上机参考解答题(45分钟内独立完成)
1.怎样加入外部.o文件

2.如何获取函数wdStart的帮助

3.怎样生成bootrom

4.有如下的bootline 定义:
"fei(0,0)host:vxWorks h=10.100.62.35 e=10.100.62.88 u=target pw=target"
另外:VxWorks image在d:\user_project\vxworks 如何配置ftp服务器

5.Attach的功能是什么,Auto Attach是什么含义,怎样设置Auto Attach

6. 如何进入system调试模式

7.给出0x220102 Errno的意义

8.填图,内存布局

9.编程序,实现100次以20 ticks为周期的对函数 void test(void)的调用


(二)上机实验题(30分钟)

1.创建一个有target server file system 的
Simulator和相应的支持target server file system 的WDB连接

2.载入\start\cobble.c到 Simulator,
理解并调试dataSemId与crunch任务的关系

---------------------------------------------------------

答案
一.
(一)
1. C:\tornado\target\config\Pentium
Config.h
2. "tffs=0,0(0,0)host:/tffs0/vxworks h=90.0.0.3 e=90.0.0.50 u=target"
3. c:\tornado\target\proj\testProject\
c:\tornado\target\config\ads8260
c:\tornado\target\proj\testProject\default
4. 配置冲突、缺少需要的模块或有模块参数没有设置
5. sp demo(10)
6. browser
7. 系统调试
8. shared memory、semaphore、message queue、pipe、signal

(二)
1.A
2. B,B,A,B,A
3. D
4. A,B,B
5. B
6. B,C,D,F
7. A
(三)
1. 先用lkup "buffer"查找字符串的准确名称,同时也可以得到字符串的地址;
然后用 d 字符串名称 或 d 字符串地址来观察字符串内容

2. tPhil1因为执行了semTake,tPhil3因为执行了taskDelay

3. 不同优先级是基于优先级的抢占调度,相同优先级是基于时间片的轮巡调度

4. taskSpawn ( "test_task", 100, 0, (FUNCPTR) test, 2000,
(int) pointer1, 200, 0, 0, 0, 0, 0, 0, 0, 0);

5. 以'c'为参数最后显示的eventCount比以'b'为参数最后显示的eventCount要 大,这是因为syncISR作为数据源发送的速度比syncTask处理数据的速度快,
binary semaphore 会被重置而不能正确反映数据的个数;
counting semaphore则不会被重置。

二.
(一)
1. 在工程管理窗口的builds页面,打开工程的default选项窗口,
在Macros中定义出EXTRA_MODULES为外部.o文件;
或在makefile中定义出EXTRA_MODULES。

2. 打开Tornado 帮助系统,选择Manuals Index ,
再选择Index页面,在输入框中键入wdStart,然后确认显示,
即可以打开该函数的html帮助。

3. 在build菜单中选择 build boot rom ,
然后在弹出窗口中选择BSP和Image 类型,然后确认;
或在相应BSP目录中直接键入make CPU=CPU类型 Image类型

4. 在ftp服务器的Security菜单中选择Users/Rights ,然后new user ,
输入用户名和密码后,再把Home directory 置为d:\user_project\vxworks

5. Attach 用于多任务调试时,进入某个任务调试;
Auto Attach在某个任务遇到断点时,会自动进入该任务调试;
Auto Attach 在tools-options-debugger-"Auto attach to task"中设置。

6. 使用debug菜单的Attach功能,在弹出的窗口中选择system;
或进入GDB窗口,键入attach system命令。

7. 先在vxModNum.h中找出0x22的定义M_semLib,然后打开semLib.h,
查找0x102的定义,得出为S_semLib_INVALID_OPTION

8. RAM_LOW_ADRS RAM_HIGH_ADRS

9. 要点:
(1) 用taskDelay的定时精度不够,只能算及格;
(2) 用watch dog时,一定要注意在watch dog的实现体内再启动该watch dog;
控制100次调用可以使用全局变量,或包装test函数后传递函数参数。

评论

此博客中的热门博文

【转】AMBA、AHB、APB总线简介

AMBA 简介 随着深亚微米工艺技术日益成熟,集成电路芯片的规模越来越大。数字IC从基于时序驱动的设计方法,发展到基于IP复用的设计方法,并在SOC设计中得到了广泛应用。在基于IP复用的SoC设计中,片上总线设计是最关键的问题。为此,业界出现了很多片上总线标准。其中,由ARM公司推出的AMBA片上总线受到了广大IP开发商和SoC系统集成者的青睐,已成为一种流行的工业标准片上结构。AMBA规范主要包括了AHB(Advanced High performance Bus)系统总线和APB(Advanced Peripheral Bus)外围总线。   AMBA 片上总线        AMBA 2.0 规范包括四个部分:AHB、ASB、APB和Test Methodology。AHB的相互连接采用了传统的带有主模块和从模块的共享总线,接口与互连功能分离,这对芯片上模块之间的互连具有重要意义。AMBA已不仅是一种总线,更是一种带有接口模块的互连体系。下面将简要介绍比较重要的AHB和APB总线。 基于 AMBA 的片上系统        一个典型的基于AMBA总线的系统框图如图3所示。        大多数挂在总线上的模块(包括处理器)只是单一属性的功能模块:主模块或者从模块。主模块是向从模块发出读写操作的模块,如CPU,DSP等;从模块是接受命令并做出反应的模块,如片上的RAM,AHB/APB 桥等。另外,还有一些模块同时具有两种属性,例如直接存储器存取(DMA)在被编程时是从模块,但在系统读传输数据时必须是主模块。如果总线上存在多个主模块,就需要仲裁器来决定如何控制各种主模块对总线的访问。虽然仲裁规范是AMBA总线规范中的一部分,但具体使用的算法由RTL设计工程师决定,其中两个最常用的算法是固定优先级算法和循环制算法。AHB总线上最多可以有16个主模块和任意多个从模块,如果主模块数目大于16,则需再加一层结构(具体参阅ARM公司推出的Multi-layer AHB规范)。APB 桥既是APB总线上唯一的主模块,也是AHB系统总线上的从模块。其主要功能是锁存来自AHB系统总...

【转】GPIO编程模拟I2C入门

ARM编程:ARM普通GPIO口线模拟I2C  请教个问题: 因为需要很多EEPROM进行点对点控制,所以我现在要用ARM的GPIO模拟I2C,管脚方向我设 置的是向外的。我用网上的RW24C08的万能程序修改了一下,先进行两根线的模拟,SDA6, SCL6,但是读出来的数不对。我做了一个简单的实验,模拟SDA6,SCL6输出方波,在示波 器上看到正确方波,也就是说,我的输出控制是没问题的。 哪位大哥能指点一下,是否在接收时管脚方向要设为向内?(不过IOPIN不管什么方向都可 以读出当前状态值的阿) 附修改的RW24C08()程序: #define  SomeNOP() delay(300); /**/ /* *********************************  RW24C08   **************************************** */ /**/ /* ----------------------------------------------------------------------------- ---  调用方式:void I2CInit(void)   函数说明:私有函数,I2C专用 ------------------------------------------------------------------------------- -- */ void  I2CInit( void ) ... {  IO0CLR  =  SCL6;      // 初始状态关闭总线  SomeNOP();  // 延时   I2CStop();  // 确保初始化,此时数据线是高电平 }   /**/ /* ---------------------------------------------------------------------------- ----  调用方式:void I2CSta...

【转】cs8900网卡的移植至基于linux2.6内核的s3c2410平台

cs8900网卡的移植至基于linux2.6内核的s3c2410平台(转) 2008-03-11 20:58 硬件环境:SBC-2410X开发板(CPU:S3C2410X) 内核版本:2.6.11.1 运行环境:Debian2.6.8 交叉编译环境:gcc-3.3.4-glibc-2.3.3 第一部分 网卡CS8900A驱动程序的移植 一、从网上将Linux内核源代码下载到本机上,并将其解压: #tar jxf linux-2.6.11.1.tar.bz2 二、打开内核顶层目录中的Makefile文件,这个文件中需要修改的内容包括以下两个方面。 (1)指定目标平台。 移植前:         ARCH?= $(SUBARCH) 移植后: ARCH            :=arm (2)指定交叉编译器。 移植前: CROSS_COMPILE ?= 移植后: CROSS_COMPILE   :=/opt/crosstool/arm-s3c2410-linux-gnu/gcc-3.3.4-glibc-2.3.3/bin/arm-s3c2410-linux-gnu- 注:这里假设编译器就放在本机的那个目录下。 三、添加驱动程序源代码,这涉及到以下几个方面。(1)、从网上下载了cs8900.c和cs8900.h两个针对2.6.7的内核的驱动程序源代码,将其放在drivers/net/arm/目录下面。 #cp cs8900.c ./drivers/net/arm/ #cp cs8900.h ./drivers/net/arm/ 并在cs8900_probe()函数中,memset (&priv,0,sizeof (cs8900_t));函数之后添加如下两条语句: __raw_writel(0x2211d110,S3C2410_BWSCON); __raw_writel(0x1f7c,S3C2410_BANKCON3); 注:其原因在"第二部分"解释。 (2)、修改drivers/net/arm/目录下的Kconfig文件,在最后添加如...