条件跳转指令Jcc(Jump condition code)
关于条件跳转指令,特别是用于有符号数比较的Jcc指令,网上的文章多有讹误,这次彻底的厘清一下,以备忘。
在介绍条件跳转指令之前,介绍一下EFLAGS寄存器中的状态标志(Status Flag)是有必要的,Jcc中的cc(condition code)即表示需要测试的状态标志或状态标志组合。EFLAGS寄存器的低16位在8086时代叫做FLAGS寄存器,又称作程序状态字PSW(Program Status Word)。
负数补码(two’s complement)的原理及证明
在本文里面,com指代complement, neg指代negative,并且本文涉及的是”2的补码”(two’s complement)而不是”1的补码”(one’s complement)
学过计算机的大部分人都知道负数在计算机内部是用补码表示的,但是大部分的教材和文章里面都只是简单的告诉你负数的补码等于其反码加一云云,至于为什么是这样,则基本上都语焉不详。
负数用补码表示的好处就是减法可以转化为加法,简化硬件设计,CPU只用一个加法器就可以进行加减法运算了。
下面我就尝试着来证明一下,为什么负数的补码等于反码加一。
理解下面的推导要求读者必须了解模数的概念和求模运算。
debian:ssh安全自动登录设置
用ssh来管理远程服务器真是一件很舒适安逸的事情,当然前提是要做足安全工作,internet上可是杀机四伏啊。
记得我刚安装好Debian的时候 ,为root设置了一个很简单的密码,然后开放了ssh服务,没几天root帐号就让人给暴了, 看看/var/log/auth.log吧,真是惨不忍睹,里面全是尝试ssh登录的记录。好吧,我承认,当时是太没经验了。当然现在这种情况是一去不复返了。
下面就来说说如何提高ssh登录的安全性和自动登录ssh服务器。
64位运算中的REX指令前缀
64bits CPU引入了REX指令前缀。
REX前缀的主要功能有以下几点:
指定通用寄存器和SSE寄存器,当然主要是来指定扩展的寄存器,如R8-R15寄存器等
指定64位操作数
指定扩展控制寄存器
一直以来都不知道这个REX缩写词是由哪个或哪几个单词缩写来的,今天突然想明白了,REX应该就是Register EXtension,因为REX的主要功能就是用来索引扩展寄存器的。
关于REX前缀更详细的介绍,请参考Intel® 64 and IA-32 Architectures Software Developer’s Manuals
VirtualBox:客户机FreeBSD 7.2时间严重漂移、跑慢问题
一直琢磨着抽空再玩玩FreeBSD,第一次接触FreeBSD是6.0-Release,距现在时间不短了。
前几天有点儿时间,在windows 2003 R2 x86服务器上的VirualBox 2.2.4里面开始安装最新的FreeBSD 7.2 AMD64 Release。安装也还算顺利,毕竟原来接触过,熟悉了他的分区规则概念slice和partition就没啥大的障碍了。这次装FreeBSD要好好的研究一下,以后在FreeBSD里面host个网站,FreeBSD毕竟是TCP/IP的发源地,其稳定性也是有目共睹的。
因为有在VirtualBox里面安装Debian的经验,特别关注了一下客户机的时间,果然客户机的时间走的特别慢,没多久就与Host差了几分钟,而且可以看到时间差在明显的拉大。系统时间的准确性对于服务器来讲还是比较重要的,cron守护程序,网络日志等都严重依赖于系统时间。因为在客户机Debian使用的ntpd来校对系统时间,运行很正常,也在这里如法炮制吧,在运行ntpd之前也用ntpdate同步了几次时间。但是,为什么又是”但是”。
ntpd看样子很正常,但是Guest系统时间依旧比Host慢一拍,差距眼看着在拉大。当时实在是搞不清怎么回事了,google了一下也没找到满意答案,就暂时放下了。
今天连上FreeBSD一看,晕,时间都慢了一天多了,看来不解决时间是不行了。去google英文站搜,经过几轮筛选总算发现了一个有价值的信息:在FreeBSD的/boot/loader.conf文件里面增加一句kern.hz=100。赶快试验了一下,还真是这样,记得要重启一下guest。不用开ntpd时间也跑的很准确了。当然如果你要求很高可以继续开着ntpd。kern=100这几话怎么讲呢,官方说是降低客户化FreeBSD的CPU使用率,难道是因为CPU使用率高导致部分时钟中断丢失造成时间跑慢吗?我还没想明白,谁明白这个原理给我留言解释一下吧,谢谢。
===
[erq]
traceroute: 使用纯真IP数据库显示中间路由器以及主机的地理位置
traceroute是常用的网络诊断和查询工具,但是通常traceroute只能显示中间路由器和主机的ip地址和主机名,如果能输出机器的地理位置是最好不过了。怎么办?重新写一个traceroute?这是windows的思路。traceroute已经足够好了,为什么要重写呢,我们只要把结果加工一下就可以了。不得不佩服UNIX的设计哲学,无疑这种正交的功能,如果硬要搀和在一起,实在是没什么必要和额外的好处。
awstats:纯真IP数据库查询脚本ip_geo_qqwry.pl
这几天正好研究了一下纯真IP数据库的格式,看着qqwry.pl的代码实在是太乱,所以完全重写了一个perl查询脚本ip_geo_qqwry.pl,配合qqhostinfo插件来查询IP地理位置,看着顺眼多了 :)
awstats:utf8编码页面使用纯真IP数据库显示地理位置问题的解决办法
utf8是目前最好的多字节编码方案,支持世界上的绝多大多数语言,也是我最喜欢的字符集。debian lenny 上的awstats安装完毕后,默认输出iso-8859-1字符集,对中文支持不友好。打开/usr/lib/cgi-bin/awstats.pl
,定位到大约第80、81行将$PageCode变量的内容更改为’UTF-8’,这样awstats就可以吐出utf8编码格式的页面了。修改成utf8字符集还有一个好处,不用加载decodeutfkeys插件就可以正确的显示来自google的中文搜索关键字了。至于百度让它自生自灭去吧!
awstats通过插件qqhostinfo插件和qqwry.pl库使用纯真IP数据库可以显示来访者的地理位置,是一个不错的解决方案。具体的使用方法网上转载很多,可以google之。纯真IP数据库使用的是gbk/gb2312/gb18030系列编码,而我的awstats使用utf8编码,所以显示出来的物理地址全部是乱码。解决方法也很简单,打开qqwry.pl,在文件前面加上一句”use Encode;”,然后找到”return $ipaddr;”这一行,在其前面加上一句”$ipaddr=decode(“gbk”,$ipaddr);” 就ok了,因为perl 5内部使用的就是utf8编码,所以就不用再encode成utf8了。