Loppuraportti: XBMC:n kääntäminen LFS-järjestelmän päälle

Tavoitteena

Olimme asettaneet alkuraportissa tavoitteeksi kääntää xbmc oman järjestelmämme päälle. Pysyin aikataulussa melko heikosti ja huomasin projektin loppusuoralla pakettien kääntämisen vievän selvästi enemmän aikaa raspberry pi:llä kuin mitä oletin.

Luistinkin omasta vaatimuksesta kääntää xbmc:n omalle järjestelmällemme joten päädyin siis kääntämään ohjelman ko. valmiin julkaisun päälle. Toivottavasti otan omasta aikataulutuksestani opinnon.

Omassa käytössäni olen pitänyt xbmc medialaitetta jo aikaisemmin ja aijonkin ottaa raspberry pi:n tähän käyttöön itselleni.

Palaute

Kurssiaiheenahan kurssi on eritäin mukava ja omavalintainen aihe on motivoiva. Toivoisin vastaavanlaisia kursseja enemmänkin.

–  Tuomas Latvanen

Kategoriat:Raspberry Pi, xbmc

Optimointi

Kellotus

Raspberry pi: tulee vakiona 700Mhz: kellotetuksella, mutta valmistaja antaa takuuta 1000Mhz asti ylikellotetulle laitteelle. Testasin eri kellotaajuuksien vakauksia. Kellotaajuus luetaan muistikortin tiedostosta ”/boot/config.txt”. Kyseisessä tiedostossa on myös näyttömuistin koko. Testasin nostaa kellotaajuutta 50Mhz korotuksilla.

  • 700 Mhz- Vakiokellotaajuus
  • 750 – 1000Mhz  – Laite vakaa
  • 1050 Mhz Sain xbmc:n kaatumaan videota toistaessa.

Näistä päätellenkin suosittelen tylsien ns. turbo asetuksien (1000Mhz) käyttöä. Tämä tapahtuu ottamalla turbon kommentointi pois. ennemmin mainitusta tekstitiedostosta.

# Turbo
arm_freq=1000
core_freq=500
sdram_freq=500
over_voltage=6

Näyttömuisti

Testasin laitteen näyttömuistin vaihtamista, ja huomasin selvää xbmc:n operaatioiden (esim. ruudun vaihtaminen) hidastumista kun olin asettanut suureemman kuin 256 megabitin näyttömuistin käyttöön. En huomannut parantunutta videontoistoa joten päädyin vaihtamaan muistin takaisin. Etsin googlella erityisiä ohjeita näyttömuistista ja huomasin joidenkin julkaisujen kuitenkin käyttävän 256MB näyttömuistia.

http://www.raspbmc.com/wiki/user/frequently-asked-questions/

Uudelleenosiointi

Dd komennolla kopioimalla kopioituu image levylle bitti bitiltä. Ylimääräistä tilaa ei voi siis jättää imageen, joten levyimagessa osiointi on mahdollisimman pieni. Minun täytyy siis suurentaa levyosiointi erikseen.

Jokela on kirjoittanut levyosioinnin laajentamisesta yksinkertaisen step-by-step ohjeen.

–  Tuomas Latvanen

Kategoriat:Raspberry Pi, xbmc

Pakettien kääntö

Aloitin pakettien käännön käyttämällä aikaisemmin luomaani ssh yhteyttä. Käytin ssh yhteyttä nopeuttaakseen prosessia sillä en halunnut kirjoittaa jokaikistä make komentoa.

Olin tehnyt listan vaadittavista paketeista tänne, ja ennen kääntämistä latasinkin jokaisen paketin.

wget http://curl.haxx.se/download/curl-7.28.0.tar.bz2 http://mxr.mozilla.org/mozilla/source/security/nss/lib/ckfw/builtins/certdata.txt?raw=1 http://www.openssl.org/source/openssl-1.0.1c.tar.gz http://ftp.gnu.org/gnu/gnutls/gnutls-3.1.4.tar.xz http://downloads.sourceforge.net/expat/expat-2.1.0.tar.gz http://downloads.sourceforge.net/boost/boost_1_51_0.tar.bz2 http://downloads.sourceforge.net/freetype/freetype-2.4.10.tar.bz2 http://fontconfig.org/release/fontconfig-2.10.1.tar.bz2 http://fribidi.org/download/fribidi-0.19.4.tar.bz2 http://libmpeg2.sourceforge.net/files/libmpeg2-0.5.1.tar.gz http://downloads.sourceforge.net/mad/libmad-0.15.1b.tar.gz http://www.ijg.org/files/jpegsrc.v8d.tar.gz http://www.mega-nerd.com/SRC/libsamplerate-0.1.8.tar.gz http://downloads.xiph.org/releases/ogg/libogg-1.3.0.tar.xz http://downloads.xiph.org/releases/vorbis/libvorbis-1.3.3.tar.xz http://downloads.sourceforge.net/flac/flac-1.2.1.tar.gz http://download.osgeo.org/libtiff/tiff-4.0.3.tar.gz http://www.oberhumer.com/opensource/lzo/download/lzo-2.06.tar.gz http://github.com/downloads/libarchive/libarchive/libarchive-3.0.4.tar.gz http://www.cmake.org/files/v2.8/cmake-2.8.10.tar.gz http://www.xs4all.nl/~carlo17/which/which-2.20.tar.gz http://downloads.sourceforge.net/infozip/zip30.tar.gz http://downloads.sourceforge.net/infozip/unzip60.tar.gz http://sqlite.org/sqlite-autoconf-3071401.tar.gz http://downloads.sourceforge.net/libpng/libpng-1.5.13.tar.xz http://downloads.sourceforge.net/pcre/pcre-8.31.tar.bz2 http://www.ece.uvic.ca/~mdadams/jasper/software/jasper-1.900.1.zip http://ffmpeg.org/releases/ffmpeg-1.0.tar.bz2 http://ftp.gnu.org/gnu/gperf/gperf-3.0.4.tar.gz http://git-core.googlecode.com/files/git-1.8.0.tar.gz http://www.python.org/ftp/python/2.7.3/Python-2.7.3.tar.xz http://www.libsdl.org/release/SDL-1.2.15.tar.gz https://libass.googlecode.com/files/libass-0.10.1.tar.gz http://sourceforge.net/projects/modplug-xmms/files/libmodplug/0.8.8.4/libmodplug-0.8.8.4.tar.gz http://ftp.gnu.org/gnu/libcdio/libcdio-0.83.tar.bz2 https://github.com/downloads/taglib/taglib/taglib-1.8.tar.gz http://prdownloads.sourceforge.net/swig/swig-2.0.8.tar.gz

