view DOCS/Polish/users_against_developers.html @ 7299:131497b1f6ad

- GCC 3.x (SPARC) is too clever for the double->int conversion trick used in the WRITE_SAMPLE macro. Use a union instead of a cast to get at the binary representation of the double's mantissa. This should fix: http://mplayerhq.hu/pipermail/mplayer-users/2002-August/018948.html http://mplayerhq.hu/pipermail/mplayer-users/2002-August/019296.html http://mplayerhq.hu/pipermail/mplayer-users/2002-September/020348.html - garbage collect the unused CAN_COMPILE_X86 define
author jkeil
date Fri, 06 Sep 2002 17:34:52 +0000
parents d5c692754cf2
children
line wrap: on
line source

<HTML>

<HEAD>
 <META http-equiv="content-type" content="text/html; charset=iso-8859-2" />
</HEAD>

<BODY BGCOLOR=white>

<FONT face="Verdana, Arial, Helvetica, sans-serif" size=2>

<P><B><I>In medias res</I></B></P>

<P>Są takie dwa tematy, które zawsze wywołują wielką dyskusję i ogniste boje na
liście dyskusyjnej <A
HREF="http://www.MPlayerHQ.hu/cgi-bin/htsearch">użytkowników mplayera</A>.
Tematem numer jeden jest:</P>

<A NAME=gcc><P><B><I>serie GCC 2.96</I></B></P>

<P><B>Przeczytaj też <A HREF="gcc-2.96-3.0.html">ten</A> tekst !!!</B></P>

<P><I>Tło</I>: były/są serie GCC <B>2.95</B>. Najlepszą z nich była 2.95.3.
Zwróć uwagę na sposób numerowania wersji jądra. Oto jak drużyna GCC numeruje
swoje kompilatory. Serie 2.95 są dobre. Nigdy nie widziano, aby coś źle się
skompilowało z przyczyny błędów w 2.95.</P>

<P><I>Poczynania</I>: <B>RedHat</B> rozpoczął włączanie wersji GCC <B>2.96</B>
w swoich dystrybucjach. Zwróć uwagę na numerację wersji. To powinno być
numerowanie drużyny GCC. Oni nałożyli łatę na wersję CVS GCC (coś na
pograniczu 2.95 a 3.0). Ta łata była bardzo poważna i tej werji użyto do
dystrybucji, ponieważ wersja 3.0 nie była skończona na czas, a oni chcieli mieć
obsługę IA64 ASAP (z powodów własnych interesów). A przecież GCC 2.95
źle kompiluje bash na architekturze s390 (nie ma dystrybucji RedHata dla
s390..).</P>

<P><I>Fakty</I>: proces kompilacji <B>MPlayera</B> wymaga
<CODE>--disable-gcc-checking</CODE>, aby pominąć wykrywanie wersji GCC 2.96
(wyraźnie wymagana jest ta opcja przy <B>egcs</B> również; to dlatego, że my
nie testujemy <B>MPlayera</B> na egcs. Proszę nam wybaczyć, ale my raczej
zajmujemy się rozwijaniem <B>MPlayera</B>). Jeżeli znasz <B>MPlayera</B>,
powinieneś wiedzieć, że jest on bardzo szybki. Osiąga to poprzez
zoptymalizowanie kodu dla MMX/SSE/3DNow/itp., dzięki fastmemcpy i wielu innym
właściwościom. <B>MPlayer</B> zawierał instrujkcje MMX/3DNow w składni, którą
wszystkie kompilatory Linuksowe akceptują ... za wyjątkiem GCC RedHata (to
określenie jest bardziej zgodne ze standardem). On po prostu je
<B><I>przeskakuje</I></B>. Nie zgłasza błędów. Nie wysyła ostrzeżeń. <B>I</B>,
tam jest "Lame". Z gcc 2.96, sprawdzanie jakości (<CODE>make test</CODE> po
kompilacji) <I>nawet się nie uruchamia!!!</I> Hej, ale on kompiluje bash na
s390 i IA64.</P>

<P><I>Wnioski</I>: większość developerów na świecie zaczęło mieć złe odczucia
w związku z GCC 2.96 RedHata. Powiedzieli oni swoim użytkownikom RedHat'a, aby 
używali do kompilacji innych kompilatorów, niż 2.96. Rozczarowanie użytkowników
RedHata powoli przemieniło się w gniew. Co było takiego dobrego, w
przeciwieństwie do bólu głowy developerów, w dolewaniu oliwy do
anty-RedHatowskiego ognia, wprawiającym użytkowników w konsternację? Ja nie
znam odpowiedzi na to pytanie.</P>

