黑暗的麻烦
2011年10月24日 16:18 发布者:eechina
Songbird Hearing公司Walter Sjursena20世纪80年代初期,我一直做一种专用的计算机终端CRT显示器,用于我们公司为一家大型飞机公司设计的一种飞行管理计算机。其显示器必须有足够的亮度,在日光直射的驾驶舱内能看清楚,而在夜间飞行时又必须能够暗下来。显示器采用书体字符来获得所需亮度,尽量减少功耗。
为了优化应用中的书体字符集,我们最初选择了一片2716 UV(紫外)EPROM,这样我们就能做试验,并快速地做修改。一名工程师做字符集,然后将需要的字符写入2716中。我们对它做了测试,一切都工作良好。然而,我们很快发现刚上市的2732 EPROM很可能会淘汰2716。由于仍处于设计前期,因此我们决定换用2732。它的封装不变,引脚也与2716一样,不过多了几个地址位,因此更换工作很简单。我们写了一片2732,将其插入面包板上的插座。一切都很正常。我们继续测试设计中的其它部分,寻找并解决各处的问题。
时间逐步接近于一次重要的设计审核。我们的客户打算来访,看看运行中的原型机。我们对顺利的演示很有信心,因为已经做了多轮测试。怎么可能会出问题?我们打算这么演示给客户看:操作员在夜间操作时,显示器会降低亮度。虽然我们已测过了光输出,坚信它能处于规范内,但测试仪器上的数字不如一次实际演示更有说服力。应我们的要求,厂内实验室建造了一座“暗室”,这样我们就能演示显示器在明亮日光和昏暗条件下的工作情况。
然后,我们把所有面包板和测试设备转移到了暗室内。过了一会儿,一名工程师来到我们办公室说出现了一个问题。当他关灯以后,显示器能在10秒后变暗。当他开灯时,显示器却全白了。
经过一番思考,我们明白了,最初的逻辑图只接了2716的地址线,却忘了2732多出的地址线。2732在实验室已经工作了几个月,我们逐渐意识到,实验室中总有从擦除UV EPROM的石英窗口射出的光线,而我们从来没有打算要把这个窗口挡上,因为我们仍处于开发模式,实验室的光线太暗,不能在较短时间内擦除UV EPROM。2732上的额外地址线恰好在光照下处于低逻辑电平,而在暗处则会是高逻辑电平。这个动作将选择我们并未写入程序的那半个EPROM,恰好是写入所有空格字符的部分。因此,整个显示器都显示空白。
知道了问题的根源,解决就很简单。我们那次重要的客户设计审核顺利通过。无论是在明亮光线还是全暗情况下,演示过程都很顺利。
第二天,一名工程师叫我去暗室,告诉我出现了一个新问题。当他关灯时,整个显示器都变为显示中文字符。而当把开关扳回时,屏幕又变回英文。我知道,这是他为庆祝成功的演示而给我开的一个玩笑。他将2732一半写入中文字符,而将悬浮的地址线接了一只开关,可以让地址线接地或悬浮。我们会心地大笑后,继续去工作了。