附录 E -- 开发者的眼泪

总在mplayer-users邮件列表上引起巨大争吵和怒火的主题主要有两个。第一个主题是关于

E.1 GCC 2.96

背景:GCC2.95系列是GNU官方发行版而GCC的2.95.3版本是这个系列中bug最少的。我们从来没有遇到过可以归罪于GCC 2.95.3的编译问题。 从RedHat Linux 7.0开始,Red Hat在他们的发行版里包括了一个打满补丁的CVS版本的GCC,命名为2.96。Red Hat在他的发行版中包括这个版本是因为 当时GCC 3.0还没有完成,而他们需要一个在所有他们支持的平台上,包括IA64和s390都正常工作的编译器。Linux发行版Mandrake也照着Red Hat的例子开始 在他们的Linux-Mandrake 8.0系列中搭载GCC 2.96。

声明:GCC小组否认于GCC 2.96有任何联系并对GCC 2.96发表了一份官方回应。世界各地的开发者 开始遇到GCC 2.96的问题,并开始推荐其他的编译程序。ApacheMySQLavifileWine。其他你会感兴趣的链接有:Real time LinuxLinux kernel news flash about kernel 2.4.17Voy Forum。MPlayer同样经受这些时有时无的只要换个不同版本的GCC就可以全部解决的问题。 有些项目开始为一些2.96的问题实现绕过的方法,但是我们拒绝修正别人的bug,尤其是其中一些绕过的方法意味着降低性能。

你能在这个站点的读到故事的另一面。GCC 2.96不允许在汇编程序中出现|(管道)字符因为它同时支持 Intel和AT&T的语法而|字符在Intel版本中是个符号。问题是它一声不吭的忽略了整个汇编程序块。这个问题现在应该被修正了,GCC会显示一个警告 而不是直接跳过。

现状:Red Hat说2.96-85以上的GCC都已经修正了。情况确实好了很多,但我们在我们的邮件列表里仍然遇到一些换了编译器之后就不存在了的问题。 在任何情况下它都不再重要了。希望一个成熟的GCC 3.x将很好的解决这个问题。如果你想要用2.96编译的话在configure的时候加上--disable-gcc-checking 标记。记住你要自己负责而且不要报告任何bug。如果你报告,你只会被我们的邮件列表封掉,因为对于GCC 2.96我们已经有够多的争吵了。请让它平息下来。

如果你的GCC 2.96有问题,你能从Red Hat的ftp服务器得到2.96-85的包,或者直接去找7.2或更高版本里面提供的 3.0.4的包。你也能用gcc-3.2-10的包(非官方的,但是工作地不错)和你能把他们跟你已经有的2.96 装在一起。MPlayer检测到它并用3.2-10代替2.96。如果你不想要或者无法使用二进制包,下面教你怎么从源代码编译最新的GCC:

  1. GCC镜像页网页并下载gcc-core-XXX.tar.gzXXX是版本号。里面包括了完整的C编译器程序, 对MPlayer是足够了。如果你也想要C++,Java或其它一些GCC的高级特性gcc-XXX.tar.gz可能更适合你。
  2. 用下列命令解开文档
    tar -xvzf gcc-core-XXX.tar.gz
  3. GCC不像大多数程序一样的在自己的源码目录内编译,而是需要一个源码目录之外的编译目录。所以你需要这样创建这个目录
    mkdir gcc-build
  4. 然后,你能继续在GCC编译目录中配置GCC,但你需要源码目录中的configure:
    cd gcc-build
    ../gcc-XXX/configure
  5. 在编译目录中运行下列命令来编译GCC:
    做依靠自己力量
  6. 现在你可以运行下列命令安装GCC(以root身份)
    make install

E.2 二进制发行版

MPlayer以前包含来自OpenDivX工程的源代码,那是不能以二进制形式再分发的。这个代码已经在0.90-pre1中去掉了,剩下的来自OpenDivX源码 的divx_vbr.c在0.90-pre9的时候由它的作者按GPL协议发布。现在如果你觉得合适的话欢迎你制作二进制的包。

二进制分发的另一个阻碍是针对CPU结构的编译优化。 MPlayer运行时CPU检测(在编译时指定--enable-runtime-cpudetection)。 它默认是禁用的因为它意味着小小的速度牺牲,现在可以创建在能在Intel CPU家族的不同的成员上运行的二进制文件了。

E.3 nVidia

我们讨厌nVidia仅仅提供二进制的驱动(用于XFree86)的作法,他们通常都很buggy。我们在mplayer-users上已有许多关于这些封闭源代码的驱动和他们的低质量,不稳定以及糟糕的用户和专家 支持的报告。这里有一个来自nVidia的Linux论坛 的例子。许多这样的问题与异常持续不断重复的出现。我们最近跟nVidia接触过,而他们说这些错误不存在,不稳定是由于质量不好的AGP芯片造成的 ,而他们没有收到驱动bug(例如紫色条纹)的报告。因此如果你的nVidia显卡有问题,建议你升级nVidia驱动和/或者购买新的主板或者要求nVidia提供开源的驱动。 在任何情况下,如果你使用nVidia的二进制的驱动并遇到驱动相关的问题,请你明白你几乎不能从我们这里得到帮助,因为我们在这个问题上无能为力。

E.4 Joe Barr

Joe Barr因为写了一篇一点都不讨人喜欢的MPlayer评论而变得 声名狼籍。他发现MPlayer难以安装,但是然而他由不太喜欢阅读文档。他同样得出结论认为开发者是不友好的, 文件是不完整和侮辱性的。你自己判断吧。他继续在他的2002年的Linux十大预言中否定mplayer,接下来在xine的评论中他继续扇风点火。富有讽刺意味的是在那篇文章结束时他引用的 他与xine原作者的G黱ter Bartsch的争论,完美地总结整个情况:

然而,他也继续说他对我写的Mplayer的专题感到“惊讶”并觉得那是不公平的,他提醒我那是一个免费软件工程。“如果你不喜欢它,”Bartsch说,“你有不使用它的自由”。

他不答复我们的邮件。他的编辑也不答复了我们的邮件。这里引用一些不同的人关于Joe Barr的评论,方便你形成你自己的观点:

Marc Rassbach有些针对这个人的评论

你们都记得在LinuxWorld 2000的时候他说Linus T说‘FreeBSD只是一小撮程序员’。Linus从没说过任何这类东西。当Joe因此被讯问时, 他的反应是说BSD的支持者是白痴和蠢才。

一段来自mplayer-users邮件列表上的Robert Munro的引文

他挺有意思,但不善于避免,um ...争论。 Joe Barr以前是Compuserve上的Will Zachmann上的Canopus论坛的常客。他那时是OS/2的拥护者(我也是OS/2迷)。

他常常说话过头,骂人,我怀疑他有没有经历过什么困难。以他最近的专栏看来,他软化了些。 适当的阴险的幽默不是他早年的方式,完全不是。