<P><I>Teraźniejszość</I>: RedHat twierdzi, że GCC 2.96-85 i kolejne wersje są
naprawione i pracują właściwie. Zwróć uwagę na numerację wersji.To typowe, że 
zaczęli z czymś takim. A co z GCC 2.96.85? Nieistotne. Nie szukam, ale
wciąż widzę błędy w 2.96. To jest bez znaczenia teraz, miejmy nadzieję, że
<B>RedHat zapomni o 2.96</B> i skieruje się ku <B>3.0</B>. W kierunku
porządnie załatanego 3.0...</P>

<P><I>To, czego ja tu nie rozumiem</I>, to z jakiego powodu jesteśmy oblegani
przez użytkowników RedHata, żalących się na komunikaty ostrzegawcze i dokumenty
w rodzaju "trzymaj się z dala" w <B>MPlayerze</B>. Dlaczego jesteśmy nazywani
"umysłowo upośledzonymi", "totalnymi dupkami", "dziecinnymi w swoim myśleniu"
przez <B>użytkowników RedHata</B>, na naszej mailowej liście dyskusyjnej, a
nawet na liście <B>redhat-devel</B>. Rozważali oni nawet stworzenie odgałęzienia
<B>MPlayera</B> dla nich samych. Użytkownicy RedHata. Dlaczego? Czy to RedHat
stworzył kompilator, dlaczego <U>wy</U> musicie nas nienawidzieć? Jesteście aż
<U>takimi</U> wyznawcami RedHata? Proszę, przestańcie. My nie chowamy
urazy do użytkowników, nie ważne jak głośno ogłaszacie coś przeciwnego. Idźcie,
proszę, użerać się z Linusem Torvaldsem, z developerami DRI (och, teraz wiem już
dlaczego oni zostali opuszczeni przez VA!), Wine, avifile. Jeśli nawet
jesteśmy aroganccy, czy nie jesteśmy tacy sami jak wcześniej wspomniani?
Dlaczego to <B>my</B> musimy cierpieć z powodu niesłusznego gniewu?</P>

<P><A HREF="mailto:willis_matthew@yahoo.com">Matt Willis</A> uprzejmie
dostarczył proste howto (jak to zrobić) kompilacji GCC-3.0.3, które poniżej
zamieszczam:</P>

<P>
<UL>
 <LI>Ściągnij gcc. Idź na stronę: <A
  HREF="http://gcc.gnu.org/mirrors.html">http://gcc.gnu.org/mirrors.html</A>.
   Ja ściągnąłem następujące pliki, ale ty nie potrzebujesz ich wszystkich:<BR>
    <CODE>gcc-g++-3.0.3.tar.gz<BR>
    gcc-objc-3.0.3.tar.gz<BR>
    gcc-3.0.3.tar.gz<BR>
    gcc-g77-3.0.3.tar.gz<BR>
    gcc-testsuite-3.0.3.tar.gz<BR>
    gcc-core-3.0.3.tar.gz<BR>
    gcc-java-3.0.3.tar.gz</CODE>
  </LI>

  <LI>Rozpakuj pliki, stwórz katalog w którym będizesz budował i zbuduj:
  <CODE><PRE>
     tar xvzf gcc-*3.0.3.tar.gz
     mkdir gcc-build; cd gcc-build
     ../gcc-3.0.3/configure --prefix=/opt --program-suffix=-3.0.3
     make bootstrap; mkdir -p /opt; make install</PRE></CODE>

  <LI>Ustaw swoją ścieżkę, aby zawierała /opt/bin<BR>
     <CODE>export PATH=/opt/bin:${PATH}</CODE>

  <LI>Teraz możesz budować MPlayera.</LI>
</UL>
</P>

<A NAME=binary><P><B><I>Dystrybucja MPlayera w postaci binariów</I></B></P>

<P>Tony użytkowników proszą nas o to. Na przykład użytkownicy Debiana maja
zwyczaj mówić: Oh, mogę zrobić <CODE>apt-get install avifile</CODE>, dlaczego
mam <B>kompilować MPlayera</B>? To brzmi rozsądnie, ale problem leży nieco
głębiej, niż:
ci-pieprzeni-developerzy-MPlayera-nienawidzą-gcc-2.96-i-RedHata-i-Debiana.</P>

<P>Przyczyny: <B>Prawo</B></P>

<P><B>MPlayer</B> zapisany jest jako <U>źródła</U>. Zawiera on kilka plików z
niekompatybilnymi liecencjami w punktach dotyczących redystrybucji. Jako
źródłowe pliki, mają one prawo współistnieć w tym samym projekcie.</P>

<P>Jednakże <U>ANI BINARIA, ANI BINARNE PAKIETY <B>MPlayera</B> NIE MAJĄ PRAWA
ISTNIEĆ W CHWILI, GDY TAKIE OBIEKTY ŁAMIĄ LICENCJE</U>. LUDZIE, KTÓRZY
ROZPROWADZAJĄ TAKIE PAKIETY BINARNE POSTĘPUJĄ NIELEGALNIE.</P>

