Teemu Huhtala OBD2-JÄRJESTELMÄÄN PERUSTUVAN OHJELMAN KEHITTÄMINEN Tietojenkäsittelyn koulutusohjelma Sovellusohjelmoinnin suuntautumisvaihtoehto 2010 OBD2-JÄRJESTELMÄÄN PERUSTUVAN OHJELMAN KEHITTÄMINEN Huhtala, Teemu Satakunnan ammattikorkeakoulu Tietojenkäsittelyn koulutusohjelma lokakuu 2010 Ohjaaja: Stenfors, Juha Sivumäärä: 39 Liitteitä: 1 Asiasanat: autotekniikka, katsastus, diagnostiikka _____________________________________________________________ Opinnäytetyön aiheena oli tehdä laajalti ymmärrettävä dokumentaatio OBD2järjestelmästä ja tutkia sen mahdollisuuksia luoda auton moduuleihin yhteyden. Opinnäytetyön tavoitteena oli ohjelmoida ElmoScan ohjelmistosta uusi ja laajempi versio. Uusi versio mahdollistaa yhdistämisen auton eri moduuleihin. Tämän työn tarkoitus on kasvattaa ihmisten ymmärrystä OBD2järjestelmästä ja sen nykyaikaisista mahdollisuuksista. Työ selventää myös mitä järjestelmä pitää sisällään ja millaisia ominaisuuksia sen avulla voidaan tulevaisuudessa hyödyntää. Työssä kerron Suomessa olevasta katsastuksessa tapahtuvasta OBD2-järjestelmän tarkastuksesta. Työssä tutustutaan lähemmin OBD2-järjestelmän liittyviin moodeihin ja niiden tarjoamiin eri päätekomentoihin. Työssä esitellään tiettyjen päätekomentojen antamia vastauksia ja niiden tulkintaa oikealla tavalla. Työn tarkoitus on selventää autoilijalle minkä takia auton vikamerkkivalo syttyy ja miten auton vikakoodit luetaan. Opinnäytetyössä tutkitaan mahdollisia tapoja ja menetelmiä miten voi yhdistää autossa oleviin yksiköihin eli moduuleihin. Opinnäytetyön loppupuolella on esitetty Suomalaisen OBD2-ohjelmiston, ElmoScan, kehittäminen. Kehittämistyön tavoitteena oli ohjelmoida uusi ElmoScan versio, joka mahdollistaa yhteyden luomisen tietyntyyppisiin moduuleihin. Uuden ohjelmistoversion kehittäminen vaati huomattavan määrän tutkimustyötä ja dokumentaatioiden ymmärtämistä käytännössä. Opinnäytetyön toimeksiantajana toimi porilainen Softator Oy. OBD2 SOFTWARE DEVELOPMENT Huhtala, Teemu Satakunnan ammattikorkeakoulu, Satakunta University of Applied Sciences Degree Programme in Business Information Systems October 2010 Supervisor: Stenfors Juha Number of pages: 39 Appendices: 1 Keywords: Automotive engineering, inspection, diagnostics _____________________________________________________________ The purpose of this thesis was to create comprehensive documentation of On-Board Diagnostic system and create a new version of the ElmoScan OBD2 diagnostic software. The new version of the software makes it possible to connect to certain type of car modules. One goal of this work is to increase people's understanding of the OBD2 system and its modern opportunities. This work also clarifies what the system contains and what features it can utilize in the future. In this work I also tell how the Finnish car inspection uses the OBD2-port. This thesis looks into OBD2 general modes and PIDs. Also the thesis introduces some specific PIDs and replies, and how to convert the replies to real information. The purpose is to clarify why a cars fault indicator lights up on the car and how to read fault codes from the car. This work looks into the possible ways and methods to connect specific type of car modules. Finnish OBD2 software development is presented at the end of this thesis. The software is called ElmoScan and purpose of this thesis was to program new features to ElmoScan. The development of the new version of the ElmoScan software required a considerable amount of research. The thesis was assigned by Softator Oy in Pori. Softator Oy is a Finish software Development Company SISÄLLYS SYMBOLI- JA TERMILUETTELO ................................................................... 6 1 JOHDANTO............................................................................................... 8 2 OBD2......................................................................................................... 9 2.1 Käyttötarkoitus ................................................................................ 10 2.2 Käyttäjät .......................................................................................... 11 2.3 OBD:n historia ................................................................................ 12 2.3.1 OBD1 ................................................................................... 12 2.3.2 OBD2 ................................................................................... 13 2.4 OBD2 Protokollat ............................................................................ 13 2.4.1 ISO 15765-4......................................................................... 14 3 2.4.2 Muut protokollat ................................................................... 14 2.5 Lainsäädäntö ja katsastus suomessa ............................................ 14 2.6 Autonvalmistajien käytäntö............................................................. 15 OBD:N TULEVAISUUS ........................................................................... 16 4 3.1 OBD3 .............................................................................................. 16 3.2 Autojen seuranta............................................................................. 16 OBD2:N KOMMUNIKOINTI .................................................................... 17 4.1 Lukijalaite ........................................................................................ 17 4.2 Tiedon pyytäminen ja vastauksen tulkitseminen ............................ 18 4.2.1 Moodin käyttäminen............................................................. 18 5 4.2.2 Moodin ja päätekomennon käyttäminen .............................. 19 OBD2 DIAGNOSTIIKKA ......................................................................... 20 5.1 Vikakoodit ....................................................................................... 20 5.2 Moodit ............................................................................................. 21 5.2.1 Nykyiset tiedot...................................................................... 22 5.2.2 Freeze Frame Data.............................................................. 22 5.2.3 Tallentuneet vikakoodit ........................................................ 22 5.2.4 5.2.5 5.2.6 5.2.7 Tyhjennä muisti .................................................................... 23 Happianturin ja järjestelmän seurannantestaus .................. 24 Vireillä olevat vikakoodit....................................................... 24 Autontiedot ........................................................................... 24 5.2.8 Pysyvät vikakoodit ............................................................... 25 5.3 Valmistajakohtaiset moodit ja päätekomennot ............................... 25 5.3.1 Ford ...................................................................................... 26 5.3.2 Muut valmistajat ................................................................... 26 6 MODUULIT.............................................................................................. 27 6.1 Käyttötarkoitus ................................................................................ 27 7 6.2 Autonvalmistajat ............................................................................. 28 6.3 Yhteyden luominen ......................................................................... 28 ELMOSCAN ............................................................................................ 29 7.1 7.2 7.3 7.4 Historia............................................................................................ 29 OBD2-ohjelmistojen nykytilanne..................................................... 30 ElmoScan ohjelmistoon tutustuminen ja työn etenemisaikataulu .. 30 Tavoitteet ........................................................................................ 32 7.5 7.6 7.7 7.8 Moduulien hakeminen..................................................................... 32 Selvitystyön aikaiset ongelmat ....................................................... 33 Ohjelmoinnin aikaisia ongelmatilanteita ......................................... 33 Saavutetut hyödyt ........................................................................... 35 7.9 Tulevaisuuden näkymät.................................................................. 36 8 POHDINTA .............................................................................................. 37 LÄHTEET....................................................................................................... 38 LIITTEET SYMBOLI- JA TERMILUETTELO $ Etuliite tarkoitus on selventää, että kyseessä on heksadesimaalijärjestelmään kuuluva luku. Työssä käytetään etuliitettä yleisesti moodien yhteydessä. ABS (Anti-lock Brake System) Auton lukkiutumaton jarrujärjestelmä. AIRBAG Turvatyyny toimii yhtenä autojen turvallisuuslaitteena. CAN-Väylä (Control Area Network) automaatioväylä, joka toimii ajoneuvojen ja koneiden sisäisenä paikallisväylänä. DTC (Diagnostic Trouble Code) Yleinen vikakoodeista käytetty yleinen lyhenne. ECM (Engine Control Management) Moottoriohjauksen yksikkö. ESC (Electronic Stability Control) Elektroninen ajonvakautusjärjestelmä. LED (Light-Emitting Diode) Loistediodi eli ledi. Kun ledin läpi johdetaan virtaa, niin se säteilee valoa. OBD (On-Board Diagnostic) Ajoneuvon sisäinen valvontajärjestelmä, joka seuraa autontoimintoja. Kannettava ohjain Tässä työssä kannettava ohjain tarkoittaa kädessä pidettävää laitetta, joka osaa toimia itsenäisesti auton OBD2järjestelmän kanssa. Pending DTC (Pending Diagnostic Trouble Code) Viereillä olevat vikakoodit. PIDS, Päätekomennot (Parameter IDs) päätekomentoja käytetään moodeissa, joissa on enemmän kuin yksi komento. Protokolla Käytäntö tai standardi joka määrittelee tai mahdollistaa laitteiden tai ohjelmistojen väliset yhteydet. TCM (Transmission Control Module) Vaihteiston kontrollointi moduuli. SAE (The Society of Automotive Engineering) Yhdysvaltalainen autoalan standardisointijärjestö. Katso lisätietoa http://www.sae.org/ VIN (Vehicle identification Number) Autokohtainen tunnistetieto. Esimerkki auton 1M8GDM9A_KP042788. Katso tunnistetiedosta: lisätietoa http://www.angelfire.com/ca/TORONTO/VIN/VINcode.ht ml Vikamerkkivalo Autojen mittaristoista löytyvä merkkivalo, joka ilmaisee tallentuneista vikakoodeista. 8 1 JOHDANTO Opinnäytetyössäni tulen kertomaan OBD2-järjestelmän nykyaikaisesta käyttötarkoituksista ja käyttäjäkunnan kasvamisesta. Samalla on tarkoitus esitellä miten OBD2-järjestelmä on kehittynyt huomattavasti laajemmaksi alkuperäisestä OBD-järjestelmästä. Tavoitteena on myös esitellä nykyaikaista CANväylää, joka on muita protokollia kehittyneempi ja tämän hetkisessä tilanteessa ainoa käytettävä protokolla uusissa autoissa. Dokumentaation osana tulee olemaan opastusta, miten jokainen aiheesta kiinnostunut voi itse syöttää komentoja auton OBD2-järjestelmälle ilman kalliita ohjelmistoja. Komentojen syöttämisen lisäksi tarkoitus on kertoa miten OBD2-järjestelmän tarjoamia vastauksia on mahdollista tulkita. Esittelen myös tärkeimmät moodit, koska niitä voidaan pitää OBD2-järjestelmän perustana. Moodien toiminnallisuus täytyy sisäistää ja ymmärtää hyvin, jos haluaa oppia OBD2-järjestelmän toiminnallisuutta tarkemmin. Perusteiden jälkeen on hyvä tutustua hieman haasteellisempaan ja mielenkiintoisempaan alueeseen, eli moduuleihin. Moduuleilla tarkoitetaan autossa olevia eri yksiköitä, joihin on mahdollisuus ottaa yhteys OBD2-järjestelmän kautta. Yksiköitä voivat olla vaikka auton ABS tai stereot. Opinnäytetyöprojektissa tutkitaan mahdollista tapaa toteuttaa autojen diagnostiikka ohjelmistoon (ElmoScan) päivitys. Päivityksen tarkoituksena on mahdollistaa ElmoScan ohjelmiston välityksellä yhdistämisen tietyntyyppisesti esiintyviin auton eri moduuleihin. Opinnäytetyönprojektin päätavoitteena on saada julkaistua ohjelmistosta uusi ja entistä edistyneempi versio ElmoScan ohjelmistosta. Luvuissa 2-6 esittelen OBD2 toiminnallisuutta yleisellä tasolla. Luvussa 7 esittelen moduuleita ja niiden tarkoitusta. Luvussa 8 kerrotaan tarkemmin ElmoScan ohjelmistoon tehdystä päivityksestä. 9 2 OBD2 OBD (On Board Diagnostic) termin pitäisi jokaiselle autolla omistajalle tuntua tutulta termiltä. OBD2 on nykyaikainen tapa valvoa ja seurata auton kasvavia sähköjärjestelmiä, sekä raportoida mahdollisimman monipuolisesti auton jokaista tapahtumaa lähes reaaliaikaisesti. OBD2-järjestelmä toimi erittäin monipuolisesti nykyaikaisten ohjelmistojen välityksellä. Geneerisen OBD2-mittauksen suorittamiseen ei vaadita tunnuksia, eikä liikennettä olenkaan salattu. Tämä mahdollistaa käyttäjien tutustua järjestelmään yllättävän helposti ja vaivatta. Auton OBD2-porttiin liitetään pelkästään lukijalaite, joka kommunikoi auton ja ohjainlaitteen välillä. Ohjainlaitteena voi toimia erillinen kädessä pidettävä kannettava ohjainta (Kuva 1), autoon kiinteästi asennettava mittaristolaite tai ihan perinteinen kannettava tietokone. Lukijalaite ja ohjainlaite voi olla myös yhdistetty samaan laitteeseen. Lukijalaitteen tehtävänä on välittää tietoa autosta ohjainlaitteelle, joka kyselee komennoilla haluttuja tietoja autolta. Kuva 1. Tyypillisen näköinen kannettava ohjain. Lähde: http://www.sinoytool.com/upload/pro/472-813200816312283.jpg. 10 Nykyään on vaikea edes ymmärtää kuinka paljon normaaleissa henkilöautoissa on sähköisesti ohjattuja laitteita. Tämän kaiken seuraamiseen on kehitetty autoon oma diagnostiikkaportti, jonka tarkoituksena on seurata autossa tapahtuvia erilaisia muutoksia ja tapahtumia. Moni autoista enemmän tietävä ei välttämättä edes osaa kuvitella mihin kaikkeen OBD2-järjestelmään voidaan hyödyntää. Autokorjaajien työnkuvaan kuuluu entistä enemmän tietokonepohjainen ongelmien tutkiminen ja selvittäminen. Eroavuus on huikea verrattuna siihen kun autoissa kulki vain muutama isompi sähköjohto ja loput olivat mekaanisesti toteutettuja laitteita. Nykytilanne on kaukana tästä ja tämä aiheuttaa omat ongelmat, mutta osaksi se on vienyt kehitystä huimasti eteenpäin ja turvallisuus on kehittynyt aivan uudelle tasolle. 2.1 Käyttötarkoitus OBD2:n käyttötarkoituksia löytyy varmasti useita, eikä kaikkia ole varmasti vielä keksitty tai hyödynnetty tarpeeksi kattavasti. Alkuperäinen käyttötarkoitus on ollut yksinkertainen ja toimiva: kehittää pakokaasujärjestelmää lähes reaaliaikaisesti seuraava järjestelmä. Järjestelmä osaa myös havaita vikoja ja tuoda ne muutamalla yksinkertaisella komennolla käyttäjälle. Autoilijoille koko OBD2-järjestelmä saattaa tuntua vain isolta vaivalta ja turhalta rahastukselta katsastuksessa, vaikka sitä se ei todellisuudessa ole. OBD2 järjestelmän tavoitteena on vähentää autojen päästöjä ja saada autoilijat nopeasti puuttumaan autoissa oleviin teknisiin ongelmiin ja vikoihin. Viat saattavat nostaa huomattavasti auton päästöjä tai heikentää auton turvallisuutta. Tämän lisäksi OBD2-järjestelmä kykenee moneen muuhunkin tarkoitukseen. OBD2-standardit päätekomennot tarjoavat suurehkon määrän lähes reaaliaikaista tietoa. Esimerkkeinä näistä tiedoista on: auton kierrosluku, nopeus ja muiden eri anturin tarjoamaa tietoa. Saa selville kuinka kuumana koneen jäähdytysneste oikeasti on tai kuinka lämmintä ilmaa koneen imusarjaan menee. Tämän tyyppistä tietoa on ilman OBD2-järjestelmää vaikea selvittää. Pelkästään näille tiedoille löytyy jo huomattavamäärä käyttöä ja mahdollisuuksia tutkia moottorin toimintaa. 11 OBD2-järjestelmällä avulla on erittäin helppo seurata esimerkiksi auton kulutusta tarkemmin ja vertailla sitä omaan kirjanpitoon tai ajotietokoneen antamiin arvoihin. Tällaisen seurannan avulla esimerkiksi yritykset voivat kehittää ohjelmiston seuraamaan ylinopeuksia, epätaloudellisia ajotapoja ja kehittämään autojen kuljettajia taloudellisemmaksi. Mahdollisuuksia ja käyttötarkoituksia on monia, kunhan löytyy tarpeeksi kehittäjiä tekemään monipuolisia ohjelmia yleisesti saataville. 2.2 Käyttäjät OBD2:lle löytyy useita eri käyttäjiä, kuten esimerkiksi autokorjaamot, katsastusasemat ja autoharrastajat. Näistä autokorjaamoilla ja katsastusasemilla on suurin käyttötarve vikakoodien lukemisessa ja niiden huoltotarpeiden selvittämisessä. Näiden lisäksi löytyy myös edistyneitä käyttäjiä, jotka saattavat jopa kehittää oman ohjelmiston, joka soveltuu paremmin hänen käyttötarkoitukseensa. Koska olemassa olevien ohjelmistojen tarjonta saattaa olla liian suppea tai ei sovellu tarpeeksi hyvin käyttäjän käyttötarkoitukseen. Näitä ohjelmia ei välttämättä ikinä julkaista yleisesti saataville ja niiden toiminta voi jäädä täysin kokeelliseksi. Toisista ohjelmistoista voi kuitenkin kehittyä laadukas ohjelmisto, jonka tulevaisuus voi olla hyvinkin tuottoisa. Osa käyttäjistä on innokkaita autoharrastajia, jotka haluavat oppia, seurata ja ymmärtää autojen toimintaa. Innokkaimmat käyttäjät yrittävät saada kaiken mahdollinen informaation ulos autosta ja päästä seuraamaan sitä reaaliaikaisesti. Autoharrastajat keskustelevat eri keskustelupalstoilla ja foorumeilla. Tällä tavalla he jakavat tietoa keskenään. Tämän tyyppinen kehittävä tutkimustyö on jo saanut aikaan useita pienempiä ohjelmia, jotka toimivat mainiosti ja ovat käyttötarkoitukseltaan edistyksellisiä kehitettyyn toimintoon. 12 Pienissä OBD2 ohjelmistoissa kehitystä tapahtuu yleisesti hitaasti, mutta suurin ongelma tulee olemaan kehittäjän eli yksittäisen ihmisen tai pienen ryhmän aika. Lopulta kehittäjien resurssien väheneminen saattaa lopettaa kehitystyön kokonaan ja ohjelmiston ylläpitäminen tulee loppumaan kokonaan. 2.3 OBD:n historia OBD:n historia on jo yllättävän pitkä ja kehitys on mennyt paljon eteenpäin. Kehittäminen on alkanut 1980-luvun alkupuolella, jolloin ensimmäiset OBDportit tulivat autoihin ja kehitystyötä alkoi tästä. Alussa suurin heikkous oli laitteiden yhteensopimattomuus. OBD-järjestelmän kehittämisen päätavoite oli autoilla puhtaamman ilman puolesta. OBD:n tarkoitus on seurata auton pakokaasujen päästöjä ja tiukentaa päästöjen seurantaa. Tärkeimmät ovat olleet päätökset, jotka ovat pakottaneet autovalmistajien lisäämään täydellisesti toimivan OBD2-portin autoihin. Yhdysvalloissa tämä tapahtui jo vuonna 1996. (Omitec Limited) 2.3.1 OBD1 OBD1-järjestelmä oli suhteellisen yksinkertainen ja se sisälsi ainoastaan happianturin tarkkailun, pakokaasunkierrätyksen seurannan, bensiininsyötön ja ECM:n seurannan. OBD1 oli tarkoitettu puhtaasti seuraamaan pakokaasupäästöjä auton elektronisten moottorinohjauksen välityksellä. Vikatiedot saatiin yleensä autoista ilman erillistä lukijalaitetta ja siihen riitti pelkästään LEDin käyttäminen tai auton vikamerkkivalo. Vikakoodien raportoimiseen toimii vikamerkkivalon vilkkuminen ja tästä saatiin luettua mitä vikakoodeja oli tallentunut järjestelmän muistiin. OBD1 heikkoutena oli liian väljä standardi, joka johti jokaiselle valmistajalle mahdollisuuden kehittää omalaista toimintaa. Tämä aiheutti useiden erilaisten adapterien tarvetta ja mahdollisti joihinkin järjestelmiin pääsyyn ainoastaan valmistajakohtaisilla lukijalaiteilla. (Omitec Limited) 13 2.3.2 OBD2 OBD2-Järjestelmä on asetettu huomattavasti tarkempi standardi ja kehittynyt samalla käyttäjäystävällisemmäksi, joka helpottaa käyttäjien tutustumista järjestelmään. Tiukemman standardin oli tarkoitus antaa tarkemmat ohjeistukset, miten järjestelmän tulee toimia. Samalla havaita herkemmin mahdolliset päästöjärjestelmiin liittyvät viat ja ongelmat. Merkittävä hyöty tiukemmasta standardista oli OBD2-liittimen standardisointi tiettyyn malliin. Katso kuva 2. Tämä vähensi ylimääräisien adapterien käyttämistä. Autoissa oleva vikamerkkivalo saattaa vilkahtaa herkästi, jos autossa ilmenee hetkellistä vikaa. Vikamerkkivalo ei välttämättä jää palamaan, koska se voi johtua hetkellisestä ongelmasta sytytyksessä tai joku tärkeä osa-alue autosta menetti yhteyden auton OBD2-järjestelmään.(Omitec Limited) Kuva 2. OBD2 standardi portti. Lähde: http://us1.webpublications.com.au/static/images/articles/i19/1935_5lo.jpg. 2.4 OBD2 Protokollat OBD2-protokollia löytyy jo useita erilaisia, joiden käyttäytymisessä on pieniä eroavuuksia. Nykyaikaiset lukijalaitteet osaavat automaattisesti valita oikean protokollan. Vanhemmat protokollat ovat poistuneet jo käytöstä ja uusimmat kehittyvät kokoajan paremmaksi. Tämä aiheuttaa ohjelmistojen kehittäjille huomattavaa määrää lisätyötä, koska joudutaan testaamaan jokaista protokollaa erikseen ja varmistaa toimiiko laitteisto ja ohjelmisto oikein. Protokollien tarjoaman tiedon sisällön kanssa ei pitäisi olla eroa, mutta ero löytyy tiedonpituudessa ja sen käsittelyssä. Vuoden 2008 jälkeen valmistetuissa autoista pitäisi löytyä aina CAN-väylä. (OBD Automotive Oy 2007) 14 2.4.1 ISO 15765-4 ISO 15765-4 eli CAN-väylä tarjoaa entistä enemmän käyttäjille tietoa auton OBD2-järjestelmästä. CAN-väylä on nykyaikaisin protokolla, joka eroaa huomattavasti vanhemmista protokollista. Tietoa ei tarjota vanhaan tapaan eli ottamalla yhteys tiettyyn moduuliin, vaan se tarjoaa kaikista moduuleista tulevat tiedot yhtäaikaisesti. Tuleva tieto kuitenkin priorisoidaan tärkeyden mukaan eli kaikki turvalaitteet ovat ennen muita ja vähemmän tarpeellinen tieto vasta näiden jälkeen. Harvoissa Suomen teillä liikkuvissa autoissa on CANväylä, koska se tuli pakolliseksi vasta vuoden 2008 jälkeen. CAN-väylän tiedonsiirtonopeus on huikeasti vanhoja nopeampi ja luotettavuus ei ole silti kärsinyt. (OBD Automotive Oy 2007; Müller 2005, 44-45 ) 2.4.2 Muut protokollat Ennen vuotta 2008 oli käytössä useita eri protokollia, jotka johtivat sekavaan käytäntöön. Yhdellä autonvalmistajalla saattoi olla useita eri protokollalla käytössä samassa automallissa. Tietyn protokollan käyttäminen ei ollut yhtenäinen muiden autovalmistajien kanssa. Vanhempien protokollien suurimpia heikkouksia oli hidas tiedonsiirto. Suurimpia eroja toiminnallisuudessa CANväylän kanssa on fyysisten osoitteiden eroavuus ja tästä seurasi komennoilla pyydettyjen vastauksien pituuksien vaihtelua. (Müller 2005, 43-45) 2.5 Lainsäädäntö ja katsastus suomessa Suomen laissa on määritetty, että jokaisen 2001 vuoden jälkeen valmistetuissa bensiinikäyttöisissä autoissa pitää olla toimiva OBD2 portti ja dieselkäyttöisissä autossa vuodesta 2003 eteenpäin. Vuosikatsastuksessa tarkistetaan OBDII portin toimivuus ja sen muistiin tallentuneet virheilmoitukset ja auton tämän hetkiset päästöt. 15 Vuosikatsastuksessa hyväksytään myös valtuutetun korjaamon tarjoama OBD-tarkastuksen tuloste, jossa tulee ilmetä seuraavat tiedot TraFi:n (AKE 2007, 2-4) mukaan: • Vikamerkkivalon tila, mikäli valo on aktiivinen ja se on mittalaiteesta saavissa. • Selkokielinen informaatio OBD-järjestelmän mahdollisista vioista. • Selkokielinen informaatio auton sisäisen valvontajärjestelmän toimintavalmiuden osatestien suorittamisesta. • Mikäli kaikkia osatestejä ei ole pystytty suorittamaan, merkitään tieto lambdasäädön toiminnasta ja sen tiedoista. 1.1.2004 jälkeen valmistetuille autoille suoritetaan korotettu pyörintänopeus päästötesti, josta tulee ilmetä normaalien tietojen lisäksi 2.6 • Lambda-arvo • Co- ja HC-arvot • happi- ja hiilioksidi-arvot • moottorin pyörintä nopeus, mikäli se on mahdollista mitata Autonvalmistajien käytäntö Autonvalmistajilla on tiukat politiikat järjestelmien salaamisesta ja valmistajakohtaisten komentojen julkaisemattomuus on aina ollut hidastava tekijä OBD2-ohjelmistojen kehittämisessä. Mahdollista on myös ostaa eräiltä autovalmistajilta parannettujen OBD2 komentojen tiedot. Näiden tietojen hinnat ovat pienimmille yrityksille aivan liian korkeita. Tämän tyyppisen toiminnan tarkoituksena on estää mahdollisuus niiden ostamiseen. OBD2 ohjelmistojen hitaat markkinat estävät kehitystyön, koska autonvalmistajien antamat tiedot, ovat vain isojen yritysten käytettävissä. Pienimmissä ohjelmistojen kehitystyössä joudutaan harrastamaan paljon hidasta tutkimustyötä. Tällöin joudutaan käyttämään suuria määriä resursseja pelkästään yksinkertaisiin autonvalmistajakohtaisien moduulien yhteyksien luomiseen ja päätekomentojen tarjoamien vastauksien tulkitseminen. 16 3 OBD:N TULEVAISUUS Tulevaisuudessa tullaan suurella todennäköisyydellä kehittämään kehittyneempi versio OBD2-järjestelmästä, joka tulee korvaamaan sen lähes täysin. Nykyiset hybridi- ja sähköautot, ovat selvästi tulevaisuudessa isomassa asemassa, mutta OBD2 ei ole kehitetty sopimaan näiden autojen vaatimiin tarpeisiin. 3.1 OBD3 OBD-järjestelmän kehitys menee eteenpäin jolloin olemassa olevan järjestelmän kehittäminen tulee nopeasti eteen. Tiedetään varmasti, että OBD3:een on jo korjattu OBD2 löytyvät puutteet ja lisätään nykyaikaisuuteen liittyviä ominaisuuksia. Yhtenä suurimpana uudistuksena odotetaan, ettei vaadita fyysistä yhteyttä tietojen hakemiseen autosta. OBD3-järjestelmässä mahdollistetaan tapa jolla voidaan hakea kaikki tiedot langattomasti autosta. Nykyään on huomattava määrä tapoja jotka mahdollistavat langattoman tiedonsiirron autossa. Tiedonsiirtoon voidaan käyttää esimerkiksi Wlan tai Bluetooth -tekniikoita. Langatonta yhteyttä pidetään yhtenä suurimmista uudistuksista, jota OBD3 tuo mukanaan.(California Air Resources Board, 2009, 13) Langattoman tekniikan tarkoituksena on vähentää auton eliniän aikana aiheuttamia käyttökustannuksia. Tieto auton vikatiedoista voidaan lähettää välittömästi sitä valvovalle viranomaiselle (TraFi). (California Air Resources Board, 2009, 13) 3.2 Autojen seuranta Nykyaikaisilla järjestelmillä ja ohjelmistoilla on mahdollisuus hallita auton OBD2-järjestelmää. Tällöin pystytään hallitsemaan useita autontoimintoja. Hyvänä lisänä on myös GPS:n tuleminen autoihin. 17 4 OBD2:N KOMMUNIKOINTI Yhdistämisen OBD2-järjestelmään tarvitaan aina lukijalaite, joka tulkitsee viestit OBD2-järjestelmän ja tietokoneen välillä. Erityisen OBD2-ohjelmiston käyttäminen ei ole välttämätöntä, jos tietää miten luoda yhteyden tietokoneen ja lukijalaiteen välille. Yhteyden luomisen jälkeen voidaan kysellä autolta haluttuja tietoja. Lukijalaite välittää autolta tulleen vastauksen terminaaliin, kunhan terminaali osaa ottaa tietoa tarpeeksi nopeasti vastaan. 4.1 Lukijalaite OBD2-lukijailaite toimii yleensä yhdistettynä johdolla tietokoneeseen, mutta tarjolla on myös langattomia vaihtoehtoja. Langattomat lukijalaitteet toimivat, joko Bluetooth tai Wlan tekniikoilla. Langattomalla tiedonsiirrolla yritetään helpottaa laitteiden käyttämistä ja välttää vaarallisia johtoja liikkuvassa autossa. Lukijalaitteen tehtävänä on hoitaa OBD2 tiedon käyttäjän ja OBD2järjestelmän välillä. Nykyaikana lukijalaitteita on lukemattomia määriä tarjolla ja hinnat liikkuvat kymmenen ja usean tuhannen euron välillä. Käyttäjän tarpeesta riippuen kannattaa valita lukijalaite tarkasti. Nimittäin on turha maksaa kalliista laitteesta, jos tarpeena on pelkästään vikakoodien lukeminen. Jos käyttäjä haluaa tehdä muutakin kuin lukea vikakoodeja saa nykyaikaisen, laadukkaan ja kattavan lukijalaitteen tilattua edullisesti. Lukijalaitteiden tärkeimmät ominaisuudet ovat tulkin toimivuuden lisäksi lukijalaitteen ominaisuudet, luotettavuus, nopeus. Kun tietokone on saanut yhteyden lukijalaitteeseen, niin kaikki nykyaikaiset lukijalaiteet pitäisi pystyä tunnistamaan automaattisesti auton käyttämä tiedonsiirto protokolla. Vanhemmissa lukijalaitteissa on mahdollista, että käyttäjä joutuu itse määrittämään auton käyttämän protokollan tai lukijalaite on tehty pelkästään toimimaan tietyn protokollan kanssa. 18 4.2 Tiedon pyytäminen ja vastauksen tulkitseminen Yhteyden luomisen jälkeen on erittäin helppoa kysellä haluttuja tietoja autolta. Tiedonpyytämiseen löytyy moodi komentoja tai jos moodi sisältää useampia eri komentoja, niin käytetään moodia ja päätekomentoa yhdessä. Kaikki moodit eivät sisällä useita komentoja. Kun auton OBD2-järjestelmältä on pyydetty tietoa, niin se saadaan vastaus merkkijonoina. Merkkijono voi sisältää joko heksadesimaaleja tai suoraan vastauksen merkkijonossa. Merkkijonojen pituus voi vaihdella käytetyn protokollan mukaan, koska protokollien tunnistetietojen esiintymisessä on eroavuuksia. Merkkijonon vastausta täytyy osata tulkita oikein, koska muuten merkkijonon tarjoamista tiedosta ei ole hyötyä. Merkkijonojen tulkitsemisesta löytyy tietoa SAE:n maksullisista dokumenteista. (Seyfert, Karl 2007) Seuraavissa kohdissa esitän esimerkkejä pelkän moodin ja moodin ja päätekomennon käyttämisestä todellisuudessa 4.2.1 Moodin käyttäminen Esimerkki pyydettäessä auton vikakoodeja pelkällä moodilla $03. Jos auton muistiin ei ole tallentunut, niin ei vastausta välttämättä tule ollenkaan. Vikakoodien pyytämiseen riittää kun syöttää lukijalaitteelle pelkästään numerosarjan ”03”. Kuva 3. Kuvankaappaus ElmoApuri ohjelmasta. Vikakoodien luku. Kuvassa 3. olevissa riveissä on nähtävissä suoraan vikakoodit. Vikakoodeja tulkittaessa rivien otsikkotiedot (43) ei ole merkitseviä. Vikakoodit ovat aina neljän merkin ryhmissä ja kuvan 3 mukaisessa tapauksessa on vikakoodeja yhteensä seitsemän. 19 4.2.2 Moodin ja päätekomennon käyttäminen Esimerkki pyydettäessä auton nopeutta käytetään moodilla $01 ja komentoa 0D. Kuva 4. Kuvankaappaus ElmoApuri ohjelmasta. Auton nopeus. Kuvassa 4 olevan vastausrivin 4 ensimmäistä merkkiä palauttaa kysytyn komennon. Tämän jälkeen loput merkeistä kertoo nopeuden heksadesimaaleina. Vastauksen saa purettua kääntämällä heksadesimaalin normaaleiksi desimaaleiksi, jolloin kuvanotto hetkellä nopeudeksi saatiin 53km/h. (Elm Electronics Inc. 2010, 27) Esimerkki pyydettäessä auton kierrosluku tietoa käytetään moodilla $01 ja komentoa 0C. Kuva 5. Kuvankaappaus ElmoApuri ohjelmasta. Auton kierrosluku. Kuvassa 5 olevan vastausrivin 4 ensimmäistä merkkiä palauttaa kysytyn komennon. Tämän jälkeen loput merkeistä on vastaus eli ”20 51”. Merkkijono käännetään heksadesimaali desimaaleiksi, jonka jälkeen saatu luku jaetaan neljällä, jolloin saadaan tulokseksi 2068 kierrosta minuutissa. (Elm Electronics Inc. 2010, 27) 20 5 OBD2 DIAGNOSTIIKKA OBD2-järjestelmän diagnostiikalla mahdollistetaan auton toimintojen seuranta ja muistiin tallentuneiden tietojen lukemisen OBD2-ohjelmiston avulla. Diagnostiikka on tärkeimpiä toiminnallisuuksia OBD2-järjestelmässä. OBD2järjestelmän diagnostiikka tarjoaa huomattavan määrän lähes reaaliaikaista tietoa. Usean tiedon tulkitsemisella voidaan tehdä monipuolisia ohjelmia, joiden toiminnot pitävät sisällä laajan kokonaisuuden. 5.1 Vikakoodit Vikakoodien (Diagnostic Trouble Code, DTC) tallentamista ja tulkitsemista pidetään OBD2-järjestelmän yhtenä tärkeimpänä ominaisuutena. Vikakoodit tallentuvat aina samalla tavalla auton muistiin ja yksittäisen vikakoodin merkkijonon pituus on aina vakio, vaikka tiedonsiirtoprotokolla vaihtuisi. Vikakoodien tarkoituksena on tallentaa autonmuistiin tapahtuneet viat, jotka ovat ilmentyneet tietyssä tilanteessa. Vikakoodien tallentumisella on tarkoitus helpottaa autossa esiintyvän vian määrittämistä. Vikakoodien tallentuminen mahdollistetaan nykyaikaisemman korjaamotoiminnan. Autossa tapahtuvan vian ilmentyessä tarpeeksi useasti (kolme kertaa) se tallentuu muistiin, jolloin vikamerkkivalo saattaa syttyä. Vika voi ilmentyä myös satunnaisesti pitkällä aikavälillä, jolloin vikakoodia ei tallenneta normaaliksi vikakoodiksi vaan vireillä olevaksi vikakoodiksi. Vikamerkkivalon palaminen ei estä autolla ajamista tai välttämättä haittaa lainkaan autontoimintaa. Vikamerkkivalon palamisen löytyy yleensä selitys vikakoodeja luettaessa lukijalaitteella. Vikakoodienlukeminen on erittäin tärkeä suorittaa säännöllisesti, koska se on kehitetty nimenomaan autojen turvallisuuden ja luotettavuuden takia. Vikakoodien lukeminen lukijalaitteella saattaa tuoda julki, myös autossa vireillä olevia vikoja. Moni autojen tekniikasta ymmärtävä saattaa säästää kalliin korjaamokäynnin, kun pystyy lukemaan vikakoodit omalla lukijalaitteellaan. Autokorjaamo veloittaa jo lukijalaitteen hinnan pelkästään yhden auton vikakoodien lukemisesta. 21 Vikamerkkivalo voi syttyä jo pienestäkin ongelmasta kuten huonosta kontaktista auton anturin liittimessä. Tämä aiheuttaa yhteyden pätkimisen ECM:n kanssa. Pätkimisen seurauksena vika on toistuva, jolloin vikamerkkivalo syttyy. Vikakoodien lukemisella pääsee heti selville mikä sytytti vikamerkkivalon ja esimerkiksi pelkän liittimen putsaamisella tuli säästettyä melko kallis korjaamo käynti. 5.2 Moodit Moodit sisältävät OBD-järjestelmän päätoiminnallisuudet omissa osaalueissaan. Moodit toimivat komentoina, joita OBD2-järjestelmä kuuntelee ja osaa niihin vastata. Osa moodeista sisältää huomattavan määrän enemmän alikomentoja kuin pelkän moodi komennon. Alikomentoja kutsutaan päätekomennoiksi (PIDS). Moodien jakaminen selkeisiin omiin osa-alueisiin selkeyttää OBD2- järjestelmän toimintaa. Jokainen moodi on kehitetty tiettyyn toimintaan ja tarkoitukseen. Päätekomennot ovat moodien sisäisiä komentoja, joilla saadaan osoitettua tarkemmin mitä tietoa haluaa kysyä OBD2-järjestelmältä. (sae j2178) Seuraavassa taulukossa (Taulukko 1) on lueteltuna kaikki yleisimmät käytössä olevat moodit. Moodien tarkempi kuvaus esitellään seuraavaksi alaotsikoiden avulla. Taulukko 1. Yhteenveto moodeista. (Seyfert, Karl 2007) Moodi $01 $02 $03 $04 $05, $06 $07 $09 $0A Tarkoitus Nykyiset tiedot Freeze Frame Data Tallentuneet vikakoodit Tyhjennä muisti Happianturin ja järjestelmän seurannantestaus Vireillä olevat vikakoodit Auton tiedot Pysyvät vikakoodit 22 5.2.1 Nykyiset tiedot $01 on moodeista eniten käytetty, koska se sisältää huomattavan määrän toiminnallisuutta. Moodi $01 sisältää esimerkiksi tallentuneiden vikakoodien lukumäärän ja huomattavan määrän standardisoituja päätekomentoja. Päätekomentoja avulla saadaan kyseltyä useiden eri antureiden tämänhetkiset arvot. Ohjelmistot yleensä hyödyntävät näitä tietoja joko tietojen keräämiseen tai näyttääkseen eri arvoja graafisessa muodossa käyttäjille. Moodin $01 päätekomentojen avulla voidaan kysellä hyödyllistä tietoa. Esimerkkinä hyödyllisistä tiedoista ovat: auton tämänhetkinen nopeus, kierroslukumäärän, auton käynnissä olo aika tai kuinka pitkään autolla on ajettu vikamerkkivalo päällä. Suurin osa tiedoista on merkkijonoja joiden tarkoitus ei selviä ennen niiden kääntämistä oikeaan muotoon. Oikeaan muotoon kääntäminen ei ole yksiselitteinen, vaan tapahtuu hyvinkin erityyppisten laskelmien avulla. (SAE International 1997, 31) 5.2.2 Freeze Frame Data $02 moodin tarkoituksena on tallentaa vikatilanteen tapahtuessa muistiin huomattava määrä hyödyllistä tietoa vikakoodin tapahtuma hetkestä. Moodi $02 tallentama tietoa sisältää esimerkiksi tapahtuneen vikakoodin, auton nopeuden ja kierrosluvun. Nämä tiedot on mahdollista lukea ja analysoida, myös jälkikäteen. Tallentuneen tiedon avulla on mahdollista selvittää mistä vikatilanne saattoi johtua tai oliko mahdollisesti poikkeuksellinen vikatilanne päällä. Poikkeuksellinen tilanne voi olla esimerkiksi isoilla kierroksilla tapahtunut auton huomattava tärinä, joka on aiheuttanut tiedonsiirto ongelman anturin ja OBD2-järjestelmän välillä. (SAE International 1997, 31) 5.2.3 Tallentuneet vikakoodit $03 moodi on OBD2-järjestelmän yksi helpoimmista moodeista käyttää, tulkita ja analysoida. Kyseltäessä pelkällä moodilla $03 saadaan vastaus, joka sisältää kaikki järjestelmän muistiin tallentuneet oikeat vikakoodit. Moodin 03 23 palauttama vastaus ei sisällä tietoa mitä vikakoodi tarkoittaa, vain pelkän merkkijonon. Merkkijonon ensimmäisen merkin avulla voidaan päätellä mikä auton osa-alue on kyseessä. Aina kun vikakoodeja on tallentunut tämän moodin muistiin, vikamerkkivalon syttyy automaattisesti. Jos vikakoodeja ei ole ollenkaan järjestelmän muistissa, vastausta ei tule tai se on tyhjä.(SAE International 1997, 32) 5.2.4 Tyhjennä muisti $04 on tarkoitettu tyhjentämään auton muistiin tallentuneet tiedot, jotka liittyvät vikakoodien tallentumiseen ja pakokaasupäästöjen seurantaan. Moodi ei sisällä yhtään erillistä päätekomentoa vaan moodi toimii pelkästään kaikkien tietojen tyhjentämiseen. Tärkeintä tietojen tyhjentämisessä on muistaa, että tyhjennettyjä tietoja ei voi palauttaa ollenkaan. Moodi $04 tyhjentää seuraavat osa-alueet: • Vikakoodien määrästä • Vikakoodeista • Freeze frame datan tallentaneen vikakoodin • Freeze frame datan sisällöstä • Happianturin testauksen tiedot • Järjestelmän seurannan tila • Moodin $06 ja $07 tulokset Mikäli, joku tyhjennettävistä osa-alueista ei vastaa $04 komentoon se ohitetaan ja jatketaan seuraavaan osa-alueeseen. Tietojen tyhjentäminen ei ole vaarallista tai haitallista. Tallentuneet tiedot vain menetetään lopullisesti. Moodi tulisi suorittaa aina kun vikakoodit on luettu ja mahdollinen vian aiheuttaja korjattu. Vikakoodien muistia ei pitäisi joutua turhaan tyhjentämään, jos järjestelmä on täysin kunnossa. (SAE International 1997, 32) 24 5.2.5 Happianturin ja järjestelmän seurannantestaus $05 ja $06 moodit toimivat testausmoodeina, joiden avulla pystytään selvittämään, saako auto puhtaan testaustuloksen. Happianturin moodin $05 toimiminen ei ole välttämätöntä, jos järjestelmäntestausmoodi $06 toimii. Katsastuksessa suoritetaan vain moodin 06 testaus, joka antaa kattavan vastauksen auton osa-alueiden toimivuudesta. Jos moodin $06 tarjoamaa tietoa ei saada tai joku osa-alueista ei toimi joudutaan suorittamaan moodi $05. (SAE International 1997, 32, 36) 5.2.6 Vireillä olevat vikakoodit $07 moodi kertoo vireillä olevat vikakoodit. Vireillä olevat vikakoodit ovat toistuneet satunnaisesti pitkällä aikavälillä tai alle 3 kertaa. Näiden tietojen avulla voi yrittää hakea satunnaista vikaa tai muuten ajon aikana ilmenneitä hetkellisiä ongelmia. Vireillä olevat vikakoodit siirtyvät automaattisesti moodin $03 alaisuuteen jos ne toistuvat yli 3 kertaa. Moodin $07 tarkoituksena on mahdollistaa nopeampi vianpaikantaminen vikakoodien nollaamisen jälkeen. Vireillä olevat vikakoodit helpottavat autokorjaajan toimintaa, koska ajokerran jälkeen pääsee heti näkemään onko vikakoodi ilmestynyt uudestaan nollaamisen jälkeen. (SAE International 1997, 36) 5.2.7 Autontiedot $09 moodi sisältää autosta tallennettuja tietoja, joista hyödyllisin on autokohtainen VIN-sarjanumero. Sarjanumeroa on hyödyllinen käyttää, jos haluaa yksilöidä tallennetut autot, omaan ohjelmaan. VIN-sarjanumeron avulla voidaan myös selvittää automerkki-kohtainen sarjanumerointi. VIN-sarjanumero on tallennettu 5-riviseksi International 1997, 39) merkkijonoksi OBD2-järjestelmässä. (SAE 25 5.2.8 Pysyvät vikakoodit $0A moodin tallentuneiden tietojen tarkoitus ei ole poistua käyttämällä moodia $04. Pysyvät vikakoodit poistuvat automaattisesti vasta kun vika on korjaantunut ja OBD2-järjestelmä huomaa tapahtuneen muutoksen. Moodi $04 saattaa sammuttaa vikamerkkivalon hetkellisesti, mutta se syttyy uudestaan kun diagnostiikka on huomannut sen uudelleen. Tällöin vikamerkkivalon syttyy automaattisesti ja pysyy päällä siihen asti kun vika on korjattu. (SAE International 1997, 44) 5.3 Valmistajakohtaiset moodit ja päätekomennot Edellä esiteltyjen moodien lisäksi löytyy huomattava määrä tuntemattomampia moodeja, jotka voi paljastaa paljon uutta erittäin hyödyllistä tietoa. Tämän tiedon löytäminen saattaa usein viedä aikaa huomattavan määrän aikaa. Tieto ei välttämättä löydy kirjoista tai muualta suoraan luettavana olevista lähteistä. Tietoja saattaa löytää esimerkiksi Internetin maksullisista palveluista, joihin liittyminen saattaa maksaa useita tuhansia euroja. Mahdollista on myös hankkia tietoa suoraan autonvalmistajilta, mutta näidenkin hinnat ovat hyvin korkeita. Korkeat hinnat hankaloittavat suuresti tietojen tarkempaa keräämistä ja sen hyödyntämistä. Toisien autovalmistajien moodit ja päätekomennot saattavat pienellä mahdollisuudella löytyä Internetistä ja toisista automerkeistä ei löydy mitään. Mahdollinen tapa selvittää tai varmistaa oman auton tietoja on käyttää valmista ohjelmistoa, josta löytyy halutut toiminnot tai ominaisuudet. Seuraavaksi esitellään yksi automerkki, jossa moodi tietojen selvittäminen ja löytäminen osoittautui haasteelliseksi. Esiteltävä automerkki on Ford. Muut automerkit käsitellään yhteenvetona omassa kohdassa. 26 5.3.1 Ford Fordin käyttämä moodi on $22. Samaa tapaa käyttävät muutama autonvalmistaja, kuten esimerkiksi General Motors -autokonserni. Kun oikeanlainen moodi on löydetty, luodaan yhteys käyttämällä sitä. Moodin yhdistäminen on vasta ensimmäinen askel todelliseen moodin tietojen käyttämiseen. Yhdistämisen jälkeen on pakollista aloittaa selvitystyö, jotta löytää oikeat päätekomennot ja mitä kyseinen päätekomento tarkoittaa. Päätekomentojen syöttämisen jälkeen saadaan vastaukset merkkijonoja. Merkkijonon tulkitsemiseen tarvitaan mahdollisesti purkaustapa, jonka avulla merkkijono puretaan oikeaksi tiedoksi. (Ford Motor Company 2007, 59-60) 5.3.2 Muut valmistajat Monilta autovalmistajilta löytyy oma moodinsa. Eri autonvalmistajien käyttämät moodit poikkeavat mahdollisesti General Motorsin ja Fordin käyttämästä moodista $22. Ainoa kriteeri moodin numeroksi on, että sen pitää olla järjestysnumeroltaan yli 9. Taulukosta 2 löytyy esimerkkejä. Taulukko 2. Esimerkkejä autovalmistajien moodeista. Autonmerkki Toyota Mazda Moodi $21 $22 OBD2-ohjelmistojen kehittäjät ovat huomanneet autonvalmistajien käyttämät moodit ja niiden päätekomennot. Jolloin kehittäjät panostavat sen tutkimiseen tarkemmin entistä enemmän. Monien OBD2-ohjelmistojen kehittäjien tilanne on tehdä valmistajakohtaiset paketit jokaiselle autovalmistajille. Autovalmistajien paketeilla yritetään hyödyntää autovalmistajakohtaiset moodit. Autovalmistajakohtaisella paketin avulla saadaan lisättyä ohjelmiston myyntiä ja näkyvyyttä. (Rleale 2009) 27 6 MODUULIT Autossa saattaa nykyaikana olla jo useita kymmeniä erilaisia moduuleja perinteisen ECM-yksikön lisäksi. Moduulilla tarkoitetaan erilaisia pienempiä yksiköitä. Moduulit on kehitetty hoitamaan sille tehtyä tarkoitusta ja mahdollisesti välittämään tietoa eteenpäin. Aikaisemmin moduulien ongelma on ollut heikko tai hankala moduulien tiedon välittäminen. Yleisesti tärkeimmät moduulit kuitenkin liittyvät läheisesti auton toimintaan ja turvallisuuteen. Auton toimintaan liittyviä moduuleita ovat muun muassa ECM ja TCM. Puolestaan turvallisuuteen liittyviä moduuleita ovat muun muassa: ABS, Airbag ja ESC. Vähemmän tarpeellisia moduuleita saattaa löytyä uusista autoista huomattavan paljon. Vähemmän tarpeellisia moduuleita voivat olla esimerkiksi stereot, lukot ja muut mukavuuteen liittyvät tekijät. Moduulien tärkeimpänä tekijänä on luoda yhteys muihin moduuliin, jotka mahdollistavat tiedonsiirtoa suoraan moduuleista käyttäjälle. OBD2 moduulit tarjoavat mahdollisuuden, jolla vältetään jokaiseen laitteeseen fyysinen yhteyden luominen. Moduulien avulla mahdollistetaan yhden portin välityksellä tiedonsiirtämisen. OBD2-järjestelmä on yhteensopiva usean moduulin kanssa. Ongelmana on moduulien yhteen sopivuus OBD2-järjestelmän kanssa. Harva moduuli on tehty suoraan täysin yhteensopivaksi OBD2-järjestelmän kanssa. (Elm Electronics Inc. 2010, 35-37) 6.1 Käyttötarkoitus Käyttötarkoituksia moduuleille varmasti löytyy useita, koska jokainen moduuli eroaa toisistaan. Käyttötarkoitukseen voi liittää kaikki auton toiminnot ja niiden säätömahdollisuudet. Jollekin voi olla tärkeää päästä tutkimaan vaihdelaatikon tarjoamia tietoja, vaikka esimerkiksi akseleiden pyörintä nopeuksia ja toiset voivat olla kiinnostuneita päästä vaihtamaan mittaristonvalojen värisävyjä. 28 6.2 Autonvalmistajat Määrityksen mukaista käytäntöä moduulien kanssa toimimiseen ei ole ollut montaa vuotta, joten autonvalmistajat ovat käyttäneet itse kehittäminään keinoja yhteyden luomiseen moduuleihin. Nämä Autovalmistajien omat tavat vaikeuttavat ohjelmistojen kehittämistä huomattavasti. Tietylle automerkille tai jopa automallille voi joutua pidempäänkin etsimään mahdollista yhteyden luomisen tapaa. Mikään ei myös estä autovalmistajia lisäämästä yksilöllisiä tunnuksia autokohtaisesti, jotka vaaditaan päästäkseen moduulin kanssa yhteyteen. Autovalmistajien kehittämät ominaisuudet tietenkin välitetään merkkihuollon käytettäväksi, mutta ei muille ohjelmistojen kehittäjille. Tämä johtaa siihen, että autonmerkkihuolto pääse aina helposti tutkimaan auton kaikkia moduuleita. (Rleale 2009) 6.3 Yhteyden luominen Moduuleihin on yleisesti mahdollista luoda yhteys OBD2-portin kautta. Mahdollisia tapoja yhteyden muodostamista tapoja on monia. Selvästi suosituin on muuttaa tiedonsiirtonopeutta (Baudrate) tai muuttamalla lukijalaitteen tunnistetta (header). Nykyaikaiset lukijalaitteet pystyvät vaihtamaan käytön aikana tiedonsiirtonopeutta tai tunnistetietoja. Yhteyden luominen on mahdotonta, jos ei tiedä autonkohtaista oikeaa tapaa miten moduuleihin yhdistetään. (Elm Electronics Inc. 2010, 35-37) 29 7 ELMOSCAN Opinnäytetyön projekti osuutena oli kehittää ElmoScan ohjelmistoon mahdollisuuden hakea ja yhdistää tietyntyyppisesti esiintyviin moduuleihin. ElmoScan ohjelmisto on ohjelmoitu Delphi:llä. Tässä projektissa käytettiin alkuperäisiä lähdekoodeja mahdollisimman vähän muokaten. Tällä yritetään välttää sekoittamasta ohjelmiston muita toimintoja. Projektissa ohjelmoitiin uusi ElmoScan versio. ElmoScan on täysin suomalainen ohjelmisto. Ohjelmisto on kehitetty autoissa käytetyn OBD2-järjestelmän ympärille. ElmoScanin kosketusnäytölle suunniteltu käyttöliittymä tarjoa monelle innokkaammalle käyttäjälle kiinnostavan ympäristön. 7.1 Historia ElmoScanilla on jo huomattavan pitkä historia, jonka aikana kehitystä on tapahtunut huomattavan paljon ja useita versioita on tullut. Versioita on julkaistu lähes vuosittain. ElmoScan oli historiansa alkuaikoina omalla alueellaan edelläkävijä ja kilpailijoitaan monella tavalla edistyneempi. Hyvinä esimerkkeinä voidaan pitää kiihdytysmittauksia, tiedonkeruuta ja auton tehomittauksen ominaisuuksia. Nykyisin monelta kilpailijalta löytyy vastaavia ominaisuuksia omistaan ohjelmistoistaan. ElmoScan ohjelmiston kehitystyö on aloitettu Porissa ja ohjelmiston omistajuus on historiansa aikana kokenut muutaman eri omistajan vaihdoksen. Nykyisenä kehityksestä ja omistajuudesta vastaa porilainen Softator Oy, joka on tämän opinnäytetyön asiakasyritys. 30 7.2 OBD2-ohjelmistojen nykytilanne Nykytilanteessa ohjelmistojen kehitys alkaa olla sillä tasolla, että ohjelmistoista on todellista hyötyä vaativimmallekin käyttäjälle. OBD2-ohjelmistot ovat päässeet käsiksi jo huomattavaan määrään päätekomentoja ja moduuleita. Tämä on selvästi myös huomattavissa kehityksen kiristymisessä ja isompien ohjelmien kehitystyöstä. Muutama vuosi takaisin oli aivan turha haaveilla yksityiskäytössä kehittyneemmästä ohjelmasta. Kehittyneemmällä ohjelmalla tarkoitetaan ohjelmaa, joka on kehitetty toimimaan usealla automerkillä ja samalla pystyy tarjoamaan tietylle autonmallille kehittyneempiä komentoja. Kehittyneemmät komennot antavat huomattavan määrän enemmän tietoa verrattuna OBD2järjestelmän sisältämiin perinteisiin komentoihin. Kehittyneempiä ohjelmia saattoi olla aikaisemmin tarjolla mutta, yksityishenkilölle hinnat olivat liian kalliit, joten vain isommilla yrityksillä oli mahdollisuus hankkia kehittyneempiä ohjelmia. Tilannetta hankaloittaa markkinoiden hidas kehittyminen. Tällä hetkellä markkinoilta löytyy useita eri ohjelmistoja ja uusia ilmestyy useita vuoden aikana. Eräitä OBD2-ohjelmistoja löytyy taulukosta 2. Taulukko 2. Esimerkkejä OBD2-ohjelmistoista. Ohjelmisto Kehittäjä ScanXL Palmer Performance Engineering Inc. OBDwiz OCTech, LLC CarMM CarMM Digimoto PerformanceScan, LLC 7.3 ElmoScan ohjelmistoon tutustuminen ja työn etenemisaikataulu ElmoScan ohjelmistoon ennakkoon tutustuminen auttoi huomattavasti ohjelmointi opinnäytetyöprojektin edistymistä. Samalla tutustuminen selvensi miten ohjelmiston lähdekoodia oli aikaisemmin rakennettu ja kehitetty. 31 ElmoScanin lähdekoodiin ymmärtämiseen menee huomattava määrä aikaa. ElmoScan ohjelmistossa on jo yli 10 000 riviä lähdekoodia. Lähdekoodi on jäsennelty hyvin omiin osa-alueisiin, jotka helpottavat tulevaisuudessakin ohjelmiston kehittämistä. Ohjelmisto on rakennettu hyväksymään uusia moduuleita, vaikka itse pääohjelman lähdekoodia ei muokattaisi. Ennen varsinaista opinnäytetyön aloittamista tuli tutustua laajalti OBD2järjestelmän toimintaan ja käyttäytymiseen. OBD2-järjestelmän tutustuminen aloitettiin hyvissä ajoin ennen varsinaisen työn tekemistä. Tutkimustyöhön kului yllättävän paljon aikaa, koska laadukkaiden lähteiden etsimiseen ja tulkintaan kului huomattavasti aikaa. Laajan selvitystyön jälkeen oli välttämätöntä tutustua tässä opinnäytetyössä käsiteltävään ohjelmistoon (ElmoScan). ElmoScan on toteutettu Delphi-ohjelmointikielellä, jonka ymmärtäminen ja tulkitseminen vaativat asiaan paneutumista ja sisäistämistä. Ohjelmointikieleen helpotti ElmoScan lähdekoodien runsas läpikäynti ja lähdekoodissa olevat kommentoinnit. Delphi-ohjelmointikieli on tyypillinen Pascal-kieleen perustuva ohjelmointikieli jolloin sitä on helppo tulkita ja ymmärtää. Ymmärtämistä edes auttaa lähdekoodin toiminnan ja syntaksien tarkoituksen täydellisesti. Opinnäytetyön vaativampi osuus oli tuoda nykyiseen ElmoScan- ohjelmistoversioon tutkimustyön aikana selvitetyt menetelmät ja halutut toiminnot. Esimerkkinä näistä toiminnoista löytyy luvusta 6. Uusien toimintojen käyttöönottamiseen vaaditaan huomattava määrä lähdekoodin kirjoittamista ja olemassa olevan koodiin sovittamista. Kehitetyt lähdekoodit tulee toimia vanhan ElmoScanin-ohjelmiston lähdekoodin kanssa yhteen ongelmitta. Uuden lähdekoodin kirjoittamiseen kuluu huomattavasti vähemmän aikaa, kuin sen toiminnallisuuden selvittämiseen. Tutkimustyön ja ohjelmoinnin lisäksi tulee tehdä kaiken kattava testaustyö Elmoscan-ohjelmiston toimivuudesta. Uusien ominaisuuksien ja toimintojen käyttäminen ei saa haitata vanhojen ominaisuuden toimivuutta. Uusien ominaisuuksien integroiminen nykyisiin toimintoihin voi johtaa ongelmallisiin tilanteisiin. Näiden ongelmien selvittäminen ja korjaaminen saattaa vaatia uusien 32 ratkaisujen kehittämistä. Uusien ominaisuuksien toiminta tulee perusteellisesti testata, koska se paljastaa ohjelmistossa olevat mahdolliset ongelmakohdat. Tämä testaus laajennetaan koko ElmoScan-ohjelmistoon, jolloin saadaan selvitettyä mahdolliset ongelmakohdat ja niiden nopealla korjaamisella pystytään vaikuttamaan ennen ohjelmiston uuden version julkaisemista. 7.4 Tavoitteet Opinnäytetyöllä oli alusta asti selvät päätavoitteet. Tavoitteena oli selvittää mahdollisia tapoja luoda yhteys tietyllä tavalla esiintyviin auton OBD2moduuleihin. Tavoitteessa huomioitiin luvun 6 sisältö, josta käy ilmi, ettei moduuleihin yhdistämiseen ole yhteistä tapaa. Kattavan selvitystyön jälkeen oli tarkoitus saavuttaa toinen päätavoitteista, eli ElmoScan projektiin liittyvä ohjelmointi. Ohjelmointityön tavoitteena oli kehittää uusi versio nykyiseen ElmoScan ohjelmistoon. Uuden version tarkoituksena on mahdollistaa tietyntyyppisten moduulien hakemisen. Samalla mahdollistamaan tapa, jolla luodaan yhteys löydettyihin moduuleihin. Tapauksissa jossa useampia moduuleita ei löydy, niin sen ominaisuutta ei saa hyödyntää jolloin sen toimiminen tulee olla estettynä. 7.5 Moduulien hakeminen Moduulien hakemisesta ohjelmointiin täysin oma proseduurinsa EcuSearch. Proseduurin ansiosta moduulien haku helpottuu jatkossa huomattavasti. Proseduurista on hyötyä, jos moduuleita pitää hakea uudestaan tai mahdollisesti päivittää listauksen haetuista moduuleista. Tämän opinnäytetyön liitteenä 1 on moduulien hakemisesta toteutetun proseduurin lähdekoodi. Lähdekoodi havainnollistaa muutettavia asetuksia ja vaadittavia toimenpiteitä eri protokollien välillä. 33 7.6 Selvitystyön aikaiset ongelmat Projektin aikaisien ongelmatilanteiden selvittämiseen auttoi huolellinen selvitystyö ja ajan kanssa asioiden huolellinen tutkiminen. Tarkempien tutkimuksien jälkeen alkoivat ongelmatilanteet lähes aina selvitä ja mahdollisten ratkaisujen löytäminen alkoi kehittyä. Tässä työssä esitellyn selvitystyön aikana kohdattiin kaksi merkittävää ja isoa ongelmaa. Selvitystyön haasteellisimmaksi ongelmaksi ilmeni luotettavan tiedon hankinta. Hyvät lähteet olivat lukijalaitteiden piirisarjojen valmistajien yleiset dokumentaatiot. Dokumentaatioissa oli selkokielisesti selitetty lukijalaitteiden toiminnallisuus ja ohjeistettu komentojen toimintaa. Toisena erityisen haasteellisena ongelmana oli terminaali ohjelmiston, eli HyperTerminaalin liian hidas tiedon vastaanottonopeus. Liian hidas tiedon vastaanottonopeus kadottaa osan vastauksessa olleista tärkeistä riveistä. Ongelma ratkaistiin tekemällä terminaalityyppinen apuohjelma, joka osaa ottaa tarpeeksi nopeasti tietoa vastaan, eikä kadota yhtään riviä välistä. 7.7 Ohjelmoinnin aikaisia ongelmatilanteita Varsinaisen ohjelmoinnin aikana ilmeni useita erityyppisiä ongelmia. Lähes jokaiseen ongelmaan löytyi ratkaisu tutkimalla suoritettua lähdekoodia. Käytetyn ohjelmiston breakpoint-toiminnon avulla oli helppo seurata mihin ohjelma todella pysähtyi. Projektin ohjelmointi tapahtui Delphi-ohjelmointikielellä. Delphin tarjoamat työkalut toimivat hyvin lähdekoodin seuraamisessa ja mahdollistivat suorituksen aikaisen lähdekoodin seuraamisen. Ohjelma osaa kertoa, myös mihin suorittaminen pysähtyi ja samalla antaa mahdollisen virheenkuvauksen. Virheenkuvauksen tulkitsemisen jälkeen tiedossa oli virheen todellinen aiheuttaja tai mistä virhe saattaisi johtua. 34 ElmoScanin lähdekoodin suorittamisen aikaista seuraamista hankaloittaa ohjelmiston lähdekoodin tiedostorakenteessa olevat useat tiedostot. Ohjelmisto on rakennettu modulaariseksi, joten siihen saa helposti lisättyä uusia ominaisuuksia. Tämäntyyppisellä tiedostorakenteella on tietenkin huomattava määrä hyötyä. Tämän ohjelmointiprojektin alussa kun saatiin ensimmäiset kokeilut suoritettua tuli heti vastaan ongelma, joka ilmeni vain tietyissä tilanteissa. Alkuperäisessä ElmoScan versiossa poistettiin automaattisesti tietoa tapauksissa, joissa ilmeni turhaa tietoa. Turha tieto ilmeni OBD2-järjestelmästä tulevasta ”SEARCHING”-tekstistä. Kaikki vastaanotetut tiedot lisättiin taulukkoon ja taulukosta otettiin talteen vain korkein luku eli aina viimeinen osio. Alkuperäinen tapa tietenkin toimii, mutta jos tarvittiin ainoastaan yhden moduulin vastausta. Alkuperäinen menetelmä ei toiminut, jos moduuleita oli enemmän kuin yksi moduuli. Tällöin taulukko otti vain korkeimman arvon eli viimeisen moduulin tiedot ja hävitti muiden moduulien tiedot automaattisesti. if (Pos('SEARCHING',s_ResponseFull) > 0) then begin b_isHexData := True; Log('RemovingSearchText'); HajoitaRivi(ar_Rows,s_ResponseFull,c_DELIMITER); s_ResponseFull := ''; for i := 1 to High(ar_Rows) do begin //for lausekkeella korjattiin ongelma tilanteet s_ResponseFull := s_Responsefull + ar_Rows[i] + c_DELIMITER; end; for i_Counter := 1 to Length(s_ResponseFull) do begin if (b_isHexData) then b_isHexData := isHexDigit(s_ResponseFull[i_Counter]); end; end; Koodi 1. Searching-tekstin poistaminen ja kaikkien moduulien tietojen lisääminen. Koodin 1 mukaisen korjauksen kehittäminen oli alkuperäisen mallin mukaan helppo korjata. Eli tehdä samantyyppisesti toimiva taulukko, mutta talteen otettaan muitakin arvoja. Taulukkoon ei lisätty ensimmäistä arvoa, vaan kaikki muut arvot lisättiin taulukkoon. Tällöin ensimmäinen arvo eli ”SEARCHING”-teksti saatiin pois ja samalla saatiin talteen kaikkien muidenkin moduulien tiedot. 35 Ohjelmointityön edistyessä ilmeni uusia ongelmia, jotka pysäyttivät ohjelman suorittamisen täydellisesti. Näitä ilmeni tilanteissa, jossa käyttäjä pääsi valitsemaan moduulin mihin haluaa yhdistää ja tämän jälkeä lukea vikakoodeja. Ongelmaksi tuli jo olemassa olevan koodin aiheuttamat tiukat rajoitteet. Koodissa 2 päätekomennolla 0101 pyydetään tietoa. Muuttujaan (s_Temp) kerätään aina kuuden merkin merkkijono. Vanhalla koodilla tuli tietoa kerättäessä muuttujaa tallennettiin 'ERR_NO', joka lopetti ohjelmiston suorittamisen. Korjauksena toimintoa muutettiin vaihtamaan muuttujan sisällöksi ”000000”, Tämä korjasi tilanteen jossa 0101 ei saa oikean tyyppistä vastausta lainkaan. s_Temp := ''; if (s_Data[i_i] = c_DELIMITER) then inc(i_i); for i_j := 1 to 6 do begin s_Temp := s_Temp + s_Data[i_i]; Inc(i_i); end; if s_Temp = 'ERR_NO' then S_Temp := '000000'; //käytetty korjaus Koodi 2. Vääräntyyppinen vastaus. Ohjelmointityön loppuvaiheessa suoritetussa testauksessa ja toimivuus tarkistuksessa tuli vastaan ongelmatilanne, joka vaati uuden toimivan ratkaisun kehittämiseen. Käyttäjä ei saa valita moduulia kaikissa suoritettavissa toiminnoissa, kuten katsastusraporttia tehtäessä. Jos estoa moduulin valintaan ei olisi, niin moduulin yhdistämisellä saatettaisiin pystyä vaikuttamaa katsastusraporttiin tulokseen. 7.8 Saavutetut hyödyt Projektilla saavutetut hyödyt ovat ohjelmiston kannalta erittäin tärkeitä ja edistyksellisiä. Ohjelmiston uudella versiolla tullaan jatkamaan ElmoScan ohjelmiston kannalta tärkeää kehitystyötä, joka takaa ohjelmiston tulevaisuuden jatkumisen. Ohjelmiston uuden version julkaiseminen ja käyttöönottaminen on ollut projektin yhtenä päätavoitteena. Uuden version päätavoitteena on 36 tuoda lisäarvoa ohjelmalle ja samalla kehittää sitä vastamaan paremmin nykyisten kilpailijoiden tuotteita. Uuden ElmoScan version myötä markkinoille saadaan kokonaan isompi uudistus, joka houkuttelee asiakkaita lisää tai mahdollisesti vanhoja asiakkaita päivittämään uudempaan julkaisuun. Uuden version on tietenkin, myös tarkoitus parantaa ohjelmiston luotettavuutta ja samalla laajentaa sitä. 7.9 Tulevaisuuden näkymät ElmoScan-ohjelmiston tulevaisuuden näkymät, ovat edelleen hyvin positiiviset, koska Suomesta tällä hetkellä kilpailijoiden tuotteita ei löydy. Vahvuutena on tarjota täysin suomalaisten kehittämä tuote, joka tarjoaa kehittyvän ohjelmiston käyttäjilleen. Kaikki käyttäjät eivät ole tottuneet käyttämään tietokoneita tai englanninkielisiä ohjelmia. Muun muassa suomenkielisyyden vuoksi ElmoScan-ohjelmisto on todella hyvässä markkina-asemassa. 37 8 POHDINTA Tämän opinnäytetyöprojektin kokonaisuuden hahmottamiseen ja toteuttamiseen kuluva aika tuntui kasvavan huomattavan pitkäksi. Varsinkin ympäristössä, jossa kehitystyötä pitää tapahtua samalla, kun yritti viimeistellä opinnäytetyötä. Tietenkin kehitystyö opettaa samalla lisää OBD2-järjestelmästä ja samalla saa lisää ymmärrystä ohjelmistotuotannosta. Pelkästään OBD2järjestelmään tutustumiseen tuntui menevän erittäin paljon aikaa mitä voisi odottaa. Hyvä ymmärtäminen OBD2-järjestelmän toiminnallisuudesta ja käytännöstä tuo huomattavan avun tämän opinnäytetyön kirjoittamiseen ja ElmoScan-ohjelmiston kehitystyöhön. Haasteellisuutta aiheuttaa selvästi heikosti käytössä oleva informaatio tai sen lähes mahdoton tulkinta. Luotettavat ja laajat lähteet, jotka sisältävät tarkempaa informaatiota OBD2-järjestelmän toiminnasta on vaikeasti saatavilla tai mahdotonta saada käyttöönsä järkevään hintaan. OBD2-järjestelmästä varmasti pystyisi keräämään lähes loputtomasti tietoa, jos olisi kaikki lähteet vapaasti saatavilla kaikille kiinnostuneille. Ohjelmointiprojektin tekemisen haasteellisuus on tietenkin aina mielenkiintoa nostava tekijä minulle, koska olen hyvin kiinnostunut ohjelmistotuotannosta. Ongelmia tuli tässä projektissa dokumentaation puutteesta koska yksinkertaistakin toiminnallisuutta joutui pelkän lähdekoodin avulla selvittämään pitkään. Lähdekoodia on helppoa tulkita, mutta monimutkaisuutta ei aina välttämättä heti oivalla. Tietenkin isomman lähdekoodi kokonaisuuden toimivuuden ymmärtäminen tuo edistymisen tunnetta ja varsinkin kun samalla saa yhdistettyä siihen oma kirjoittamaa lähdekoodia. Lopullisen lähdekoodin viimeistely ja toimivuuden testaaminen tuo tullessaan mukavan lisän projektin loppuun viemisessä varsinkin kun kyseessä on kaupallinen tuote. 38 LÄHTEET AKE 2007. Ottomoottorikäyttöisten ajoneuvojen pakokaasupäästöjen tarkastus. Viitattu 18.10.2010. Saatavissa: http://www.ake.fi/NR/rdonlyres/D9364707-6D5B-4477-A43B186DCCC91403/0/11912082007.pdf. California Air Resources Board 2009. Transitioning Away from Smog Check Tailpipe Emission. Viitattu 27.9.2010. Saatavissa: http://www.arb.ca.gov/msprog/smogcheck/march09/transitioning_to_obd_onl y_im.pdf. Elm Electronics Inc. 2010. ELM 327 - OBD to RS232 Interpreter. Viitattu 22.10.2010. Saatavissa: http://www.elmelectronics.com/DSheets/ELM327DSF.pdf. Ford Motor Company 2007. 2001 MY OBD System Operation Summary for Gasoline Engines. Müller, Gerhard 2005. Diagnostiikkaa EOBD-liitännällä. Prosessori 9, 42-45. OBD Automotive Oy 2007. EOBD, OBD2 ja valmistajakohtaiset protokollat. Viitattu 22.9.2010. Saatavissa: http://www.obd.fi/index.php?option= com_content&task=view&id=32&Itemid=2. Omitec Limited. EOBD - A detailed history. Viitattu 12.10.2010. Saatavissa: http://www.omitec.com/en/support/technology-briefs/detailed-history-ofeobd/. Rleale. ‘OBDII and Enhanced Diagnostics Again’. canbushack: Hack Your Car. 13.12.2009. Viitattu 14.10.2010. Saatavissa: http://www.canbushack.com/blog/index.php/2009/12/13/obdii-and-enhanceddiagnostics-again. 39 SAE International 1997. On-Board Diagnostics for Light and Medium Duty Vehicles Standards Manual HS-3000. Pennsylvania USA. Seyfert, Karl 2007. OBD2 generic pid diagnosis. Viitattu 2.10.2010. Saatavissa: http://findarticles.com/p/articles/mi_qa3828/is_200709/ ai_n21033507 . LIITELUETTELO LIITE 1 EcuSearch Proseduuri LIITE 1 procedure Tfrm_Menu.EcuSearch; //Header päälle & Ecu talteen var s_ResponseFull, s_Protocol: String; i,i_EcuPos,i_EcuSync,I_EcuCopy,I_EcuTunniste: Integer; begin Log('Header on'); cport_main.WriteStr('ath1' + #13); //Headerit ReceiveData(cport_main,s_ResponseFull,'ath1'); cport_main.WriteStr('ATDPN' + #13); //Protokolla ReceiveData(cport_main,s_ResponseFull,'0100'); s_Protocol := s_ResponseFull; cport_main.WriteStr('0100' + #13); //Tiedot ReceiveData(cport_main,s_ResponseFull,'0100'); i := 0; SetLength(ar_ecus, i+1); if (s_Protocol = 'A6') or (s_Protocol = '6') or (s_Protocol= 'A8') or (s_Protocol = '8') then begin //11BIT i_EcuPos := 0; i_EcuSync :=0; i_EcuCopy :=3; i_EcuTunniste :=1; end; if (s_Protocol = 'A1') or (s_Protocol = '1') or (s_Protocol = 'A2') or (s_Protocol = '2') or (s_Protocol = 'A3') or (s_Protocol = '3') OR (s_Protocol = 'A5') OR (s_Protocol = '5') then begin //PWM,VPW,ISO9141-2,ISO,14230-4 i_EcuPos := 5; i_EcuSync := 3; i_EcuCopy := 2; i_EcuTunniste :=2; end; if (s_Protocol = 'A7') or (s_Protocol = '7') or(s_Protocol = 'A9') or (s_Protocol = '9') then begin // 29BIT ISO15765-4 i_EcuPos := 7; i_EcuSync := 5; i_EcuCopy := 2; i_EcuTunniste :=3; end; ar_ecus[i] := copy(s_Responsefull, i_EcuPos, i_EcuCopy); if AnsiPos(c_Delimiter,s_ResponseFull) > 0 then begin //jos löytyy ecuja niin käsitellään. Log('EcuHeaderResponse' + s_Responsefull); while AnsiPos(c_Delimiter,s_ResponseFull) > 0 do begin i := i+1; SetLength(ar_ecus, i+1); i_EcuSync := AnsiPos(c_Delimiter,s_ResponseFull); delete(s_Responsefull, 1, i_EcuSync); //poistetaan lisätyt ar_ecus[i] := copy(s_Responsefull, i_EcuPos, i_EcuCopy); //ecut lisätään arrayhyn ennen poistoa end; for i :=0 to High(ar_ecus) do begin ar_ecus[i]:= IntToStr(i_EcuTunniste) + ar_ecus[i]; end; Log('EcusResponsed' + ' Ecu1: ' + ar_ecus[0]+ ' Ecu2: ' + ar_ecus[1]+ ' Ecu3: ' + ar_ecus[2]); end; //Otetaan header pois päältä ReadTimeoutReset; Log('Header is on, disabling'); cport_main.WriteStr('ath0' + #13); ReceiveData(cport_main,s_ResponseFull,'ath0'); end;
© Copyright 2025