nimesin certdatan vielä certdata.txt:ksi.
mv certdata.txt?raw=1 certdata.txt

Pakettien asennus:

En käy läpi erikseen jokaista paketin kääntämistä, sillä pakettejahan on lähes puolisataa. Paketit toimitetaan yleensä pakattuina, ja pakkaamisen jälkeen paketit voivat vaatia myös configurointia. Tämänjälkeen paketit voidaan kääntää ja lopuksi asentaa. Tarkemmat ohjeet löyisin pääasiassa BLFS sivustolta.

Purkaminen

Paketit toimitetaan yleensä tar.gz tai tar.bz2 muodoissa. Poikkeuksena näistä mozillan certdata tiedosto(tekstitiedosto) sekä jasper joka toimitettiin .zip tiedostona. Eri muotojen purkamiskomento vaihtelee joten listaankin ne tässä

.tar.gz     ”tar -xvzf filename.tar.gz”
.tgz         ”tar -xvf filename.tgz”
.tar.Z        ”tar -xvf filename.tar.Z”
.tar.bz2    ”tar -xvjf filename.tar.bz2”

.zip        ”unzip filename.zip”

Configurointi

Pakettien configurointi onnistuu yleensä./configure komennolla, eli configure skriptin ajamalla. Kaikki paketit eivät edellytä tätä. Tyypillinen configuroitni on esim: ”./configure –prefix=/usr” Pakettien configurointi ja kääntöohjeet ovat katsottava jostain ja tyypillisesi löytäisinkin ne ”README” tai ”INSTALL” nimisistä tiedostoista paketin sisältä. Asensin paketit pääosin BLFS kirjan ohjeiden mukaisesti, turvautuen ohjeisiin ongelmatilanteissa.

Kääntö

Pakettien kääntäminen on prosessi jossa lähdekoodi muutetaan konekielelle. Kääntäminen vaatii mm. jo asennetut gcc (itse kääntäjä) ja make (ohjaa kääntämisprosessia). Työkaluna make lukee paketin mukana toimitettua tiedostoa ”makefile” joka sisältää tarkemmat kääntöohjeet.

Makefilestä ohjelman kääntö onnistuu siis komennolla
”make”

Huomiona pakettien kääntö voi viedä erittäin vaihtelevan määrän aikaa.

Asennus

Lopuksi paketti asennetaan käyttäen komentoa

”make install”

Make install kopio käännetyt binäärit lopulliseen sijaintiinsa.

–  Tuomas Latvanen

Kategoriat:Raspberry Pi, xbmc

Raspin käyttöönotto

Olen nyt kirjoittanut ko. netistä ladatun lfs julkaisun muistikortille, ja voin alkaa käyttää laitetta.

Huom: ennenkuin laitat laitetta verkkoon, sinun täytyy joko vaihtaa root käyttäjän salasana ”pilfs” toiseen taikka varmistaa että laite on semmoisessa verkossa jossa ulkopuolinen ei voi yhdistää porttiin 22. Muuten riskeeraat koko järjestelmän tietoturvan

DHCP clientin kytkeminen päälle

Halusin kääntää paketteja käyttäen ssh yhteyttä, joten minun täytyi laittaa verkkoyhteys toimimaan. Sitä ennen vaihdoinkuitenkin kirjainkartan käyttömukavuuden kannalta.

[root@tty1] [~] loadkeys fi

Intestines julkaisun verkkoasetukset sijaitsevat /etc/sysconfig/ kansiossa, jossa ”ifconfig.eth0” sisältää verkkoasetukset. Valmiit dhcp:tä käyttävät verkkoasetukset ovat ”ifconfig.dhcp” tiedostossa, joten muutaman tiedoston nimeämällä saadaan käyttöön dhcp.

[root@tty1] [~] cd /etc/sysconfig/
[root@tty1] [/etc/sysconfig/] mv ifconfig.eth0 ifconfig.eth0_old
[root@tty1] [/etc/sysconfig/] mv ifconfig.dhcp ifconfig.eth0

Vielä ssh yhteyden luomiseksi vaadittava ip osoite voidaan selvittää ”ip addr” komennolla.

Yhdistin nyt laitteeseen valitsemallasi salasanalla.
tuomas@morde:~/Downloads$ ssh root@192.168.1.151
root@192.168.1.151’s password:
Last login: Thu Jan  1 01:04:25 1970 from 192.168.1.101

–  Tuomas Latvanen

Kategoriat:Raspberry Pi, xbmc

XBMC – intestines xbmc:n kirjoitus levylle

Pakatun imagen lataaminen:
tuomas@morde:~$ cd Downloads/
tuomas@morde:~/Downloads$ wget http://circu.it/pilfs/pilfs-base-20121118.zip

–2012-12-09 08:11:01–  http://circu.it/pilfs/pilfs-base-20121118.zip
Resolving circu.it (circu.it)… 208.64.38.104
Connecting to circu.it (circu.it)|208.64.38.104|:80… connected.
HTTP request sent, awaiting response… 200 OK
Length: 377822116 (360M) [application/zip]
Saving to: `pilfs-base-20121118.zip’

100%[======================================>] 377,822,116 9.01M/s   in 46s

2012-12-09 08:11:48 (7.82 MB/s) – `pilfs-base-20121118.zip’ saved [377822116/377822116]

100%[===================================================================================================>] 1,086,337,762 11.2M/s   in 92s