<P>Więc jeśli znasz kogoś, kto rozporządza binarnymi pakietami, wówczas daj mu
do przeczytania ten tekst i (poproś go o) kontakt z nami. To co on/ona robi,
jest nielegalne I TO JUŻ NIE JEST <B>MPlayer</B>, a <U>jego/jej</U> mplayer.
Jeśli źle działa, to to jest jego/jej wina. Niech nikt nie przychodzi i nie
żali się na listę mailową <B>MPlayera</B>, bo najprawdopodobniej zostanie
zapisany na czarną listę.</P>

<P>Przyczyny: <B>Techniczne</B></P>

<P>
<UL>
  <LI>Optymalizacja szybkości działania <B>MPlayera</B> (MMX, SSE, fastmemcpy,
    itp) jest zdeterminowana podczas kompilacji. Z tego powodu skompilowane
    binaria zawierają bardzo specyficzny dla danego procesora kod.  Binaria
    <B>MPlayera</B> skompilowane dla K6 nie będą wydolne na procesorach Pentium
    i vice versa. To zostało rozpracowane poprzez wykrywanie runtime, co nie
    jest łatwą do obejścia zrobienia, gdyż sprawia masową utratę prędkości.
    Jeśli nie wierzysz (to było juz 10000 razy wyjaśnione w szczegółach na
    mplayer-users, przeszukaj archiwum), to rozwikłaj to i wyślij nam patch.
    Ktoś zaczął nad tym pracować, ale nie ma o nim wieści od tamtej pory.</LI>
  <LI>System audio/video <B>MPlayera</B> nie jest oparty na systemie
    wtyczek. System audio/video jest wkompilowany w binaria, co powoduje
    zależność binariów od różnych bibliotek (GUI zależy od GTK, DivX4 zależy od
    libdivxdecore, SDL zależy od libSDL, każde wydanie SDL zawiera unikalny
    błąd, ktory musi być ominięty w czasie kompilacji, X11 wyjście w różny
    sposób się kompiluje X3 i X4, itp). Możesz powiedzieć: więc zróbmy 30
    wersji binariów do ściągnięcia! Nie zrobimy tego. Zrobimy te rzeczy w
    postaci wtyczek w przyszłości.</LI>
</UL>

<A NAME=nvidia><P><B><I>NVidia</I></B></P>

<P>Nie lubimy binarnych sterowników nvidii, ich jakości, niestabilności,
nieistniejącego wsparcia dla użytkowników, wciąż pojawiających się nowych
błędów. Większość użytkowników ma do nich podobne podejście. Skontaktowali się
z nami później ludzie z NVidii i powiedzieli, że te błędy nie istnieją,
niestabilność jest winą chipów AGP i odmówili opublikowania raportu o
błędach sterownika (np. o fioletowej linii). Więc jeśli masz problem ze swoją
NVidią, uaktualizuj sterownik nvidii i/lub kup nową płytę główną.</P>

<A NAME=kotsog><P><B><I>Joe Barr</I></B></P>

<P>On nie odpowiada na nasze maile. Jego wydawca nie odpowiada na nasze maile.
Sieć jest pełna jego fałszywych stwierdzeń i oskarżeń (on widocznie nei lubi na
przykład chłopaków z BSD, z powodu różnicy poglądów [na jaki temat?]).</P>

<P>Oto kilka cytatów wypowiedzi różnych ludzi na temat Joe Barr (tylko po to,
abyś zrozumiał, dlaczego on się kompletnie nie liczy):</P>

<P><I>"Wszyscy pamiętacie LinuxWorld 2000, kiedy on twierdził, że Linus T.
powiedział, że FreeBSD, to garstka developerów. Linus nie powiedział NICZEGO w
tym rodzaju. Kiedy to wypomniano Joe'mu, jego reakcją było wyzwanie ludzi
utrzymujących BSD of dupków i glupków."</I></P>

<P><I>"On jest interesujący, ale kiepsko mu wychodzi unikanie ...
kontrowersyjności. Joe Barr był regularnym uczestnikiem forum Willa Zachmanna
w Compuserve, kilka lat temu. Był zwolennikiem OS/2 (ja również byłem
zwolennikiem OS/2). Często przekraczał wszelkie granice, rozwścieczając ludzi
i podejrzewam, że to były ciężkie czasy dla niego. Trochę złagodniał ostatnio,
będąc ocenionym przez własny dział redakcyjny. Stonowany, subtelny humor nie był
jednak jesgo stylem w tamtych wczesnych dniach w zupełności.  "</I></P>
</HTML>