Sarjaterminaali

Linux.fista
Versio hetkellä 6. lokakuuta 2007 kello 16.33 – tehnyt Pb (keskustelu | muokkaukset) (→‎Mikä on sarjaterminaali?: wikilinkki)
Siirry navigaatioon Siirry hakuun

Sarjaterminaali on melko unohdettu laite PC-maailmassa, mutta siitä voi olla hyötyä erikoisemmissa tilanteissa, kuten selvittäessä ongelmia X:n tai ytimen kanssa.

Johdanto

Mikä on sarjaterminaali?

Sarjaterminaali on fyysinen laite, jossa on näyttö ja näppäimistö, ja se kytkeytyy tietokoneeseen sarjaliitännällä. Nykyään tutumpi käsite lienee terminaaliemulaattori X Window Systemin alla, kuten esimerkiksi xterm. Sarjaterminaali toimii kuten terminaaliemulaattori: se näyttää tekstiä ja sen kautta voi syöttää tekstiä. Perinteiset sarjaterminaalit eli päätteet eivät ole tietokoneita siinä mielessä, että niissä ei ajeta varsinaisia ohjelmia. Ne toimivat vain käyttöliittymänä oikeaan (keskus)tietokoneeseen. Tietokoneella voidaan emuloida sarjaterminaalia sopivalla ohjelmistolla, esimerkiksi DOSissa pyörivällä Telix:llä tai Windowsin HyperTerminalilla.

Mitä hyötyä sarjaterminaalista voisi nykyään olla?

Jos koneen konsoli lakkaa jostain syystä vastaamasta, esimerkiksi X (graafinen ympäristö) tai koko näytöllä pyörinyt peli kaatuu, näppäimistö ei enää reagoi tai näyttö on täynnä sotkua, sarjaterminaali antaa mahdollisuuden mennä toista kautta koneelle korjaamaan tilanne. Tämän voisi tehdä myös verkon kautta mikäli käytössä on toinen kone ja verkon kautta kirjautuminen on mahdollista (kts. ssh).

Tilanne on toinen, jos itse ydin kaatuu. Kaatuessaan ydin jotain tapahtuneesta ja nämä tiedot olisi tietysti hyvä saada muistiin, mutta koska ydin on jo nurin, ei niiden tallentaminen yleensä onnistu muuten kuin kynällä paperille. Toisaalta lähes aina myös X on ollut käynnissä, joten ilmoitukset eivät edes näy. Kernel voi tulostaa ilmoituksensa myös sarjaporttiin, jolloin ne näkyvät sarjaterminaalissa. Jos sarjaterminaali onkin tavallinen PC, voi terminaaliemulaattorista tallentaa näkymän suoraan tiedostoon.

Paitsi, että ydin voi tulostaa esimerkiksi käynnistymistekstinsä sarjaterminaaliin, myös käynnistyslataimet Lilo ja Grub osaavat tarvittaessa käyttää sitä. Monet palvelimiksi tarkoitetut ei-PC koneet tukevat sarjaterminaalia jo käynnistyksen alusta (BIOSista) lähtien.

Sarjaterminaalin asentaminen

Ensimmäinen yhteys

Oletetaan, että sarjaterminaalin virkaa toimittaa vanha PC-kone. Rautavaatimuksina on sarjaportit molemmissa tietokoneissa ja nollamodeemikaapeli. Nollamodeemikaapelin rakennusohjeet löytyvät mm. täältä. Täysin kytketty kaapeli ei ole välttämätön, GND-, TxD- ja RxD-kytkennöillä eli kolmella johtimella pärjää.

Sarjaterminaalina toimivaan tietokoneeseen tarvitaan käyttöjärjestelmä ja terminaaliemulaattori, joka osaa jutella suoraan sarjaporttiin, esimerkiksi DOS ja Telix. Linux-koneessa, jota kutsutaan lopputekstin ajan palvelimeksi, on tarvittavat ohjelmistot luultavasti jo asennettu.

Kaapeli kiinni ja koneet käyntiin. Käytetään vaikkapa agettyä hoitamaan kirjautumiskehote sarjaterminaalille. Jotta saadaan hieno kehote, luodaan palvelimelle tiedosto /etc/issue.serial ja kirjoitetaan siihen:

This is \n (\s \m \r) \t
Connected on \l at \b bps
\U

Ja palvelimella annetaan komento (ei tarvita pääkäyttäjän oikeuksia)

/sbin/agetty -L -f /etc/issue.serial 9600 tts/0 ansi 