2012-12-09 04:37:24 (11.2 MB/s) – `hiawatha0.2_quake.img.zip’ saved [1086337762/1086337762]

zip paketin purku:
tuomas@morde:~/Downloads$ unzip pilfs-base-20121118.zip

Archive:  pilfs-base-20121118.zip
inflating: pilfs-base-20121118.img

Imagen kirjoittaminen muistikortille

Image kirjoitetaan muistikortille käyttäen dd ohjelmaa.
tuomas@morde:~/Downloads$ sudo dd bs=4M if=/home/tuomas/Downloads/pilfs-base-20121118.img of=/dev/sdb

[sudo] password for tuomas:
237+1 records in
237+1 records out
996147200 bytes (996 MB) copied, 87.4062 s, 11.4 MB/s

Synkronisoin vielä kirjoitusmuistin komennolla sync
tuomas@morde:~/Downloads$ sync

Muistitikulle on nyt kirjoitettu netistä ladattu raspilfs image

DHCP:n käyttöönotto

Halusin kääntää paketteja käyttäen ssh yhteyttä, joten minun täytyi laittaa verkkoyhteys toimimaan. Sitä ennen vaihdoinkuitenkin kirjainkartan käyttömukavuuden kannalta.

[root@tty1] [~] loadkeys fi

Intestines julkaisun verkkoasetukset sijaitsevat /etc/sysconfig/ kansiossa, jossa ”ifconfig.eth0” sisältää verkkoasetukset. Valmiit dhcp:tä käyttävät verkkoasetukset ovat ”ifconfig.dhcp” tiedostossa, joten muutaman tiedoston nimeämällä saadaan käyttöön dhcp.

[root@tty1] [~] cd /etc/sysconfig/
[root@tty1] [/etc/sysconfig/] mv ifconfig.eth0 ifconfig.eth0_old
[root@tty1] [/etc/sysconfig/] mv ifconfig.dhcp ifconfig.eth0

Vielä ssh yhteyden luomiseksi vaadittava ip osoite voidaan selvittää ”ip addr” komennolla.

Kategoriat:Raspberry Pi, xbmc

Loppuraportti: LFS-käyttöjärjestelmän rakentaminen Raspberry Pille

Ryhmän jäsenet

Ilkka Jylhä ja Tom Himanen.

Tavoitteet

Tavoitteena oli rakentaa Raspberry Pille Linux tyhjästä ja testata järjestelmän toimivuus Quake3:lla.

Onnistuminen

Olimme aluksi varovaisen optimistisia asennusprojektin suhteen, joka kuitenkin osoittautui tiettyjen osa-alueiden osalta työläämmäksi ja hitaammaksi kuin kuvittelimme. Samaan hengenvetoon on kuitenkin todettava, että jotkut asiat olivat merkittävästi helpompia kuin kuvittelimme.

Järjestelmän kopioiminen ja pienentäminen dd-työkalulla osoittautui äärimmäisen paljon tuskallisemmaksi operaatioksi kuin osasimme kuvitella. Sen sijaan esimerkiksi käynnistysskriptien asennus oli niin helppoa, että siitä tuli suorastaan huono omatunto.

Lopputulos oli onnistunut. Testasimme järjestelmän toimivuuden ja suorituskyvyn asentamalla Quake3:n. Peli toimi sulavasti ottaen huomioon käytetyn laitteiston.

Loppusanat

LFS:n asentaminen oli oppimiskokemuksena erittäin hyvä ja valaiseva, mutta ainakaan omiin tarpeisiimme LFS:stä ei ole. Siirrymme itse kukin luultavasti käyttämään Raspbiania Raspberry Pi:llä, mutta LFS:n asennus ei ollut ajanhukkaa – päin vastoin.

Palaute

Kurssi oli erittäin nautinnollinen. Itsenäinen työskentely itselleen kiinnostavan projektin parissa sai ajantajun katoamaan, ja kurssin myötä ymmärrämme GNU/Linux -järjestelmiä entistä syvemmin. Aikaa oli vähän, joten keskityimme ensisijaisesti järjestelmän kasaamiseen.

Omalta osaltamme raportointi voi olla hiukan huolittelematonta, mutta pidämme tasoa resursseihin nähden riittävänä, sillä projektissamme olisi laajuudesta johtuen ollut ääretön määrä raportoitavaa. Raportointivelvollisuutta sinänsä emme missään määrin kritisoi, sillä on täysin perusteltua edellyttää todistusaineistoa itsenäisestä työskentelystä. Emme siis muuttaisi kurssissa mitään.

Kategoriat:Raspberry Pi

OMXPlayer loppuraportti

Minulle ilmeni OMXPlayerin asentamisessa monen monia ongelmia ja käytin niiden ratkaisemiseen useita tunteja. Yleensä en edes saanut niitä ongelmia ratkaistua. Osa ongelmista johtui joko huolimattomuudestani tai osaamisen puutteesta, osa taas saattoi johtua siitä, että minulla oli vanhempi Raspberry Pi kuin muilla ryhmän jäsenillä.

Kokeilin OMXPlayerin asentamista http://www.intestinate.com/pilfs/ -sivustolta löytyvälle LFS Baselle, sekä Ilkan ja Tomin tekemälle LFS:n toiselle versiolle. Ensimmäisen kerran yritin asentaa OMXPlayeria alkuperäiselle LFS Baselle, mutta asennukseni päättyi seuraavanlaiseen ruutuun:

LgP8i

Tämä tarkoitti sitä, että tiedostojärjestelmä oli vaurioitunut, todennäköisesti sen takia, koska olin irroittanut virtapiuhan laitteen ollessa päällä.

Tämän jälkeen odotin muutaman päivän, että Tom ja Ilkka saavat oman Basen valmiiksi, jotta voisin asentaa OMXPlayerin suoraan siihen.

Lopulta kun tämä toinen (pienempi) versio oli valmis, kokeilin saada tätä toimimaan. Yritykseni Päättyivät kuitenkin seuraavanlaisiin ruutuihin:

Virhe käynnistäessä

WP_001263

Kokeilin etsiä pitkään tietoa internetistä ja en löytänyt muuta ratkaisua kuin sen joka myös lukee ruudussa eli: ”UNEXPTECTED INCOSISTENCY; RUN fsck MANUALLY”.

Kokeilin siis tehdä fsck:n manuaalisesti seuraavilla komennoilla:

sudo fsck /dev/mmcblk0p

Se korjasi ison läjän erilaisia virheitä tiedostojärjestelmässä, mutta tämän jälkeen ilmestyi alemman kuvan kaltainen ongelma (edellä). Siitä pääsi kyllä eteenpäin sisäänkirjautumisvaiheeseen, mutta tutut käyttäjätunnus ja salasana eivät toimineet (pilfs/root).

Lopulta luovutin näiden ongelmien kanssa painimisen ja aloitin taas OMXPlayeria alkuperäiseen LFS Baseen. Tässä asennuksessa ilmenevät ongelmat olivat seuraavanlaisia:

Ongelmat

ffmpegin kääntämisessä ilmeni seuraavanlainen ongelma [KUVA]

ffmpeMAKEkomento

Kokeilin tämän jälkeen kääntää ffmpegin seuraavilla komennoilla:

./configure --prefix=/usr        \
--disable-debug      \
--enable-shared      \
--disable-static     \
--enable-gpl         \
&& make

Kuitenkin sama virheilmoitus ilmestyi ruudulle:


gcc: internal compiler error: Killed (program cc1)
Please submit a full bug report,
with preprocessed source if appropriate.
See <http://gcc.gnu.org/bugs.html> for instructions.
make: *** [libavcodec/roqvideoenc.o] Error 4

Kokeilin tehdä swapin komennolla

dd if=/dev/zero of=/var/swapfile bs=1M count=512 && mkswap /var/swapfile && swapon -v /var/swapfile

Tämän jälkeen sain FFmpegin käännettyä onnistuneesti.

kokeilin, että oliko FFmpeg asentunut oikein komennolla make check

sain seuraavanlaisen virheilmoituksen

ffmpegMAKECHECK

En tiennyt oliko käännöksessä tapahtunut jonkinnäköinen virhe, koska tietokoneeni oli sammunut siinä välissä kun olin muualla ja en saanut selville, että oliko käännös päässyt loppuun saakka. Päätin jatkaa muiden ohjelmien kääntämistä, koska ffmpegin kääntämisessä menee noin 1.5-2 tuntia. Laitoin myös FFmpegin kääntymään yön yli ja menin nukkummaan.

FFmpeg oli kääntynyt yön aikana onnistuneesti, kuten myös kaikki muutkin ohjelmat.

Ongelmat OMXPlayerin asentamisessa

Asensin OMXplayerin http://www.intestinate.com/pilfs/#omxplayer -sivun ohjeiden mukaan, mutta make komennon jälkeen minulle tuli seuraavanlainen virheilmoitus:

OMXPlayerMAKEerror

Kokeilin ratkaista tätä ongelmaa asentamalla aluksi eri asennuspaketin tuosta OMXplayerista, mutta ilmeni sama viesti. Tämän jälkeen asensin FreeType 2:n uudestaan ja tämän jälkeen vielä kerran OMXPlayerin, mutta viesti oli seuraavanlainen:

OMXplayerMAKEerrorpart2

Tähän ongelmaan, en enään keksinyt mitään ratkaisua, joten OMXplayerin asentaminen jäi enemmän tai vähemmän kesken.

-Santeri Friman

***********************************************************

Tero Karvisen Linux-projektina -kurssi on loppumassa ja on loppuraportin paikka. OMXPlayer:n asennus ryhmän kahden jäsenen tekemän LFS:n päälle onnistui vähän eri tavalla.

Kurssin alkaminen

Kurssi alkoi siis lokakuun 24. päivä ja aiheeksi valikoitui Linux From Scratch on th Raspberry Pi, ja minun ja Santeri Frimanin vastuualueeksi tuli OMXPlayer:n asentaminen Ilkka Jylhän ja Tom Himasen tekemän LFS:n päälle.

Kurssin eteneminen

Kurssi eteni ainakin omalta osaltani aikataulun mukaisesti. Kurssin vaatimat raportoinnit jäivät lukumäärällisesti vähäiseksi, mutta ne käsittelivät kokonaisuuksia, joihin meni jopa viikko tai puolitoista kun muitakin kouluhommia oli. Tämän lisäksi, mitä ei raporteista näe, asensin OMXPlayer:n ensiksi jo valmiin LFS Basen päälle, jonka pystyi lataamaan PiLFS -sivustolta. Sitten kun Ilkka ja Tom saivat valmiiksi ensimmäisen version niin jouduin asentamaan OMXPlayer:n uudestaan. Ja koska matkan varrella tein oman virheen tuhoamalla Ilkan ja Tom määritelmiä asetuksia, niin jouduin vielä kolmannenkin kerran asentamaan OMXPlayer:n.

Loppusanat

Minulla OMXPlayer asentui heti onnistuneesti, paitsi että jouduin ostamaan aktiivisen usb-hubin, jotta langaton näppäimistö suostui toimimaan oikein. Vikakuvauksena oli kirjaimen monistuminen näytöllä, vaikka mitään näppäintä ei painettu. Tämä vaikeutti asentamista ennen hubin ostamista huomattavasti. Syytä miksi asentaminen onnistui toisessa helpommin en osaa sanoa, mutta voisin epäillä syyksi eri Raspberry Pi mallia, koska Santerilla käytössä on Model A 256mb-muistilla varustettuna ja minulla Model B 512mb. Ainakin FFmpeg:n kääntäminen vähemmällä keskusmuistilla ilman swappia ei onnistunut. Ja koska OMXPlayer:n asennus sujui reilusti ajoissa asensin myös Quake 3 ja XBMC:n kokonaisuudessaan omalle Raspberry Pi:lle.

Kurssin palaute (Antti-Ville)

Kurssi oli mukava, koska sai tehdä juuri sitä mitä itse halusi, mutta ehkäpä vieläkin laajempi ja tuntemattomampi aihe voisi olla. Raspberry Pi on kuitenkin niin suosittu jopa nyt että internetistä löytyy kattavasti ohjeita. Ja jos ohjeita ei löytynyt, meillä oli mahdollisuus keskustella PiLFS -sivuston tekijän Mogwai:n kanssa, joka auttoi ystävällisesti askarruttavien kysymysten kanssa. Tästä paras esimerkki oli kun tutustuin jo XBMC:n kääntämiseen vaikka se ei minun vastuualue ollutkaan.  XBMC:n kääntämisen kanssa oli muutamakin ongelma esimerkiksi libssh-paketin kanssa, joka keskeytti sen konfiguroinnin.

Kurssin palaute (Santeri)

Myös minunkin mielestä kurssi oli mukava, koska paino oli omassa tekemisessä ja hommia sai tehdä rauhassa, en kuitenkaan päässyt etenemään yhtä sujuvasti kuin Antti-Ville lukuisien ongelmieni takia.  Osallistuin kurssille tietämättä mitään etukäteen esimerkiksi ohjelmien kääntämisestä, mutta huomasin hyvin nopeasti, että se on pitkälti kolmen komennon hakkaamista uudelleen ja uudeelleen. Halusin kuitenkin suorittaa tämän kurssin nyt koska en voi olla varma, että järjestetäänkö kurssia enään 3 vuoden kuluttua (esimerkiksi 21. joulukuuta maailmanlopun takia [vitsi], kun minulla olisi enemmän osaamista ja voisin tehdä oikeasti jonkin haastavan projektin. En kuitenkaan tarkoita, etteikö tämä olisi ollut riittävän haastava, koska en lopulta saanut edes OMXplayeria asentumaan. Vaikka ohjelmien kääntäminen ei hirveästi osaamista tarvinnutkaan, voin rehellisesti sano, että  kurssi opetti minulle todella paljon asioita esimerkiksi Linux From Scratchistä, ArchLinuxista sekä ohjelmien kääntämisestä ja myös siitä, miten perinteinen videoplayeri toimii.

Lähteet

Tero Karvinen – Linux-projekti -kurssi

PiLFS – Linux From Scratch on the Raspberry Pi

-Jokela Antti-Ville

Tätä dokumenttia saa kopioida ja muokata GNU General Public License (versio 2 tai uudempi) mukaisesti. http://www.gnu.org/licenses/gpl.html

Kategoriat:Uncategorized

Emojärjestelmän poistaminen oman järjestelmän rinnalta + jakeluversion luominen

Kun Raspberry Pille oli saatu asennettua uusi järjestelmä, se käynnistyi moitteettomasti.

Seuraava vaihe oli poistaa emojärjestelmä, josta käsin uusi järjestelmä oli asennettu. /etc/fstabista poistettiin emojärjestelmän juuriosio (/dev/mmcblk0p2) ja emojärjestelmän swappiosio (/dev/mmcblk0p4).

Lisäksi pienensimme osion /dev/mmcblk0p3, mitä ei ilmeisesti ole (dokumentoidusti) tehty aiemmin LFS:n asennuksessa Raspille. Poistimme alkuperäisen osion, loimme uuden pienemmän ja kirjoitimme muutokset osiotauluun.

Tämän jälkeen järjestelmä ei kuitenkaan bootannut, ja järjestelmä itki seuraavaa:

* Mounting root file system in read-only mode… mount: / is busy [FAIL]
*****
Cannot check root filesystem because it could not be mounted in read-only mode.
After you press Enter, t system will be halted and powered off.
******
Press Enter to continue…[60.063950] mmc0: card 1234 removed
mmcblk0: error -110 sending status command, retrying
mmcblk0: error -110 sending status command, retrying
mmcblk0: error -110 sending status command, retrying
end_request: I/0 error, dev mmcblk0, sector 26501112
EXT4-fs error (device mmcblk0p3): ext4_find_entry:935: inode #765537: comm udevd: reading directory lkblock 0
EXT4-fs error (device mmcblk0p3): ext4_find_entry:935: inode #765537: comm udevd: reading directory lkblock 0

PiLFS:n rakentanut, IRC-tunnusta “mogwai” käyttävä henkilö arveli, että ongelmana voisi olla osioiden relatiivinen nimeäminen, jolloin juuriosio muuttuisi /dev/mmcblk0p3 -> /dev/mmcblk0p2 sen jälkeen, kun olemme poistaneet emojärjestelmän juuriosion (/dev/mmcblk0p). Tämä koituu kohtaloksi, kun /etc/fstabissa ja bootloaderissa järjestelmän juuriosioksi on määritelty /dev/mmcblk0p3.

Lähdimme testaamaan hypoteesia poistamalla osioita yksi kerrallaan; näin voimme abduktiivisesti todeta ongelman aiheuttajan. Aloitimme poistamalla uuden järjestelmän swapin (/dev/mmcblk0p4). Käynnistimme uudelleen, ja järjestelmä käynnistyi ihan hyvin, mutta valitti, ettei saa mountattua osiota /dev/mmcblk0p4. Näin ollen päätimme päivittää /etc/fstabin ajan tasalle kommentoimalla swappiosion rivi pois.

#/dev/mmcblk0p4 swap swap pri=1 0 0

Lisäsimme samalla /boot-osion /etc/fstabiin.

/dev/mmcblk0p1 /boot vfat defaults 0 0

Tämän jälkeen käynnistimme järjestelmän uudelleen. Käynnistyminen ei tuottanut yhtään virheilmoitusta. Seuraavaksi päätimme poistaa osion 2, arpoa oikeat asetukset bootloaderiin ja kokeilla, käynnistyykö järjestelmä. Viimeksi bootloaderissa ja fstabissa juurijärjestelmäksi oli määritelty osio kolme, joten vaihdoimme molemmissa tiedostoissa juuriosioksi osion 2.

Tämä oli huono lottorivi, sillä bootin tuloksena oli seuraavanlainen virheilmoitus.

PANIC: VFS: Unable to mount root fs on unknown-block(179,2)
Entering kbd (current=0xce82ac80, pid 1) due to Keyboard Entry

Määritimme cmdline.txt:ssä juuriosioksi osion 3:

dwc_otg.lpm_enable=0 console=ttyAMA0,115200 kgdboc=ttyAMA0,115200 console=tty1 root=/dev/mmcblk0p3 rootfstype=ext3 elevator=deadline rootwait

Myös /etc/fstab-tiedostossa muutimme juuriosioksi osion 3. Käytännössä palasimme yrittämään samaa ratkaisua, joka oli jo kerran pissinyt.

# Begin /etc/fstab

# file system  mount-point  type     options             dump  fsck
#                                                              order

/dev/mmcblk0p3 /            ext3     defaults            1     1
/dev/mmcblk0p1 /boot    vfat     defaults 0     0
#/dev/mmcblk0p4 swap         swap     pri=1               0     0
proc           /proc        proc     nosuid,noexec,nodev 0     0
sysfs          /sys         sysfs    nosuid,noexec,nodev 0     0
devpts         /dev/pts     devpts   gid=5,mode=620      0     0
tmpfs          /run         tmpfs    defaults            0     0
devtmpfs       /dev         devtmpfs mode=0755,nosuid    0     0

# End /etc/fstab

Jostain ihmeen syystä järjestelmä käynnistyi ongelmitta ja epäselväksi jäi, mikä meni ensimmäisellä kerralla vikaan yrittäessämme käynnistää järjestelmää käyttäen juuriosiona /dev/mmcblk0p3-osiota. Joka tapauksessa tästä voitiin päätellä, että käynnistyslatain ja fstab eivät kumpikaan numeroi osioita dynaamisesti. Ongelma kuitenkin liittyi todennäköisesti osion pienentämiseen.

Alun perin mukailimme ohjetta osion suurentamisesta, joka toimi niin että poistetaan osio, luodaan osio uudestaan koko levyn kokoisena, kirjoitetaan muutokset luodulle osiolle, bootataan ja bootin jälkeen komennetaan resize2fs.

Pienennettäessä osiota poistimme alkup. osion, loimme siihen kohdalle uuden pienemmän, kirjoitimme muutokset osiotauluun ja boottasimme

Osion pienentäminen kuitenkin hajotti juuriosion jonka johdosta emme kykeneet enää käynnistämään järjestelmää.

Osion pienentäminen tulee tehdä käänteisessä järjestyksessä, ensiksi resize2fs.
esim resize2fs -M
“”resize2fs -M     Shrink the filesystem to the minimum size.”

sen jälkeen muokataan osiota vastaamaan uutta kokoa. Ongelmana tässä on se että ainoastaan unmountatun osion kokoa voidaan pienentää. Niinpä osion pienentäminen on tehtävä järjestelmästä käsin, joka ladataan toiselta osiolta.

Tämän jälkeen teimme swappitiedoston, mutta minimoidaksemme muuttujia emme aktivoineet sitä ainakaan vielä.

dd if=/dev/zero of=/dev/swapfile bs=1M count=512

Päätimme kokeilla tässä vaiheessa osion pienentämistä uudelleen. Koska olimme jo poistaneet emojärjestelmän, jouduimme suorittamaan pienennysoperaation miniläppäriä käyttäen, johon liitimme Raspin ensisijaisena mediana käytetyn muistikortin.

Ensiksi poistimme muistikortilla olevan “tyhjän” tilan osioiden mmcblk0p1 ja mmcblk0p3 välistä, joka syntyi, kun emojärjestelmän sisältänyt mmcblk0p2 poistettiin. Tyhjä tila poistettiin siirtämällä mmcblk0p3 osio heti /boot osion jälkeen.
Operaation jälkeen tarkistimme, että tiedostojärjestelmä on kunnossa, ennen kuin aloimme käpälöidä tiedostojärjestelmää.

sudo fsck -n /dev/mmcblk0p3

Tämän jälkeen muunsimme tiedostojärjestelmän ext3-muodosta ext2-muotoon.

sudo tune2fs -O ^has_journal /dev/mmcblk0p3

Tarkistimme, että tämänkin jälkeen kaikki on tiedostojärjestelmässä OK.

sudo e2fsck -f /dev/mmcblk0p3

Ajoimme resize2fs-komennon pienentääksemme osion koon 3500 mibitavuun.

sudo resize2fs /dev/mmcblk0p3 3500M
resize2fs 1.42 (29-Nov-2011)
Resizing the filesystem on /dev/mmcblk0p3 to 896000 (4k) blocks.
The filesystem on /dev/mmcblk0p3 is now 896000 blocks long.

sudo fdisk /dev/mmcblk0
d
3
n
p
3
98304
+3700M
w
sudo fsck -n /dev/mmcblk0p3
sudo tune2fs -j /dev/mmcblk0p3
sudo sync

Kaikkien järkytykseksi totesimme homman toimivan.

OpenSSH:n asennus LFS:ään

Otimme ohjenuoraksemme CBLFS:n ohjeet OpenSSH:n asennukseen (http://cblfs.cross-lfs.org/index.php/OpenSSH). OpenSSH on riippuvainen paketista OpenSSL, joten aloitimme asentamalla sen.

Latasimme OpenSSL:n lähdekoodit (http://www.openssl.org/source/openssl-1.0.1c.tar.gz), purimme ne, käänsimme ja asensimme.

./config –openssldir=/etc/ssl –prefix=/usr shared && make MANDIR=/usr/share/man && make MANDIR=/usr/share/man install && ln -sv ../../etc/ssl /usr/share &&
cp -v -r certs /etc/ssl

OpenSSL asentui ongelmitta ja aloitimme OpenSSH:n asennuksen.

./configure –prefix=/usr –sysconfdir=/etc/ssh –libexecdir=/usr/sbin –with-md5-passwords –with-privsep-path=/var/lib/sshd –with-default-path=”/bin:/usr/bin”  –with-superuser-path=”/sbin:/bin:/usr/sbin:/usr/bin” && make

OpenSSH kääntyi ongelmitta, mutta asennuksen jälkeen SSH-demoni (= palvelu) piti saada käynnistymään järjestelmän käynnistyksen yhteydessä. Tähän tarvittiin Beyond Linux From Scratchin käynnistysskriptejä (http://www.linuxfromscratch.org/blfs/downloads/6.3/blfs-bootscripts-20080816.tar.bz2), joiden asennus- ja käyttöohjeet löytyvät täältä: http://www.linuxfromscratch.org/blfs/view/6.3/introduction/bootscripts.html. SSH-demonin käynnistysskriptien lisääminen kaikille ajotasoille oli ubuntumaisen helppo tehtävä ja se tapahtui seuraavasti.

tar blfs-bootscripts-20080816.tar.bz2
cd blfs-bootscripts-20080816
make install-sshd

Tämän jälkeen käynnistimme Raspberry Pin uudelleen ja sshd nousi ylös ongelmitta. Testasimme myös SSH-yhteyden ottamista Raspberry Pihin ja saimme yhteyden muodostettua.

Wgetin asennus

Wgetin asennus oli melko suoraviivainen toimenpide.

./configure –prefix=/usr –sysconfdir=/etc && make && make install

Kaikki ei kuitenkaan mennyt oletetusti, ja ./configure skripti itki seuraavaa:

configure: error: — with-ssl was given, but GNUTLS is not available

Configure-skripti siis olettaa löytävänsä järjestelmästä GNUTLS:n, mutta sitä ei ole. Sen sijaan OpenSSH:n vuoksi järjestelmässä on joka tapauksessa OpenSSL, joten neuvoimme wgetin configure-skriptiä hyödyntämään OpenSSL:ää salattujen yhteyksien käsittelyyn. Komento näyttä tämän jälkeen seuraavanlaiselta.

./configure –prefix=/usr –sysconfdir=/etc –with-ssl=openssl && make && make install

Fonttiongelman ratkaisu

Bashin promptin määrittävää $PS1-muuttujaa muotoillessamme huomasimme, että erikoismerkit eivät tulostu oikein. Aloimme testata ongelmaa ja jätimme Bashin promptin viilaamisen tuonnemmaksi.

Huomasimme, että ongelma muistutti sitä, kun ottaa SSH-yhteyden ISO-8859-koodausta käyttävältä koneelta UTF-8 -koodausta käyttävään koneeseen tai toisin päin. Näin ollen osasimme arvella ongelman johtuvan koodauksesta. Emme kuitenkaan sulkeneet näppäimistökarttaongelmiakaan pois.

Kokeilimme asettaa tiedostossa /etc/sysconfig/console asettaa $KEYMAP-muuttujaan arvot fi-latin9 ja fi-latin1. Kokeilimme myös asettaa muuttujalle $FONT arvoiksi lat1-16 ja lat0-16. Tämäkään ei tuntunut vaikuttavan asiaan. Jokaisen muutoksen jälkeen sourcetimme (source /etc/sysconfig/console) konffit ja käynnistimme koneen uudelleen.

Kun ratkaisua ei tuntunut löytyvän, kysyimme mogwailta neuvoa IRC:ssä. Koska hän on ruotsalainen, hän oli törmännyt samoihin ongelmiin kuin mekin, joten hänellä oli antaa meille valmis ja toimiva konffi, joka näyttää seuraavanlaiselta:

/etc/sysconfig/console:

UNICODE=”1″
KEYMAP=”fi-latin1″
KEYMAP_CORRECTIONS=”euro2″
LEGACY_CHARSET=”iso-8859-1″
FONT=”LatArCyrHeb-16 -m 8859-1″

Bashin promptin viilaus

Saatuamme erikoismerkit ja ääkköset pelaamaan terminaaliemulaattorissamme otimme Bashin promptin uudelleen työn alle. Prompti on terminaaliemulaattorissa se merkkijono, jonka perään komennot kirjoitetaan, ja joka sisältää usein tiedon sisään kirjautuneesta käyttäjästä, senhetkisestä sijainnista järjestelmän hakemistopuussa sekä sen järjestelmän nimen, johon on kirjauduttu.

Halusimme promptin, joka (1) erottuu muusta tulosteesta sekä (2) kertoo kirjautuneen käyttäjän, kirjautumisen kohteen sekä nykyisen sijainnin. Päätimme erottaa promptin muusta tulosteesta värin avulla. Näin ollen rootin ~/.bashrc näytti loppujen lopuksi seuraavanlaiselta:

#!/bin/bash
export PS1=”[\e[0;31m\u\e[m@\e[0;32m\h\e[m:\w]\e[0;31m\$\e[m ”

Tämän jälkeen meidän kuitenkin tarvitsi tehdä ~/.bash_profile, joka kutsuu ~/.bashrc:tä.

if [ -f ~/.bashrc ]; then source ~/.bashrc ; fi

[root@pilfs:~]#

LFS-käyttäjän luominen

Loimme perus käyttöä varten Raspberry Pille uuden käyttäjän.

useradd -m -s /bin/bash lfs
Kopioimme lfs-käyttäjälle ~/.bashrc:n ja ~/.bash_profilen root-käyttäjältä roottina.

cp ~/.bashrc ~lfs/.bashrc && cp ~/.bash_profile ~lfs/.bash_profile && chown lfs:lfs ~lfs/.bash*

Varmuuskopion ottaminen

Koska järjestelmämme oli runnottu Raspberry Pin alussa olevaan tilaan siten, että se mahtuu alle neljään gigaan, halusimme siitä vain neljään gigaan mahtuvan varmuuskopion. Dd:llä varmuuskopioitaessa dd kopioi ihan onnessaan levyä bitti bitiltä riippumatta mm. siitä, onko levyn viimeinen osio loppunut jo ajat sitten.

Tästä syystä meidän tarvitsi antaa dd:lle lupa lopettaa kopiointi ensimmäisen neljän gigan jälkeen. Näin voitiin tehdä count-attribuutilla, joka määrittää, miten monta blokkia kopioituaan dd saa lopettaa projektinsa. Varmuuskopiota ottaessamme määritimme blokin yhden megatavun kokoiseksi, jottemme sekoaisi laskuissamme.

dd if=/dev/mmcblk0 of=hiawatha_0.1.img bs=1M count=3700

Kun varmuuskopio siirrettiin neljän gigan muistikortille, se toimi yllätykseksemme mainiosti ja järjestelmä buuttasi. Törmäsimme ongelmiin vasta, kun meidän tarvitsi seuraavaksi mountata kortti lähimpään tietokoneeseen.

Tämä ei kuitenkaan onnistunut, koska muistikortin kolmannen osion tiedostojärjestelmä koki olevansa rikki. Ongelma kuitenkin korjautui helposti fsck:lla.

sudo fsck /dev/mmcblk0p3

Dhcpcd:n asennus

Dhcpcd:n asennus oli helppo toimenpide. Se onnistui ongelmitta noudattaen BLFS:n ohjeita (http://www.linuxfromscratch.org/blfs/view/svn/basicnet/dhcpcd.html). Järjestelmä buuttasi seuraavanlaisella konffilla:

[root@pilfs:~]$ cat /etc/sysconfig/ifconfig.eth0
##########################
# Config with dhcpcd
##########################

ONBOOT=”yes”
IFACE=”eth0″
SERVICE=”dhcpcd”
DHCP_START=””
DHCP_STOP=”-k”

###########################
# Old config with static IP
###########################

#ONBOOT=yes
#IFACE=eth0
#SERVICE=ipv4-static
#IP=10.42.0.2
#GATEWAY=10.42.0.1
#PREFIX=24
#BROADCAST=10.42.0.255

DHCP:n toimivuus testattiin ottamalla SSH-yhteys Raspberry Pihin ja tulostamalla yllä oleva konffi terminaaliin ja kopipeistaamalla se raporttiin.

Irssin asennus

Irssi on riippuvainen paketista Glib, joka puolestaanon riippuvainen paketista pkg-config. Niinpä aloitin irssin asennuksen kääntämällä paketin pkg-config.

wget http://pkgconfig.freedesktop.org/releases/pkg-config-0.27.1.tar.gz &&
tar xzvf pkg-config-0.27.1.tar.gz && cd pkg-config-0.27.1 &&
./configure –prefix=/usr \
–docdir=/usr/share/doc/pkg-config-0.27.1 \
–with-internal-glib &&
make && make install

Tämän jälkeen asensin Glibin, josta valitsin version 2.

wget http://ftp.gnome.org/pub/GNOME/sources/glib/2.27/glib-2.27.4.tar.bz2 && tar xjvf glib-2.27.4.tar.bz2 && cd glib-2.27.4 && ./configure –prefix=/usr && make && make install

Loppujen lopuksi pääsin asentamaan itse irssin.

wget http://www.irssi.org/files/irssi-0.8.10a.tar.bz2 && wget http://svn.cross-lfs.org/svn/repos/patches/irssi/irssi-0.8.10a-gslice-1.patch && tar xjvf irssi-0.8.10a.tar.bz2 && cd irssi-0.8.10a && patch -Np1 -i ../irssi-0.8.10a-gslice-1.patch &&
./configure –prefix=/usr –sysconfdir=/etc && make && make install

Irssiä kuuluu käyttää screenissä, joten sekin piti vielä kääntää.

wget http://ftp.gnu.org/gnu/screen/screen-4.0.3.tar.gz && tar xzvf screen-4.0.3.tar.gz && cd screen-4.0.3 && ./configure –prefix=/usr –with-socket-dir=/var/run/screen \
–with-sys-screenrc=/etc/screenrc && sed -i ”s%/usr/local/etc/screenrc%/etc/screenrc%” {etc,doc}/* && make && make install

Nanon kääntäminen

./configure –prefix=/usr –enable-all

Screen (http://www.linuxfromscratch.org/blfs/view/svn/general/screen.html) ja links (http://www.linuxfromscratch.org/blfs/view/svn/basicnet/links.html) asennetiin BLFS-ohjeiden mukaan.

Quake3:n asennus

Quake3 asennettiin pilfs-ohjeiden (http://www.intestinate.com/pilfs/#quake3) mukaisesti ongelmitta. Ainoastaan Alsan kuolleet linkit aiheuttivat päänsärkyä. Asia korjautui asentamalla uudet, SVN-käynnistysskriptit SVN-BLFS -ohjeiden mukaisesti.

Kategoriat:Raspberry Pi

Asennuksen aloittaminen

Onnistuimme rakentamaan oman Linux-kernelin päälle rakennetun käyttöjärjestelmämme Raspberry Pin päälle, ja tässä postauksessa kerromme, mitä kannattaa tehdä ja mitä ei.

Linux-ytimen päälle Linux from Scratch -kirjan ohjeita mukaillen itse rakennettua käyttöjärjestelmää kutsutaan yleensä ”Linux from Scratchiksi” (suom. ”Linux tyhjästä”), ja näin mekin teemme. Lopputuotteemme erisnimi on kuitenkin Hiawatha. ”Linux from Scratch” -käsitteeseen viittaamme usein vakiintuneen käytännön mukaisesti lyhenteellä LFS.

Käytimme ohjenuoranamme PiLFS-ohjekirjaa, joka käytännössä neuvoo noudattamaan LFS-ohjekirjaa kertoen muun muassa, missä kohtaa alkuperäisestä ohjeistuksesta kannattaa poiketa, tai mitä erityistä kannattaa huomioida.

Aluksi on syytä todeta, että Raspberry Pi (myöh. RasPi) eroaa normaalista tietokoneesta esimerkiksi BIOS:in osalta, jota RasPissa ei ole. RasPissa on asetustiedostoja, joita muokkaamalla muutetaan asetuksia, joita normaalisti muutettaisiin BIOS:in asetuksissa.

Jokaisen RasPille Linux from Scratchia asentavan on syytä huomioida se tosiasia, että 25 dollarin arvoisessa luottokortin kokoisessa yhden piirilevyn tietokoneessa on todennäköisesti hitaampi prosessori kuin kännykässäsi. Asentaminen on vieläpä aikamoista prosessorin huudatusta, sillä ohjelmat asennetaan kääntämällä ne lähdekoodeista, mikä tehdään pääasiallisesti prosessorilla.

Tästä syystä yritimme aluksi emuloida RasPia qemulla PiLFS-ohjekirjan mukaisesti. Aikeenamme oli rakentaa ja kääntää ohjelmistot emulaattorilla, tehdä aikaansaannoksestamme image ja siirtää se RasPille. Emulaattori ei kuitenkaan muutaman tunnin taistelun seurauksena alkanut toimia, joten lopetimme ajan haaskauksen ja aloimme rakentaa järjestelmää suoraan RasPilla.

Seurasimme PiLFS-sivuston (IRC-tunnuksen mogwai ylläpitämä) ja LFS-kirjan ohjeita. Koska em. kirjojen kirjoittaminen uudestaan ei ole mielekästä, eikä siihen ole resursseja, keskitymme lähinnä kirjoja seuratessamme kohtaamiimme ongelmiin ja yllätyksiin.

LFS:n RasPille asentavan on syytä tietää, että ohjelmien kääntämiseen käytettävät, mogwain tekemät skriptit rouskuttavat 60–70 tuntia putkeen.

Kategoriat:Raspberry Pi

Nyt se toimii

Hiawatha 0.1 käynnisti itsensä onnistuneesti 20.11.
Raspberry Pi:lle rakennettu LFS-järjestelmä saatiin käynnistymään omin voimin. Lähipäivinä aiomme kertoa muistiinpanojemme pohjalta, millaisia haasteita kohtasimme. Stay tuned!

Kategoriat:Raspberry Pi