OSCam/fr/Self-made

Aus Streamboard Wiki
Wechseln zu: Navigation, Suche

LanguageDE S.png OSCam Übersicht LanguageEN S.png OSCam Home LanguageFR S.png OSCam Accueil LanguageIT S.png OSCam Home

OSCam selbstgemacht

Intro

Nachfolgend wird der Weg vom Auschecken bis hin zur kompilierten OSCam im Groben beschrieben. Alle aufgeführten Linux-Beispiele und Code-Fragmente wurden auf einem Linux-PC mit Debian 6 getestet.

Umgebung

Ein Linux-PC wird vorausgesetzt. Selbstverständlich muss es kein physikalischer PC sein, eine virtuelle Maschine (VM) macht es genauso gut Smiley wink.png. Der kostenlose VMware Player ist z.B. sehr empfehlenswert.

Lade Dir ein Linux Deiner Wahl herunter, entweder als ISO zum Installieren oder als fertige VM. Wie oben bereits erwähnt, basieren die Linux-Inhalte in diesem Artikel auf eine Debian-Distribution. Bei Ubuntu sollte es allerdings fast genauso funktionieren.

Benötigte Pakete

Folgende Pakete werden zum Erstellen von OSCam benötigt:

apt-get install cvs subversion
apt-get install autoconf libccid automake libtool gettext make cmake
apt-get install patch ncurses-bin gcc g++ flex bison pkg-config libpng3
# zlib (development headers) - zlib1g-dev
apt-get install tar bzip2 gzip zlib1g-dev

# for sa and aes:
apt-get install libssl-dev libssl0.9.8

# for pcsc:
apt-get install libpcsclite1 libpcsclite-dev

# for smartreader branch:
apt-get install libusb-1.0-0 libusb-1.0-0-dev

Verzeichnisstruktur

root@srv01:/var/shares/linux# tree oscam -L 2 -d
oscam
+-- bin                # hier landen die fertigen OSCam`s
¦   +-- archive        # hierein archivieren wir "alte" OSCam-Binaries
+-- make               # in diesem Verzeichnis "machen" wir OSCam
+-- svn-sb             # hier wird der OSCam-Sourcecode abgelegt
¦   +-- branches       # NICHT manuell erstellen! Wird beim ersten Auschecken erstellt
¦   +-- tags           # NICHT manuell erstellen! Wird beim ersten Auschecken erstellt
¦   +-- trunk          # NICHT manuell erstellen! Wird beim ersten Auschecken erstellt
+-- toolchains         # optional, dient zum Erstellen der OSCam für andere Plattformen - Cross-Compiling
    +-- mipsel         # optional - mipsel-Toolchain, z.B. für Dream-Boxen
    +-- ppc            # optional - ppc-Toolchain, z.B. für die DBox2
    +-- tdt            # optional - sh4-Toolchain, z.B. für Kathrein-Boxen

Sourcecode "auschecken" (SVN)

Erstes Auschecken

Wir holen zum ersten Mal die OSCam-Sourcen. Dies machen wir nur einmal:

oscamRoot='/var/shares/linux/oscam' # anpassen!
svnDir='svn-sb' # anpassen!
cd $oscamRoot
svn co http://streamboard.de.vu/svn/oscam $svnDir

Update

Nachdem wir die OSCam-Sourcen einmal komplett geholt haben, müssen wir unser lokales Repository nur noch aktualisieren, wenn sich am Quellcode etwas geändert hat:

oscamRoot='/var/shares/linux/oscam'
svnDir='svn-sb'
svnBranch='trunk'
cd $oscamRoot
svn up $svnDir/$svnBranch

Kompilieren

Es ist absolut nichts magisches und in ein paar Sekunden erledigt Smiley wink.png:

# Variablen anpassen! **************************************
oscamRoot='/var/shares/linux/oscam'
ver='1.00'
svnDir='svn-sb'
svnBranch='trunk'
svnBuildDir=''
# **********************************************************
cd $oscamRoot
# aktuelle Sourcen auschecken ******************************
svn up $svnDir/$svnBranch
# "alte" OSCam`s archivieren (optional) ********************
mv $oscamRoot/bin/oscam* $oscamRoot/bin/archive/
#
cd $oscamRoot/make
# i686 mit Webinterface ************************************
rm -fr $oscamRoot/make/*
cmake -DLIBUSBDIR=/usr -DWEBIF=1 -DCS_CONFDIR=/var/keys ../$svnDir/$svnBranch/$svnBuildDir
# wenn mehrere CPU-Kerne zur Verfügung stehen...
make -j4 # wir nutzen 4 CPU-Kerne zum Kompilieren
# ...ansonsten nur "make" ausführen
# erstellte Binaries verschieben...
if [ -x "oscam" ]; then mv -f oscam ../bin/oscam-i686-$ver-$(svnversion -n ../$svnDir/$svnBranch/$svnBuildDir)-wi; fi;
if [ -x "utils/list_smargo" ]; then mv -f utils/list_smargo ../bin/; fi;

Für andere Plattformen kompilieren

Cross-Compiling ist das magische Wort. Um OSCam für andere Plattformen zu kompilieren sind so genannte Toolchains notwendig. Einige Toolchains und weitere Informationen zum "Cross-Compiling" findest Du »hier«.

Beispiel DM800

Toolchain-Datei:

# toolchain-mipsel.cmake
set (OSCAM_SYSTEM_NAME Tuxbox)
set (CMAKE_SYSTEM_NAME Linux)
set (CMAKE_C_COMPILER /var/shares/linux/oscam/toolchains/mipsel/bin/mipsel-unknown-linux-gnu-gcc)
set (CMAKE_SYSTEM_PROCESSOR mips)

Auschecken und kompilieren:

# Variablen anpassen! **************************************
oscamRoot='/var/shares/linux/oscam'
ver='1.00'
svnDir='svn-sb'
svnBranch='trunk'
svnBuildDir=''
# **********************************************************
cd $oscamRoot
# aktuelle Sourcen auschecken ******************************
svn up $svnDir/$svnBranch
# "alte" OSCam`s archivieren (optional) ********************
mv $oscamRoot/bin/oscam* $oscamRoot/bin/archive/
#
cd $oscamRoot/make
# mipsel ***************************************************
rm -fr $oscamRoot/make/*
cmake -DLIBUSBDIR=/var/shares/linux/oscam/lib-mipsel/usr -DWEBIF=1 -DCS_CONFDIR=/var/keys -DCMAKE_TOOLCHAIN_FILE=../toolchains/toolchain-mipsel.cmake ../$svnDir/$svnBranch/$svnBuildDir
make -j4
if [ -x "oscam" ]; then mv oscam ../bin/oscam-mipsel-$ver-$(svnversion -n ../$svnDir/$svnBranch/$svnBuildDir)-wi; fi;


Diese Seite in anderen Sprachen - This page in other languages - Cette page dans d'autres langues - Queste pagine in altre Lingue

LanguageDE S.png Deutsch LanguageEN S.png English LanguageFR S.png Français LanguageIT S.png Italiano