Komento jää odottamaan vierailijaa sarjaporttiin. Parametrien selitykset:

  • -L Ei käytetä kantosignaalia, kuten modeemien kanssa, vaan yhteys on aina auki
  • -f /etc/issue.serial Käytetään edellä kirjoitettua kehotetta.
  • 9600 Yhteyden baudimäärä (signaalin muutosten määrä sekunnissa). Mahdollisia lukemia ovat mm. 115200, 57600, 38400, 19200, 9600 ja 4800.
  • tts/0 Sarjaportin laitetiedoston nimi ilman /dev/-alkua. Esimerkki voisi olla myös ttyS0.
  • ansi Sarjaporttiin kytketyn terminaalin tyyppi. ansi tarkoittaa, että sarjaterminaali käyttää ANSI-komentoja.

Seuraavaksi sarjaterminaalikoneessa käynnistetään Telix. Sen asetuksiin asetetaan sama yhteyden nopeus kuin edellä, 8 databittiä, parity none ja stop-bittejä 1. Vuonohjaus pitää olla XON/XOFF (tästä lisää lopuksi) ja terminaaliemulaation tyypiksi pitää laittaa samainen ansi. Enterin painalluksella ruudulle pitäisi valua sisäänkirjautumiskehote. Sisäänkirjautuminen ei tosin onnistu, ellei agettyä ajeta pääkäyttäjän oikeuksin.

Jos terminaalin ruudulle tulee sotkua, pitää yhteysasetukset tarkistaa. Todennäköisesti yhteyden nopeus ei täsmää.

Kirjautumiskehote pysyväksi

Edellä kuvatulla tavalla sarjaterminaalin kautta voi kirjautua kerran, sen jälkeen agetty pitää käynnistää uudelleen. Sama koskee myös virtuaalikonsoliin kirjautumista, joten hoidetaan ongelma samalla tavalla kuin se on ratkaistu virtuaalikonsolien kanssa. Muokataan tiedostoa /etc/inittab, joka on yksi järjestelmän kriittisimpiä asetustiedostoja. Sieltä löytyy liuta rivejä tyyliin:

c1:12345:respawn:/sbin/agetty 38400 tty1 linux

Ne luovat kirjautumiskehotteet virtuaalikonsoleihin. Lisätään loppuun rivi:

s1:2345:respawn:/sbin/agetty -L -f /etc/issue.serial 9600 tts/0 ansi

Agettyn parametrit ovat samat kuin edellisessä kappaleessa sävelletyt. Tallennetaan ja käsketään initin lukea inittab:

telinit q

Lisäksi tiedosto /etc/ioctl.save pitää poistaa, kun sarjaterminaalia asennetaan ensimmäistä kertaa.

Nyt init pitää huolen siitä, että sarjaportissa pyörii aina agetty tai joku muu prosessi, jos sieltä on kirjauduttu sisään. Jos sarjaterminaalilta haluaa kirjautua sisään pääkäyttäjänä (root), pitää kyseinen sarjaportti lisätä /etc/securetty-tiedostoon.

Ytimen viestit

Ytimen viestit eivät vielä tule sarjaterminaaliin. Jotta näin tapahtuisi, ytimeen pitää olla käännettynä "serial console" tai "console on serial port" -tuki. Lisäksi sille pitää antaa seuraavat parametrit käynnistyksen yhteydessä (kts. Grub):

console=ttyS0,9600n8 console=tty0

Niillä kerrotaan ytimelle, että sarjaportissa ttyS0 on sarjaterminaali, ja sen pitää käyttää nopeutta 9600 bps, parity none -asetusta ja 8 databittiä. Lisäksi on olemassa toinenkin konsoli, tty0, joka sattuu olemaan ensimmäinen virtuaalikonsoli. Ytimen viestit tulevat siis sekä virtuaalikonsoliin että sarjaterminaaliin.

Vuonohjaus

Vuonohjaus tarkoittaa toimintaa tilanteessa, jossa lähettäjä lähettää dataa nopeammin kuin vastaanottaja ehtii käsitellä. Ilman vuonohjausta dataa hukkuisi. Vuonohjaus voidaan tehdä ohjelmallisesti, jolloin datavirran seassa liikkuu XOFF- ja XON-komentomerkkejä, joilla vastaanottaja pyytää lähettäjää odottamaan ja jatkamaan lähetystä.

Toinen tapa on käyttää erillisiä johtimia vuonohjaukseen. Näitä RS-232 sarjaportista löytyy kaksi paria: CTS/RTS ja DSR/DTR.

Katso myös