Konzipierung und Implementierung von automatisiertem WLAN
Transcription
Konzipierung und Implementierung von automatisiertem WLAN
Fachbereich Informatik Bachelorarbeit Konzipierung und Implementierung von automatisiertem WLAN–Verbindungsaufbau im KFZ Dirk Andres Matrikelnummer: 646066 Darmstadt, 17. Oktober 2005 Betreuende Professoren: Prof. Dr. Joachim Wietzke Prof. Dr. Klaus Kasper Inhaltsverzeichnis 1. Einleitung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.1 Motivation der Bachelorarbeit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.1.1 Konventionelle WLAN–Szenarien . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.1.2 Neue Möglichkeiten und Einsatzgebiete . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.2 Aufbau der Bachelorarbeit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.3 Inhalt der beigefügten CD–ROM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 2. Einführung in die WLAN–Technologie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 2.1 WLAN–Standards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 2.2 Einordnung der WLAN–Technologie im ISO OSI Schichtenmodell . . . . . . . . . . . . . . . 6 2.3 Infrastrukturmodi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.3.1 Infrastruktur–Modus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.3.2 Ad–hoc–Modus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 2.4 SSID und BSSID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 2.5 Sicherheit im WLAN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 3. Anforderungen an WLAN–Lösungen im KFZ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.1 Wahl und Integration geeigneter Hardware . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.2 Übersichtliche grafische Anwendungsrealisierung . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.3 Spezifizierung der WLAN–Konfiguration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 3.4 Konfliktfreier Wechsel der Betriebsmodi und zustandsabhängige Benutzerinteraktion 12 3.4.1 Automatisierte IP–Adressvergabe . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 3.4.2 Zustandsabhängige Verbindungsvisualisierung . . . . . . . . . . . . . . . . . . . . . . . 13 3.5 Dynamischer Verbindungsaufbau . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 4. Verifizierung vorhandener Connection Manager Lösungen . . . . . . . . . . . . . . . . . . . . . 15 4.1 Übersicht . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 4.2 Der Pocket PC 2003 Connection Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 4.2.1 Aufwandsbetrachtung im Infrastrukturszenario . . . . . . . . . . . . . . . . . . . . . . . 16 4.2.2 Aufwandsbetrachtung im Ad–hoc–Szenario . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4.3 Zusammenfassende Bewertung für den Einsatz im KZF . . . . . . . . . . . . . . . . . . . . . . . 18 ii 5. Vorbetrachtungen im allgemeinen WLAN–Szenario . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 5.1 Notwendigkeit einer individuellen Softwarelösung . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 5.2 Programmiersprache und Entwicklungsumgebung . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 5.3 Anmerkungen zur Implementierung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 5.4 Grundlegende Konzipierungsüberlegungen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 5.5 Die Wireless Zero Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 5.6 802.11–Netzwerktreiber–Architektur und NDIS USER MODE I/O PROTOCOL . . . . . 24 5.6.1 802.11–Netzwerktreiber–Architektur . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 5.6.2 Implementierungsaspekte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 5.6.3 Wireless Research API (WRAPI) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 6. WLAN–Verbindungsaufbau im Ad–Hoc–Szenario . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 6.1 IP–Adressen–Problematik und Lösung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 6.1.1 Bewertung konventioneller Verfahren zur IP–Adressvergabe . . . . . . . . . . . . 29 6.1.2 Abwandlung von APIPA durch Registrierungsmanipulation . . . . . . . . . . . . . . 30 6.1.3 IP–Adresszuweisung mittels IPHelper Funktionen . . . . . . . . . . . . . . . . . . . . . 34 6.2 Adapterkonfiguration über das NDISUIO–Protokoll . . . . . . . . . . . . . . . . . . . . . . . . . . 36 6.2.1 Setzen des Infrastrukturmodus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 6.2.2 Setzen des Authentifizierungsmodus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 6.2.3 Setzen der SSID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 6.3 Netzwerkscan und dynamischer Verbindungsaufbau . . . . . . . . . . . . . . . . . . . . . . . . . 42 6.4 Integration einer 3rd Party VOIP–Anwendung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 6.4.1 Voraussetzungen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 6.4.2 Implementierung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 6.4.3 Testdurchführung und Bewertung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 7. WLAN–Verbindungsaufbau im Infrastruktur–Szenario . . . . . . . . . . . . . . . . . . . . . . . . 48 7.1 Adapterkonfiguration über das NDISUIO–Protokoll . . . . . . . . . . . . . . . . . . . . . . . . . . 48 7.2 Dynamischer Verbindungsaufbau . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 7.3 Integration einer Informationsanwendung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 8. Anmerkungen zur Entwicklung unter Windows XP . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 8.1 NDISUIO–Schnittstellendefinition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 8.2 Enumeration der WLAN–Adapter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 8.3 Assoziation des Adapters mit dem NDISUIO Handle . . . . . . . . . . . . . . . . . . . . . . . . . 57 iii 9. Prioritätsgesteuerter WLAN–Verbindungsaufbau . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 9.1 Motivation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 9.2 802.11–Netzwerkscan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 9.3 Implementierung eines BSSID List Scans . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 9.4 Verwertung der gesammelten Geräteinformationen . . . . . . . . . . . . . . . . . . . . . . . . . . 64 10. WLAN–Integration eines Embedded Automotive Frameworks unter QNX . . . . . . . . . 67 10.1 Systembedingte Voraussetzungen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 10.2 Realisierung mittels WLAN–Karte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 10.2.1 Verbindungsaufbau mittels Systembefehlen . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 10.2.2 Integration der Systemkommandos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 10.2.3 Verbindungsaufbau mittels DeviceControl–Zugriffen . . . . . . . . . . . . . . . . . . . . . 73 10.3 Realisierung mittels Ethernet–WLAN–Bridge . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 10.3.1 Beschaffenheit der Netzwerkgeräte und Integration in das bestehende Kabelnetzwerk . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 10.3.2 Interface–Bridging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 10.3.3 Konfiguration des Access Points . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 10.3.4 Konfiguration der Ethernet–WLAN–Adapter . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 10.3.5 Dynamische IP–Adresszuweisung für Endgeräte . . . . . . . . . . . . . . . . . . . . . . . 77 10.4 Verbindungsgesteuerte Client–Server–Kommunikation . . . . . . . . . . . . . . . . . . . . . . . . 78 11. Ergebnis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 11.1 Zusammenfassung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 11.2 Bewertung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 11.3 Ausblick . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 A Abbildungsverzeichnis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 B Screenshots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 C Listings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 D Quellenverzeichnis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87 E Eigenständigkeitserklärung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 iv 1. Einleitung 1.1 Motivation der Bachelorarbeit Die WLAN-Technologie erstreckt sich heutzutage auf viele Bereiche unseres Alltages. Dabei werden längst nicht alle Möglichkeiten dieser Technologie genutzt. Ziel der vorliegenden Arbeit ist es, denkbare WLAN–basierte Szenarien und Lösungen von praktischer und softwaretechnischer Seite zu beleuchten. 1.1.1 Konventionelle WLAN–Szenarien Das Hautpeinsatzgebiet von WLAN–Lösungen beschränkt sich bisher weitgehend auf privat installierte Access Points, zu denen ausschließlich mit dem eigenen Laptop oder PC verbunden wird. Die Konfiguration der Geräte erfolgt im Idealfall einmal, was den Anwender in vielen Fällen schon einiges an Zeit und Geduld kosten kann. Der Vorteil der WLAN–Technologie wird hierbei in der kabellosen Installation gesehen. Lästiges Kabelgewirr oder Wanddurchbrüche gehören der Vergangenheit an. Auch die Internetanbindung des Laptops aus dem heimischen Garten kann begeistern. Die Einsatzgebiete dieser sich immer weiter etablierenden Technologie sind dabei jedoch bei weitem nicht ausgenutzt. Tausende von Tank– und Raststättenbetreiber haben diesen Gedanken bereits aufgegriffen und WLAN Basisstationen installiert. Gegen Bezahlung steht es dem Kunden frei mit eigenen Systemen ins Internet zu gehen. Die Einrichtungsarbeit bleibt dem Anwender selber überlassen. Innovative Nutzungsmöglichkeiten wurden bisher jedoch nicht umgesetzt. 1.1.2 Neue Möglichkeiten und Einsatzgebiete Die bereits eingerichteten Netzwerkschnittstellen könnten einen zentralen Einstiegspunkt in ein weiteres, viel versprechendes Anwendungsgebiet ermöglichen: Der Einsatz von WLAN– Anwendungen im KFZ. Viele Leute besitzen bereits heute das nötige Equipment: Ein WLAN–fähiger Laptop, ein handelsüblicher PDA oder ein Handy, welches mit Festplatte und Wireless–LAN–Adapter ausgerüstet ist. Der Einsatz eines Softwaremoduls, welches über die Möglichkeit verfügt, spezifische WLAN–Profile zu verwalten und je nach Bedarf Netzwerkanbindungen anzustreben, erschließt eine Vielzahl von realisierbaren Szenarien. Ein Beispiel wäre das Angebot eines digitalen Bonusprogrammes. Beim Anfahren einer Tankstelle wird automatisiert eine -1- Einleitung Verbindung zu einem Tankstellenserver hergestellt, welcher den Besuch registriert und den treuen Kunden mit digitalen Prämien, wie mp3s oder Spielen, beschenkt. Werbespots oder Angebotsinformationen weisen den Kunden auf Sonderaktionen im Tankstellenshop hin. Selbst das Bezahlen über digitale Zertifikate könnte realisiert werden. Hierbei verbindet sich das Programm eigenständig mit der benutzen Zapfsäule, welche die getankte Benzinmenge in Rechnung stellt und von dem entsprechenden Konto abbucht. Befindet sich das Kraftfahrzeug wieder auf der Straße ist es mit einer Anwendung möglich mit anderen Fahrern per WLAN–Telefonie zu kommunizieren. Über die vollständige Automatisierung ist ein Voice over IP Telefonat ohne Aufmerksamkeitsdefizit möglich. Die Anwendung ließe sich weiterhin auf In Car Systeme ausweiten. Beim Besuch einer Werkstatt werden gespeicherte Daten genutzt um Wartungsarbeiten einzuplanen und Angebote einzuholen. Softwareupdates werden bei Bedarf drahtlos und ohne Wartezeit installiert. 1.2 Aufbau der Bachelorarbeit Nach einer kurzen technischen Einführung in die WLAN–Technologie werden grundlegende Anforderungen an den Verbindungsaufbau im KFZ erarbeitet. Danach folgt die Betrachtung einer systemeigenen Software unter PocketPC 2003 zur Verbindungsverwaltung nach erstellten Kriterien. Eine abschließende Bewertung weist auf Schwachstellen des Programms im Bezug auf den Einsatz in einem Kraftfahrzeug hin und motiviert für den Einsatz einer individuell erstellten Software. Der Kernteil der Arbeit beleuchtet den automatisierten WLAN–Verbindungsaufbau im KFZ aus verschiedenen Perspektiven. Auf einem Handheld unter PocketPC 2003 wurde eine Software entwickelt, welche versucht den gestellten Anforderungen gerecht zu werden. Gesammelte Erfahrungen bei der Auseinandersetzung mit der WLAN–Technologie boten Eckpfeiler der Konzipierungsüberlegungen. Die WLAN–Treiber–Architektur und das NDISUI–Protokoll dienen als Grundlage für die Implementierung des Verbindungsaufbaues in verschiedenen Betriebsmodi. Automatisierte IP–Adresszuweisung im Ad–hoc–Netzwerk und die Suche nach verbundenen Geräten bilden eine weitere Komponente einer erfolgreichen Netzwerkkommunikation und werden ausführlich an Hand von Quelltextauszügen vorgestellt. Danach werden ausgesuchte Anwendungsszenarien und ihre Softwareumsetzung fokussiert. Nach grundlegenden Anmerkungen zur Implementierung unter Windows XP und variabler Hardware geht die Arbeit auf Aspekte des prioritätsgesteuerten WLAN–Verbindungsaufbaus ein. Hierbei werden Informationen verfügbarer drahtloser Netzwerke ausgelesen und verwertet. -2- Einleitung Die Anwendung wählt selbsttätig zwischen vorhandenen Alternativen in Abhängigkeit von Signalstärke, Infrastrukturmodus oder Netzwerkkennung. Vorliegende Arbeit wendet sich nun einer Plattform zu, welche ausschließlich für den Einsatz in einem Kraftfahrzeug konzipiert wurde. Es handelt sich hierbei um ein Embedded Automotive Framework unter dem echtzeitfähigen Betriebssystem QNX 6.3. Dieses zeichnet sich durch einige systembedingte Besonderheiten aus. Da WLAN–Treiber und systemeigene Verwaltungsmöglichkeiten kaum vorhanden sind, nimmt sich die Abhandlung im Weiteren den aufgetretenen Problemen und Lösungsansätzen im Bezug auf die drahtlose Netzwerkanbindung an. Die Integration von WLAN–Karten wird ebenso berücksichtigt wie die Anbindung externer Ethernet–WLAN–Brücken. Softwaregesteuerte Konfiguration und Verbindungserkennung steht bei der Betrachtung im Vordergrund. Ebenso wird ein Anwendungsszenario entworfen, welches auf einer automatisierten Client– Server–Kommunikation basiert. Die Arbeit bemüht sich die vorgestellten Sachverhalte verständlich von allgemeinen Grundlagen bis hin bis zu sehr speziellen Aspekten, die für die Implementierung relevant sind, zu beleuchten. Da das Thema einen sehr starken Praxisbezug aufweist und vorgestellte Ideen bereits im Vorfeld realisiert Anmerkungen zur wurden, kann das vorliegende Implementierungstechnik und Manuskript den durch beigefügten, umfangreiche kommentierten Quelltextauszügen als Einführung und Leitfaden in die Implementierung softwaregesteuerter WLAN–Adapterkonfigurationen, speziell unter Windows, Verwendung finden. 1.3 Inhalt der beigefügten CD–ROM Auf der beigefügten, selbstständig startenden, CD–ROM befindet sich eine HTML Version der vorliegenden Arbeit. Querverweise sind mit Hyperlinks zu den betreffenden Stellen versehen. Ebenso werden Verweise auf Software und Quelltexte, welche in den Kapiteln Erwähnung finden, eingebunden. Diese Softwaresektion enthält frei verfügbare Programme für den Einsatz auf PocketPC 2003, Windows XP und QNX. Einige Programme liegen zusätzlich in Form von Quelltexten vor. Weiterhin sind der vollständige Quelltext und eine kompilierte Version der eigens entwickelten Software gespeichert. Dies beinhaltet ein Programm zur automatisierten WLAN Verbindungsherstellung unter PocketPC 2003, welches für den HP iPAQ 5500 entwickelt wurde, weiterhin eine Software, welche sich mit dem hardwareunabhängigen, prioritätsgesteuerten Verbindungsaufbau unter Windows XP beschäftigt und eine Client– Server–Anwendung mit WLAN–Verbindungsdedektion unter QNX. Die Softwareauswahl gliedert sich nach Kapiteln, Betriebssystem und Plattform. Die Programme und Quelltexte können über den Browser auf der lokalen Festplatte gespeichert -3- Einleitung und ausgeführt werden. Informationen zur Installation werden innerhalb der HTML– Dokumentation angeboten, so wie in beigelegten readme.txt Dateien. Eine Linksammlung liefert Hintergrundinformationen zu implementierungsrelevanten Aspekten. Abrundend wird ein recht populistischer Artikel vorgestellt, welcher für die Veröffentlichung in einem Computermagazin geschrieben wurde. -4- 2. Eine Einführung in die WLAN–Technologie Der Begriff WLAN steht als Akronym für "Wireless Local Area Network". Man versteht hierunter ein "drahtloses" lokales Funknetzwerk, welches sich durch räumliche Flexibilität, innerhalb eines vorgegebenen Empfangsbereiches, auszeichnet. Verkabelungsprobleme und Kabelgewirr können elegant umgangen werden. Der Einsatz einer kabellosen Netzwerktechnik für tragbare Geräte, wie Notebooks oder Handhelds, bringt erhebliche Vorteile mit sich, allerdings auch einige Nachteile. Im Folgenden möchte ich auf einige Grundlagen und Begrifflichkeiten, sowie auf einige technische Details der Wireless–LAN–Architektur eingehen. Sicherlich erhebt diese kurze Einführung in Technologie drahtloser Netzwerke keinen Anspruch auf Vollständigkeit. Es wird hierbei lediglich auf Aspekte eingegangen, welche für den automatisierten Verbindungsaufbau von Bedeutung sind und das Verständnis, der im Weiteren beschriebenen Verfahren, fördert. 2.1 WLAN–Standards Die Bezeichnung WLAN bezieht sich im Grunde genommen auf drahtlose Netzwerke im Allgemeinen und umfasst Standardisierungen wie HiperLan/2, Bluetooth, DECT, HomeRF und IrDA. Technisch korrekt beschäftigt sich diese Arbeit ausschließlich mit dem IEEE 802.11 Standard. Das Institute of Electrical and Electronics Engineers (IEEE) verabschiedete seit 1997 zahlreiche standardisierte Spezifikationen. Diese wurden in Abhängigkeit von der zeitlichen Reihenfolge alphabetisch, von 802.11a bis hin zu 802.11i (2005), gekennzeichnet. Es handelt sich hierbei größtenteils um regional unterschiedliche Anpassungen sowie technische Erweiterungen. Die in Deutschland am häufigsten vorzufindenden Varianten sind der 802.11b und der 802.11g Standard. Beide Ableger der 802.11–Technologie stellen 13 Kanäle in Deutschland zur Verfügung und senden im 2.4 - 2.4835 GHz Band [MLMMS04]. Ein gravierender Unterschied zeigt sich jedoch in den Datenraten und der daraus resultierenden Übertragungsgeschwindigkeit. Während der b–Standard lediglich maximal 11 Mbit/s Datendurchsatz bietet, kann der abwärtskompatible g–Standard mit bis zu 54 Mbit/s aufwarten. Allerdings sind diese Werte rein theoretischer Natur. In der Praxis muss berücksichtigt werden, dass sich alle Geräte im Netzwerk diese Bandbreite teilen. Zudem wird diese durch einschränkende Faktoren wie z.B. Stahlwände oder störende Funksignale auf einen reellen Nettowert reduziert. -5- Eine Einführung in die WLAN–Technologie 2.2 Einordnung des 802.11–Technologie im ISO OSI Schichtenmodell Betrachtet man das OSI–Referenzmodell, welches 7 Schichten zum Aufbau einer Netzkommunikation, unabhängig von der Art der eingesetzten Protokolle, kennt, so siedelt man die WLAN–Technik in den Schichten 1 und 2 an. Bei Schicht 1 handelt es sich um die Bitübertragungsschicht. Diese stellt die physikalischen Grundlagen für eine Netzwerkkommunikation zur Verfügung. Elektrische Signale, optische Signale sowie in unserem Fall, elektromagnetische Wellen, werden zur Kodierung eines Bitstromes verwendet. Die Sicherungsschicht, als zweite Ebene des Referenzmodelles, gewährleistet die weitgehend fehlerfreie Übertragung der zu sendenden Informationen. Hierzu werden die Bitströme fragmentiert, also in Pakete aufgeteilt, und mit Folgenummern und Prüfsummen versehen. Der Empfänger wertet diese Informationen bei dem Erhalt der Pakete aus und kann bei erkannten fehlerhaften Zustellungen die wiederholte Übertragung des Paketes anfordern. Die Bedeutung dieser OSI Schichten für den automatisierten Verbindungsaufbau von WLAN Geräten wird schnell ersichtlich. Neben der Steuerung der zwei untersten Schichten ist für eine erfolgreiche Netzkommunikation ebenso der Einsatz der abstrakteren Schichten obligatorisch. Da alle Ebenen des Referenzmodelles völlig unabhängig voneinander arbeiten, benötigt die Manipulation der höheren Schichten eine eigenständige Realisierung. Konkret handelt es sich hierbei um das Anbinden eines Netzwerkprotokolles, ohne das keine verwertbaren Informationen gesendet werden können [WIOSI05]. OSI 7 Application Application layer HTTP OSI 6 Presentation OSI 5 Session layer OSI 4 OSI 4 Transport layer Transport layer OSI 3 OSI 3 Network layer Network layer OSI 2 LLC Layer LLC Layer Data Link MAC Layer Ethernet 802.3 CSMA/CA OSI 1 OSI 1 10 BASE-2, DSSS, FHSS, Physical layer Physical layer 10 BASE-T Infrared TCP IP Pair cable, coax cable OSI OSI angepasst LAN Abbildung 2.1 : Einordnung von IEEE 802.11 im ISO OSI Kommunikationsmodell -6- Air IEEE 802.11 Eine Einführung in die WLAN–Technologie 2.3 Infrastrukturmodi Ein WLAN–Adapter kann in zwei verschiedenen Infrastrukturmodi betrieben werden. Zum einen im Infrastrukturmodus und zum anderen im Ad–Hoc–Modus. 2.3.1 Infrastruktur–Modus Bei dem Betrieb im Infrastruktur–Modus dient ein Access Point (AP) als vermittelnde Komponente zwischen Funknetzwerk und Festnetz. Der Zusammenschluss mehrer Funkstationen ist als Basic Service Set (BSS) bekannt. Sind, wie in Abbildung 2.2 dargestellt, zwei oder mehrere Funkzellen über das Kabelnetzwerk miteinander verbunden, spricht man von einem Extended Service Set (EES) [MLMMS04]. Abbildung 2.2 : Infrastruktur Szenario Aufgabe des Access Points ist die zentrale Verwaltung und Konfiguration von WLAN– Verbindungen, sowie das Routing in angebundene Netzwerke. Alle relevanten Einstellungen werden direkt auf diesem Gerät vorgenommen. Des Weiteren bietet ein solcher Access Point in der Regel eine Reihe höherer Dienste zur Netzwerkverwaltung an. So können die Geräte, welche sich auf den niedrigeren OSI–Schichten Zugang verschafft haben, optional über einen integrierten DHCP–Server mit einer netzkompartiblen IP–Adresse versehen werden. Doppelte oder fehlerhafte IP–Adressvergabe kann somit profilaktisch unterbunden werden. -7- Eine Einführung in die WLAN–Technologie 2.3.2 Ad–Hoc–Modus Will man zwei oder mehrere Endgeräte ohne den Einsatz eines zentralen Routers miteinander verbinden, so geschieht dies über das Ad–Hoc–Protokoll. Abbildung 2.3 : Ad–hoc–Szenario Es erfolgt ein loser, unbeständiger Zusammenschluss dieser Geräte innerhalb begrenzter Reichweite. Der Ad–Hoc Einsatz eignet sich somit für den schnellen, ungeplanten Einsatz. Alle Stationen agieren hierbei gleichberechtigt und unterliegen keinerlei zentraler Steuerung und Verwaltung. Es lassen sich hierbei lediglich Peer–to–Peer oder Ende–zu–Ende Verbindungen einrichten, was heißt, dass ein Gerät ausschließlich mit Stationen kommunizieren kann, welche sich in direkter Signalreichweite befinden. Eine Gruppe von Stationen, welche auf einer einheitlichen Funkfrequenz miteinander kommunizieren, nennt man Independent Basic Service Set (IBSS) [MLMMS04]. Der Einsatz von Routingmechanismen in solchen Peer–to–Peer–Netzwerken existiert zurzeit nur im Experimentalstadium. Ein solcher Zusammenschluss, bei dem jeder Teilnehmer als Router fungieren muss, nennt man Mesh–Netz. Ziel dieser mobilen Mesh–Netze ist es, Kommunikation zwischen Geräten zu ermöglichen, welche sich nicht in direkter Signalreichweite befinden, sondern einen Verbindungspfad über dazwischen liegende Stationen aufbauen [WIMAH05]. -8- Eine Einführung in die WLAN–Technologie 2.4 SSID und BSSID Ein Wireless LAN, unabhängig ob im Ad–hoc– oder im Infrastrukturmodus, identifiziert sich in erster Linie über eine bis zu 32 Zeichen lange Netzwerkkennung, genannt SSID (Service Set ID) oder ESSID (Extended Service Set ID). Grundlage für einen Netzwerkverbund auf der Grundlage des 802.11 Standards ist die Kenntnis der SSID, welche in einem Zusammenschluss unter Verwendung einer übergeordneten Infrastruktur sowohl auf dem Client als auch auf dem Access Point eindeutig sein muss. Die Verwendung des Betriebsmodus „Any“ erlaubt Geräten mit beliebiger SSID den Zugriff auf das Funknetzwerk. Ein Zugangspunkt ist in der Regel so eingestellt, dass die SSID eines Funknetzwerkes aktiv als Broadcast in den „Äther“ geschickt wird um das Auffinden und Einrichten der Verbindung zu vereinfachen. Ähnlich der SSID identifiziert sich ein Access Point über eine weitere Kennung, der BSSID (Basic Service Set Identifier). Diese entspricht immer der 48 Bit umfassenden MAC–Adresse des WLAN–Adapters und ist unmanipuliert in jedem Falle weltweit eindeutig. Alle Clients müssen sich auf diese BSSID einigen um eine Kommunikation auf unterster OSI–Ebene zu ermöglichen. Wenn mehrere Verbindungspunkte eine gleiche SSID vorweisen, kann über das gezielte Einstellen dieser Kennung selektiv verbunden werden. Im Falle eines infrastrukturellen Verbundes nehmen alle Teilnehmer die BSSID des Access Points an, in einem Peer–to–Peer–Netz wird die BSSID dynamisch generiert, muss jedoch auf allen Geräten identisch sein [MSDN05]. 2.5 Sicherheit im WLAN Im Weiteren möchte ich auf standardisierte Sicherheitsmechanismen eingehen, welche Vertraulichkeit, Integrität und Authentizität in Funknetzwerken sichern sollen. Als eine recht schwache Sicherheitsmassnahme, welche die sichere Zuordnung des Senders gewährleisten soll, kann das Rundsenden der SSID auf einigen Access Points unterbunden werden. Nur Netzwerkadapter, bei welchen eine kompatible Konfiguration vorgenommen wurde, erlangen Zugriff. Dieses Verfahren ist jedoch nicht standardkonform. Weiterhin wird die Netzwerkkennung in allen gesendeten Paketen unverschlüsselt mit übertragen, so dass es möglich ist, diese mit Hilfe eines Paketfilters auszulesen. Eine Access Control List (ACL) kann den Netzwerkzugang zusätzlich auf spezifizierte MAC– Adressen beschränken. Geräte mit fremder Kennung werden vom Access Point grundsätzlich abgewiesen. Diese Liste wird manuell auf dem Access Point verwaltet. Es kann jedoch nicht sichergestellt werden, dass eine solche Kennung eindeutige Rückschlüsse auf die Authentizität der Station ziehen lässt, da die MAC–Adresse eines Netzwerkadapters systemintern manipuliert werden kann. -9- Eine Einführung in die WLAN–Technologie Das Wired Equivalent Privacy (WEP)–Protokoll dient sowohl der Sicherung von Vertraulichkeit und Integrität als auch der Authentifizierung. Passive Angriffsmethoden wie das Abhören des Datenverkehrs sollen durch Verschlüsselung der Daten unterbunden werden. Über den RC4–Algorithmus, welcher einen Schlüssel und einen Initialisierungsvektor als Eingabe benötigt, wird die paketweise Verschlüsselung des Datenstromes durchgeführt. Der Schlüssel, der optional eine Länge von 40 oder 104 Bit aufweisen muss, ist für alle Komponenten des Funk–LANs zwingend. Seine Vergabe findet direkt auf dem Access Points statt. Der Initialisierungsvektor wird systemintern für jedes Datenpaket generiert und der eigentlichen Nachricht bei der Übertragung vorangestellt. Dieses Verfahren gilt jedoch als mathematisch unsicher. Bei der Authentisierung wird der gleiche Schlüssel wie bei der Integritätssicherung genutzt. Wird der Authentisierungsmodus mit „Shared Key“ gewählt, so erfolgt der Zugriff nach dem Challenge–Response–Verfahren. Alternativ erfolgt im „Open“–Modus keine Kontrolle. Im IEEE 802.11 Standard wird als Nachfolger des WEP–Protokolls Wi–Fi Protected Access (WPA) und WPA2 eingeführt [MLMMS04. - 10 - 3. Anforderungen an WLAN–Lösungen im KFZ Bei der Aufarbeitung der Problemstellung hinsichtlich des in der Einleitung dargestellten Szenarios, sowie im Laufe der Implementierung und der anschließenden Testphasen, kristallisierten sich elementare Anforderungen an Software und Peripherie heraus. Die erarbeiteten Punkte stellen im Weiteren eine wichtige Orientierungshilfe bei der Bewertung vorhandener Softwarelösungen dar und sind dem Verständnis von Konzipierungsgrundlagen bezüglich der geleisteten Implementierungsarbeit von enormem Nutzen. 3.1 Wahl und Integration geeigneter Hardware Wahl und Integration geeigneter Hardware meint hierbei äußere Faktoren, welche für den Betrieb von WLAN–Lösungen in einem Kraftfahrzeug von grundlegender praktischer Bedeutung sind und die Thematik dieser Arbeit lediglich streifen. Aus Gründen der Vollständigkeit wird im Folgenden kurz auf Anforderungen eingegangen, welche in der Praxis Berücksichtigung finden sollten. Generell kann die Realisierung einer WLAN–Lösung auf internen Komponenten, also dauerhaft in das Fahrzeug integrierter Hardware, oder auf externen mobilen Geräten, wie Handhelds, PocketPCs oder Laptops, durchgeführt werden. Allgemein ist zu sagen, dass vor allem die Positionierung und Bemessung der Bedienelemente im Cockpit besondere Aufmerksamkeit erfahren sollte. Der Anwender benötigt direkten Zugang zu den Elementen, welche so übersichtlich wie möglich skaliert sind um den Konzentrationsaufwand für die Bedienung minimal zu halten. Handelt es sich um ein mobiles Gerät, in welchem alle Peripherie in einem kompakten Gehäuse integriert ist und die Bedienung über einen Touch–Screen erfolgt, so bietet sich eine Montage über eine Docking–Lösung mit integrierter Stromzufuhr an. Vom Betrieb über den geräteeigenen Akkumulator sollte abgesehen werden, da der WLAN–Adapter einen enormen Energiebedarf aufweist. Das systemeigene Powermanagement, welches bei einigen Betriebssystemen sinnvollerweise regulierend eingreift, drosselt die gerätespezifische Energiespeisung und führt zu unerwünschten Leistungseinbußen. Der Einsatz spezieller WLAN–Antennen, welche die Übertragungsreichweite deutlich erhöhen, ist empfehlenswert 3.2 Übersichtliche grafische Anwendungsrealisierung Das grundlegende Augenmerk liegt auch hier wieder auf dem Bedienkomfort und der Aufwandsminimierung. Grafische Elemente wie Softbuttons, Textfelder und Zustandsindikatoren müssen überlegt und funktionell gestaltet angeordnet sein. Eine Zusammenfassung von Bedienelementen nach Funktionsgruppen ist in jedem Falle von Vorteil und erhöht die intuitive Bedienbarkeit. - 11 - Es werden lediglich Kernfunktionen Anforderungen an WLAN–Lösungen im KFZ angeboten. Detaillierte Dialoge verwirren und verleiten zu konzentrationsintensiver Suche. Eine geeignete, aussagekräftige Farbgebung der Elemente erleichtert die Bedienung zusätzlich. Eine Ein–Dialog–Benutzeroberfläche enthält alle wesentlichen Elemente, welche für die Auswahl des gewünschten drahtlosen Netzwerkes und der Verbindungsüberwachung notwendig sind. 3.3 Spezifizierung der WLAN–Konfiguration Sinn der automatisierten WLAN–Verbindungsherstellung im KFZ ist es, Zugriff auf Netzwerke zu erlangen, welche den Bedürfnissen der Anwendung entsprechen. Greift man das einleitende Tankstellenszenario erneut auf, so wird ersichtlich, dass der Tankstellenbetreiber Software zur Verfügung stellt, welche ausschließlich Zugang zu seinen eindeutig konfigurierten Zugangsstationen und den von ihm zur Verfügung gestellten Diensten gewährt. Soll über das an der Tankstelle erhaltene Programm im Peer–to–Peer Modus verbunden werden, so ist dies auch nur zu den Geräten mit identischer Konfiguration möglich. Ähnlich verhält es sich in Firmennetzwerken oder zu Hause. Ein automatisierter Verbindungsaufbau zu fremden Geräten ist weder erwünscht noch programmatisch realisierbar. Die Informationen, welche für die Einrichtung des WLAN–Zugangs benötigt werden, müssen dabei nicht weitergegeben und veröffentlicht werden. Die Konfiguration des WLAN–Adapters bleibt im Quellcode verborgen, was eventuell sogar vor Missbrauch der Verbindungsdaten schützen kann. Dabei werden die drahtlosen 802.11 Netzwerke über fest vorgegebene Parameter spezifiziert, welche ein Wireless Local Area Network eindeutig definieren. Elementare Parameter sind hierbei der Infrastrukturmodus, die SSID oder BSSID, der Authentifizierungsmodus und eventuelle Sicherheitsmerkmale wie die 64– oder 128–Bit WEP–Verschlüsselung. 3.4 Konfliktfreier Wechsel der Betriebsmodi und zustandsabhängige Benutzerinteraktion Eine Anwendung, welche Zugriff auf WLAN–Ressourcen benötigt, kann diesen im Infrastrukturmodus, sowie im Ad–hoc–Modus erfordern. Ein direkter Wechsel der Infrastrukturmodi wird entweder automatisiert über die Software erfolgen oder durch Interaktion des Anwenders. In beiden Fällen muss diese Anforderung sofort bedient werden. Ein Verbindungswechsel zwischen zwei oder mehreren Access Points ist auf Grund der ähnlichen verbindungsspezifischen Voraussetzungen ohne weiteres zu bewerkstelligen. Anders verhält es sich bei dem angesprochenen Wechsel von Netzwerken mit verschiedenartiger Infrastruktur. - 12 - Anforderungen an WLAN–Lösungen im KFZ 3.4.1 Automatisierte IP–Adressvergabe Fand die IP–Adresszuweisung bei der Verbindung zu einem Access Point problemlos über einen DHCP–Server statt, so steht dieser bei einem Independent Basic Service Set, sprich Ad–Hoc–Netzwerk, nicht mehr zur Verfügung. Es müssen eventuell zeitkritische Protokolloperationen durchgeführt werden, um dieses Problem zu lösen. 3.4.2 Zustandsabhängige Verbindungsvisualisierung Ist die Anwendung darauf ausgelegt, dass der Anwender in Abhängigkeit des aktuellen Verbindungszustandes mit der grafischen Benutzeroberfläche interagiert, so muss über aussagekräftige grafische Elemente darauf Aufmerksam gemacht werden, wann welche Aktion ausgeführt werden kann. So kann eine rot eingefärbte Schaltfläche die Verbindungsbereitschaft anzeigen falls bisher noch kein Verbindungsaufbau zu Stande kommen konnte. Eine grün eingefärbte Schaltfläche signalisiert eine erfolgreiche Netzwerkanbindung. Der Anwender ist somit in der Lage allein durch visuelle Überprüfung zu Erkennen, wann netzwerkabhängige Aktionen ausgeführt werden können oder wann eine erfolgreich durch die Software bewältigt wurde. Weiterhin können Aufgabe Softbuttons programmatisch deaktiviert werden falls die über dieses Element auszuführende Funktion auf Grund fehlender Netzwerkgegenstellen keinen Sinn machen würde. Dieses Verfahren schützt den Anwender vor nutzlosen Eingabevorgängen am Gerät und Leichtfertigkeit auf der Straße. 3.5 Dynamischer Verbindungsaufbau Eine Grundvoraussetzung für den erfolgreichen Einsatz von WLAN–Lösungen im KFZ ist die periodische und flexible Erkennung von in Reichweite befindlichen Netzwerkpartnern und die daraus resultierende Verbindungsherstellung, bzw. Unterbrechung. Auch diese Anforderungen lassen sich recht anschaulich am Tankstellenszenario nachvollziehen. Fährt der Anwender eine Tankstelle an mit der Absicht einen Verbindungsaufbau zur Basisstation herzustellen wird er auf Grund der eingeschränkten Signalreichweite zunächst noch nicht in der Lage sein eine sofortige praktikable Verbindung aufzubauen. Er versetzt sein WLAN–Gerät zunächst in Bereitschaft im Infrastruktur–Modus zu verbinden. Erst wenn die physikalischen Voraussetzungen erfüllt sind, signalisiert ein grafischer Indikator die bestehende Netzanbindung, verweist auf mögliche Interaktion oder nimmt diese selbstständig in Angriff. Durch den schnellen Ortswechsel der potentiellen WLAN–Partner und die ständig variierende Signalstärke muss die Software, welche für die Herstellung und Erhaltung von - 13 - Anforderungen an WLAN–Lösungen im KFZ Verbindungen verantwortlich ist, automatisiert nachprüfen ob eine Verbindung neu erkannt wurde, ob eine bereits eingerichtete Verbindung beständig bleibt oder ob diese dauerhaft unterbrochen wurde. Auf Grund der Ergebnisse werden programmatisch entsprechende Reaktionen eingeleitet. Die Anforderungen an die Dynamik werden auch im mobilen Ad–hoc–Einsatz deutlich. Angenommen zwei Fahrzeuge fahren in angemessenem Abstand hintereinander her. Das hintere Fahrzeug verringert aus nicht näher bekannten Gründen seine Geschwindigkeit und gerät für eine kurze Zeit außer Reichweite. Obwohl die Software einen Verbindungsverlust erkennt, wirkt sich dieser erst nach einer bestimmten Verzögerungszeit auf den Zustand des Programms aus, indem der grafische Indikator eine Trennung meldet und erneut auf die Suche nach einem Netzwerkpartner geht. - 14 - 4. Verifizierung vorhandener Connection Manager Lösungen 4.1 Übersicht WLAN–Lösungen existieren in unterschiedlichen Formen. Die meisten herkömmlichen PC– Systeme lassen sich mit PCI–WLAN–Karten oder USB–WLAN–Adaptern ausrüsten. Notebooks oder Tablet–PCs werden durch PCMCIA–Steckkarten WLAN–fähig. Viele Pocket PCs und Handhelds sind bereits ab Werk mit integrierten WLAN–Adaptern ausgerüstet. Die physikalische Beschaffenheit dieser unterschiedlichen Geräte ist für die folgenden Betrachtungen von geringer Bedeutung, da sich alle Adapter festgelegten Standards unterwerfen müssen und sich im Einsatz weitgehend identisch verhalten. Unterschiedliche Betriebssysteme greifen abhängig von dem bereitgestellten Befehlssatz auf die Hardware zu und bieten systemeigene Verwaltungswerkzeuge zur Konfiguration. Ein Betriebssystem, auf welchem vorgestellte Szenarien und Lösungen zum großen Teil implementiert wurden, ist Pocket PC 2003, eine Variante von Windows CE. Entwickelt für mobile Endgeräte, bietet Pocket PC 2003 hauptsächlich Schnittstellen und Methoden, welche konkret auf die Hardwareanforderungen bezüglich integrierter Peripherie und Funktionsumfang dieser kompakten Geräte zugeschnitten wurden. Mobile Endgeräte, wie der zur Entwickelung genutzte HP iPAQ 5500, auf welchem das angesprochene Betriebssystem zum Einsatz kommt, eignen sich auf Grund ihrer kompakten Größe und des leistungsstarken XScale Prozessors hervorragend für den Einsatz in einem Fahrzeug. Das Gerät lässt sich über einen Touchscreen bedienen und ist mit einem integrierten WLAN– Adapter ausgerüstet, welcher den 802.11b Standard unterstützt. Die folgende Bewertung systemeigener Software zur Verwaltung von IEEE 802.11 Netzwerken soll zum einen Aufschluss über Verhaltensweisen bei der Verwaltung von drahtlosen Netzwerken liefern und zum anderen zeigen, ob die erarbeiteten Anforderungen an den automatisierten WLAN– Verbindungsaufbau im KFZ aus Kapitel 3 umsetzbar sind. 4.2 Der Pocket PC 2003 Connection Manager Die zentrale Instanz zur Verwaltung von Netzwerkadaptern und Verbindungen unter dem Betriebssystem Pocket PC 2003 übernimmt alle für die Vernetzung des Gerätes relevanten Aufgaben. So lassen sich Programme mit Netzwerkbedarf generell zwei Einsatzgebieten zuordnen: Internet oder Firma. Über konfigurierbare Profile wird die Art des Verbindungsaufbaus in Abhängigkeit des Einsatzgebietes definiert. Greift eine Anwendung auf ein Firmennetzwerk zu, so wird das dafür reservierte Profil aktiviert. Konfigurierbar sind Einwählverbindungen - 15 - Verifizierung vorhandener Connection Manager Lösungen über Modem, Bluetooth und Infrarot. Weiterhin kann ein VPN–Zugang und ein Proxyserver spezifiziert werden. Um den Verbindungsmanager aufzurufen, muss durch einige, nicht immer intuitiv auffindbare, Menüs navigiert werden. Ist die Wireless–Option „WLAN“ aktiviert, so findet man hier auch die Verwaltungsinstanz für drahtlose Netzwerke. Um eine neue WLAN–Verbindung zu konfigurieren oder eingerichtete Konfigurationen zu verwalten, ist aufgeführte Menüstruktur abzuarbeiten: Start –> Einstellungen –> Verbindungen –> Verbindungen –> Erweitert –> Netzwerkkarte –> Drahtlos Hier werden alle verfügbaren WLAN–Netzwerke aufgeführt. Über Selektion und die Option „Verbinden“ werden Informationen zu Einsatzgebiet und Authentifizierung abgefragt. Werden diese korrekt spezifiziert, erfolgt der Verbindungsaufbau. Alternativ ist das Einrichten eines neuen, nicht erkannten, Netzwerkes möglich. Benötigt werden Angaben zum Netzwerknamen, Infrastrukturmodus, Einsatzgebiet und Authentifizierungsmerkmale. Da das alleinige Auffinden des Verwaltungsdialoges schon recht kompliziert werden kann, reagiert das System bei Erkennung eines neuen Netzwerkes in Form eines Assistenten. Da zu einer funktionstüchtigen TCP/IP–Kommunikation auch eine netzkompartible IP–Adresse an den Adapter gebunden werden muss, fließt dieser Aspekt ebenfalls in die Betrachtung mit ein. Die TCP/IP–Konfiguration der integrierten Adapter erfolgt im Untermenü „Netzwerkkarten“, an gleicher Stelle wie der Konfigurationsdialog der drahtlosen Netzwerke. Ist die Bezeichnung des betreffenden WLAN–Adapters bekannt, kann hier zwischen dynamischer und manueller Adressvergabe gewählt werden. Vorgegeben ist die dynamische Zuweisung über einen DHCP–Server. Das Verhalten und Zusammenspiel dieser Komponenten soll nun im Folgenden untersucht werden. 4.2.1 Aufwandsbetrachtung im Infrastrukturszenario Betrachtet werden soll der Aufwand, der benötigt wird um eine WLAN–Verbindung zu einem Access Point herzustellen. Als Testvoraussetzung wird angenommen, dass bisher noch keine Konfiguration getätigt wurde, der WLAN–Adapter eingeschaltet ist und sich in direkter Signalreichweite befindet. Erkennt der Verbindungsmanager einen neuen Access Point, so erscheint selbstständig ein Assistent, welcher dazu auffordert, die Art der Verwendung zu definieren. Zur Auswahl steht „Internet“ oder „Firma“. Bei einer VPN–Verbindung zu einem Firmennetzwerk soll ebenfall die „Internet“–Option gewählt werden. Betätigt man nun die „Verbinden“–Schaltfläche, so fordert der Dialog zur Eingabe des auf dem Access Point konfigurierten WEP–Schlüssels auf. Nach entsprechender Eingabe stellt der WLAN–Adapter eine Verbindung her. Der Verbindungsstatus wird über eine LED in der - 16 - Verifizierung vorhandener Connection Manager Lösungen oberen rechten Ecke des Gehäuses signalisiert. Verbunden blinkt diese grün, andernfalls rot. Werden bei Aktivierung des Gerätes oder des Adapters zwei oder mehrere Access Points vorgefunden, so kann die Verbindung selektiv erfolgen. Ist das Gerät aktiv verbunden und ein weiterer Access Point kommt in Reichweite, so wird dies ignoriert. Auch nach Verbindungsverlust zu dem vormals aktiven Access Point wird keine Verbindung zu dem neu erkannten Netzwerkknoten angestrebt. Bei zwei oder mehreren eingerichteten Verbindungen und ohne bereits aktivierte Netzanbindung wird die Verbindung vom Connection Manager nach Verfügbarkeit aktiviert. Das beschriebene Verhalten erfolgt automatisiert und komfortablerweise unter Verwendung eines selbständig erscheinenden Assistenzdialoges. Da die meisten Netzwerke über einen separaten DHCP–Server verfügen, oder ein solcher im Access Point integriert ist, erfolgt die IP–Adressvergabe dynamisch. Identifizieren sich die Hosts im Netzwerk über einen Dynamic Name Server (DNS) und orientiert sich die Anwendung an der Geräteidentifikation, spielt die erhaltene IP–Adresse lediglich eine untergeordnete Rolle, da der Name dynamisch mit der entsprechenden Adresse verknüpft wird. Befindet sich das Gerät nicht im Signalbereich des gewünschten WLAN–Netzwerkes, muss die Einrichtung von Hand erfolgen. Eine solche Situation kann sich ergeben, wenn die Verbindung im Vorfeld eingerichtet wird, um einen automatisierten Netzwerkzugang bei Bedarf zu gewährleisten. Hierzu ist es nötig sich in das Konfigurationsmenü drahtloser Verbindungen zu begeben. Nach Eingabe aller nötigen Parameter, wie in Kapitel 4.2 beschrieben, befindet sich das Profil in Bereitschaft und verhält sich wie eine über den Assistenten konfigurierte Verbindung im Bezug auf die Dedektion weiterer WLAN–Zellen oder Verbindungsverlust. 4.2.2 Aufwandsbetrachtung im Ad–hoc–Szenario Das Einrichten einer Ad–hoc–Verbindung über den Assistenten oder die Anzeige verfügbarer drahtloser Netzwerke kann nur durchgeführt werden, wenn sich bereits mindestens ein Gerät im Ad–hoc–Modus befindet und diesbezüglich konfiguriert wurde. Dies erfolgt über die manuelle Einrichtung einer neuen Verbindung. Sucht der Connection Manager nach gemischten Infrastrukturmodi, so kann die Anzeige verfügbarer Netzwerke recht widersprüchlich erscheinen. Der Ad–hoc–Verbindungsaufbau ist gänzlich unmöglich, wenn das Gerät infrastrukturell eingebunden ist. Das Bereitstellen der Parameter für die erkannte Verbindung wird ähnlich der Konfiguration einer infrastrukturellen Konfiguration vorgenommen. Wechselt das Gerät, welches die Verbindung anfänglich signalisierte in den verbindungslosen Zustand, so ergibt sich beim Partnergerät keine Änderung. Es scheint weiterhin aktiver Teilnehmer eines Independent Basic Service Sets zu sein. Dieses Verhalten liegt in der Natur des Ad–hoc–Protokolls. Da - 17 - Verifizierung vorhandener Connection Manager Lösungen ein solcher loser Netzwerkverbund keinerlei zentraler Kontrolle untersteht, kann eine aktive Netzwerkanbindung nicht erkannt werden. Die WLAN–Adapter wechseln in den Ad–hoc Modus und sind bereits eigenständige, aktive Netzwerkstationen. Ist das Gerät einmal verbunden, so kann es nie von selbst in einen verbindungslosen Zustand wechseln und die Verbindung zu einem, in Reichweite befindlichen, infrastrukturellen Netzwerk anstreben. Wenn ein uneinheitlicher WEP–Schlüssel vergeben wird, bauen beide Geräte ein unabhängiges Ad–hoc–Netz auf, auf welches die Geräte gegenseitig nie Zugriff erlangen werden. 4.3 Zusammenfassende Bewertung für den Einsatz im KZF Bewertet man die erzielten Ergebnisse nach den Kriterien für den automatisierten Verbindungsaufbau im KFZ, so kann gesagt werden, dass der Connection Manager über sehr weitreichende Funktionalität verfügt, jedoch den Anforderungen an den mobilen Einsatz im KFZ nicht gerecht wird. Von grundlegendem Nachteil ist auf jeden Fall die komplizierte Menüführung, welche sich durch den enormen Funktionsumfang ergibt. Der Assistenzdialog, welcher bei der Erkennung von neuen WLAN–Netzwerken erscheint, erleichtert zwar die Konfiguration, lässt sich aber nicht an die individuellen Bedürfnisse des Anwenders anpassen. Ähnlich verhält es sich mit der systeminternen Netzwerkverwaltung. In Abhängigkeit von der aktuellen Einstellung, werden verfügbare WLAN–Knoten nicht immer erkannt oder lassen sich nicht anwählen. Weiterhin kann das Verbindungsverhalten kaum beeinflusst werden. Will ein Anwender, welcher bereits mit einem WLAN–Knoten verbunden ist, auf ein alternatives Netzwerk ausweichen, so sind umfangreiche Konfigurationsvorgänge vorzunehmen. Bei einem Betrieb im Ad-hoc–Modus muss die IP–Adressvergabe zusätzliche Berücksichtigung finden. Meistens kommt man um manuelle Konfiguration nicht herum. Der bei dem Betrieb im KFZ obligatorische dynamische Verbindungsaufbau kann ebenfalls nicht realisiert werden. Wird nach Abarbeitung aller Infrastrukturkonfigurationen keine Verbindung hergestellt, so stellt sich der WLAN–Adapter auf den Ad–hoc–Modus ein. Dies macht im konventionellen Einsatz Sinn, ist jedoch für das behandelte Szenario von Nachteil. Intelligente Verbindungsverwaltung, welche auf die Anforderungen der Anwendung eingeht, kann daher nur durch eine individuelle Softwarelösung umgesetzt werden. - 18 - 5. Vorbetrachtungen im allgemeinen WLAN– Szenario 5.1 Notwendigkeit einer individuellen Softwarelösung Aus der Erkenntnis, dass vorhandene Softwarelösungen unzureichend und mit den Anforderungen für den Einsatz im KFZ nicht in Einklang zu bringen waren, entstand die Notwendigkeit ein individuelles Softwaremodul zu entwickeln. Es wurde nach einer Lösung gesucht WLAN–Verbindungen softwareintern zu verwalten und zu überwachen, um dynamisch auf gegebene Zustände reagieren zu können. Diese Zustände ergeben sich aus dem aktuellen Status des WLAN–Adapters, der Verfügbarkeit möglicher WLAN–Netzwerkpartner und dem konkreten Bedarf an Netzwerkzugriffen. Eine Kommunikationsanwendung muss beispielsweise erkennen können, ob eine Ad–hoc– Verbindung zu einem Partnergerät möglich ist, um eine Voice over IP (VOIP) Sitzung mit dem entsprechenden Gerät mit individueller IP–Adresse herzustellen. Ist dies nicht der Fall, wird entweder aktiv ein Verbindungsaufbau mit spezifischen, vorgegebenen Parametern eingeleitet, auf eine alternative Verbindungsvariante umgestiegen oder signalisiert, dass sich kein kompatibles Gerät in Reichweite befindet . Diese Aktionen müssen dem Benutzer durch Automatisierung in vollem Umfang abgenommen werden. Bei komplexeren Anwendungen kann die Notwendigkeit bestehen mehrere Netzwerke oder Infrastrukturmodi prioritätsgesteuert zu verwalten. Eine solche Aufgabe ist nur mit einer entsprechend intelligenten Software zu bewältigen. 5.2 Programmiersprache und Entwicklungsumgebung Bei der Entscheidungsfindung für die Wahl einer geeigneten Programmiersprache waren einige hinreichende Kriterien zu bedenken. Der zu entwickelnde Quellcode sollte durch ein hohes Maß an Modularität problemlos in bestehende oder neue Anwendungen im mobilen Einsatz integrierbar und auch auf unterschiedliche Betriebssysteme portierbar sein. Die Programmiersprache muss von dem eingesetzten Betriebssystem, in unserem Falle der Windows CE Variante Pocket PC 2003, in vollem Umfang unterstützt werden. Des Weiteren ist eine modulare, objektorientierte Softwarearchitektur wünschenswert, um den Quelltext übersichtlich und verständlich zu halten. - 19 - Vorbetrachtungen im allgemeinen WLAN–Szenario Die oben genannten Faktoren sowie der Wunsch, dass der zu entwickelnde Quelltext auf das echtzeitfähige, in unseren Projektframeworks eingesetzte Betriebssystem QNX1 portierbar sein sollte, bildeten die Grundlage der Entscheidung für die Programmiersprache C++. Bei der Suche nach einer Entwicklungsumgebung fiel die Wahl auf das Embedded Visual Studio 4.0 in Kombination mit dem Pocket PC 2003 Software Development Kit2 (SDK) von Microsoft. Dieses SDK unterstützt die Entwicklung auf vorgegebener primärer Zielplattform, welche sich durch die Verwendung des iPAQ H5500 Pocket PCs ergab. Es ergänzt die Basisfunktionalität der Entwicklungsumgebung um betriebssystemspezifische APIs in Form von Header–Dateien und Bibliotheken, welche spezielle Hardwareeigenschaften von unterstützten mobilen Endgeräten berücksichtigen und ermöglicht das Übersetzen des Quellcodes für Prozessoren mit ARM4 Befehlssatz. Zusätzlich wird der Service Pack 4 für das Visual Studio benötigt. Die Möglichkeit kompilierte Quelltexte aus der IDE (Integrated Development Environment) auf dem externen System auszuführen und zu debuggen, ermöglicht direkten Zugang zum Zielsystem. Hierbei werden die Programmdateien mittels Active Sync Software3 auf das mobile Endgerät transferiert, zur Ausführung gebracht und der Programmablauf im Debugging–Modus ausgewertet. Der Pocket PC ist dabei über USB oder seriell mit dem Entwicklungs-PC verbunden. Zusätzliche Werkzeuge helfen bei der Verwaltung und der Systemüberwachung. Mit Hilfe des Remote Registry Editors lässt sich die Windows–Registrierung auf dem verbundenen Gerät bearbeiten. Über den Remote Process Viewer erlangt man Kontrolle über Prozesse, Threads und Module und kann diese gegebenenfalls terminieren. Will man Screenshots des externen Gerätes erstellen, so bemüht man das Remote Zoom In Werkzeug. 5.3 Pocket Anmerkungen zur Implementierung PC 2003 unterstützt ohne Installation von Zusatzsoftware keine Konsolenanwendungen. Es ist zwar theoretisch möglich diese mit Hilfe eines speziellen Software Delevopment Kits4 (SDK) zu implementieren und auf den Geräten auszuführen, jedoch würde die Bedienung der Software zu unübersichtlich und für den praktischen Einsatz im KFZ kaum praktikabel. Nützliche Konsolenanwendungen wie „ipconfig“, um die IP–Konfiguration auszulesen und die „ping“–Anwendung, um die Funktionalität von Verbindungen zu überprüfen, wurden beim Entwickeln und Testen zu Rate gezogen. 1 www.qnx.com www.microsoft.com 3 www.microsoft.com/windowsmobile/downloads/activesync38.mspx 4 www.symbolictools.de/public/pocketconsole/developers/portsdk.htm 2 - 20 - Vorbetrachtungen im allgemeinen WLAN–Szenario Möglich wurde dies nach dem Aufspielen eines Konsolen–Gerätetreibers5, der eigentlichen Konsolenanwendung6 und den "Nettools"7. Es wurde bereits im Anfangsstadium entschieden eine grafische Benutzeroberfläche zu entwerfen, welche es dem Benutzer möglich machen sollte, per Softbutton optional in Bereitschaft zu wechseln, entweder im Ad–hoc–Modus oder im Infrastruktur–Modus nach potentiellen Netzwerkpartnern zu suchen und eine Verbindung zu diesen herzustellen. Die übersichtliche grafische Aufbereitung des Verbindungsstatus zählt ebenfalls zu den gestellten Anforderungen und spricht zusätzlich für den Einsatz grafischer Elemente. Die Entwicklung der grafischen Benutzeroberfläche (GUI) wurde mittels Microsoft Foundation Classes (MFC) realisiert. Diese beinhalten eine Sammlung von objektorientierten Klassenbibliotheken und ermöglichen dem Programmierer vereinfachten Zugriff auf niedere, zur Erstellung von grafischen Elementen notwendige, System–APIs [WIMFC05]. Die Implementierung der grafischen Komponente dient dem Zweck Benutzereingaben entgegenzunehmen und Systemausgaben zu visualisieren und ist der Logik des Programms kaum dienlich. In den folgenden Ausführungen wird auf wesentliche, für das Verständnis des Programms wichtige Implementierungsaspekte eingegangen. Da die MFC-Programmierung für das Thema der Arbeit lediglich aus gestalterischer Sicht von Interesse ist, wird diesbezüglich auf detaillierte Kommentare verzichtet. Bei den Quelltext–Listings wurde darauf geachtet, logisch zusammenhängende und ausführlich kommentierte Befehlssequenzen aufzubereiten. Die Deklarationen wichtiger Variablen und Header–Dateien, sowie eingebundene Bibliotheksmodule werden vorangestellt um die praktische Verwertbarkeit zu garantieren. Der komplette Quelltext der entwickelten „WLANConnector“–Anwendung für Pocket PC 2003 ist auf der beigefügten CD–ROM zu finden. 5.4 Grundlegende Konzipierungsüberlegungen Die Erkenntnis, das die komplette systeminterne Verbindungsverwaltung über den ausführlich diskutierten Connection Manager abgehandelt wird, legte die Vermutung nahe, dass WLAN–Verbindungen mittels der im Betriebssystem Pocket PC 2003 SDK integrierten Connection Manager–APIs definiert und aktiviert werden können [PPCDG05]. Bei der Auseinandersetzung mit diesem Befehlssatz wurde jedoch deutlich, dass diese Funktionssammlung für unser primäres Ziel kaum von Nutzen sein kann. Innerhalb des Connection Managers, welcher sowohl Einwählverbindungen über Modem oder serielle Schnittstellen verwaltet und diese Verbindungen generell zwei verschiedenen Anwendungsbereichen, nämlich „Internet“ oder „Firmennetzwerk“ zuordnet, erfolgt die Verbindungskonfiguration auf sehr abstrakter Ebene. 5 www.symbolictools.de/public/pocketconsole/index.htm#download www.symbolictools.de/public/pocketconsole/applications/cmd/index.htm 7 http://www.symbolictools.de/public/pocketconsole/applications/nettools/index.htm 6 - 21 - Vorbetrachtungen im allgemeinen WLAN–Szenario Dabei kommt einer untergeordneten Instanz, welche als unabhängiges Modul in den Connection Manager eingebunden ist, die Steuerung der WLAN–Komponenten zu. 5.5 Die Wireless Zero Configuration Diese Instanz ist als Wireless Zero Configuration bekannt. Dieser systemeigene Dienst dient der Konfiguration von drahtlosen Netzwerken auf den meisten Windows–Systemen und ist für das Verhalten bei der Erkennung von WLAN–Netzen sowie bei der Verbindungsherstellung zu selbigen verantwortlich. Ein Implementierungsbeispiel der Wireless Zero Configuration, geschrieben in C++, kann dem Windows CE.NET 4.2 Platform Builder8 entnommen werden. Bei Windows 2000 oder Windows XP wird die WZC in einer Liste von verfügbaren Diensten innerhalb des Dienstemanagers geführt und kann hier explizit gestartet oder gestoppt werden. Bei deutschsprachigen Betriebssystemsversionen lautet die entsprechende Bezeichnung "Konfigurationsfreie drahtlose Verbindung". Hersteller von WLAN–Adaptern schaffen mit alternativer, individueller Konfigurationssoftware eine Möglichkeit der benutzerfreundlicheren Installation ihrer WLAN–Karte, in einigen Fällen mit Hilfe von Assistenten, welche durch den Einrichtungsvorgang führen. Der Einsatz dieser Programme ist erfahrungsgemäß nicht immer intuitiv und empfehlenswert. Eingerichtete Verbindungen werden in manchen Fällen bei einem Neustart des Rechners nicht automatisch wiederhergestellt und benötigen erneute Aufmerksamkeit. Dieses Konfigurations–Utility, das bei der Integration der meisten WLAN– Adapter optional installiert werden kann, ersetzt und beendet die WZC und stellt deren "Starttyp" auf "manuell" um. Angesprochenes Vorgehen ist in jedem Falle erforderlich, wenn mittels Fremdsoftware manipulativ auf die WLAN–Adapterkonfiguration zugegriffen wird, und dient der Vermeidung von internen Komplikationen [WRAPI05]. Da das Betriebssystem Pocket PC 2003, welches auf dem HP iPAQ beheimatet ist, keinen Dienstmanager kennt, kann das Starten des Dienstes wie folgt unterbunden werden: Ein Eintrag in der Windows CE Registrierung verweist auf die Dynamic Link Library namens „WZCSVC.dll“, welche die Implementierung des WZC–Dienstes verkörpert. Ändert man diese Zeichenkette, welche im Registrierungspfad "HKEY_LOCAL_MACHINE\Drivers\BuiltIn\ZeroConfig" zu finden ist, geringfügig um und führt einen Systemneustart durch, so kann die DLL nicht mehr gefunden werden. Der Dienst wird folglich nicht gestartet und der Connection Manager für die Konfiguration von WLAN–Verbindungen unbrauchbar [PPCDF05]. 8 www.microsoft.com - 22 - Vorbetrachtungen im allgemeinen WLAN–Szenario Screenshot 5.1 : WZC–DLL in der Windows CE Registrierung Es empfiehlt sich den Dienst bei der ersten Initialisierung der Anwendung zu beenden. Der Aufruf der entwickelten „disableWZC“–Funktion9 wurde innerhalb der OnInitDialog– Funktion10 der MFC–Anwendung platziert. Dies bewirkt das Abarbeiten der Befehlssequenz bei der Initialisierung des Basisdialoges. Programmatisch wird dies durch folgende Implementierung erreicht: 1 #include <Winreg.h> 2 3 void disableWZC() 4 { 5 HKEY hKey = NULL; 6 DWORD dwDisposition = 0; 7 CString wzc = _T("WZCSVC.dllx"); 8 9 RegCreateKeyEx( 10 HKEY_LOCAL_MACHINE, 11 _T("Drivers\\BuiltIn\\ZeroConfig"), 12 0, 13 NULL, 14 0, 15 KEY_EXECUTE|KEY_READ|KEY_ALL_ACCESS, 16 NULL, 17 &hKey, 18 &dwDisposition ); 19 20 21 22 9 WLANConnector – IpSwapper.cpp WLANConnector – WLANConnectorDlg.cpp 10 - 23 - Vorbetrachtungen im allgemeinen WLAN–Szenario 23 24 RegSetValueEx ( 25 hKey, 26 TEXT ("Dll"), 27 0, 28 REG_SZ, 29 (LPBYTE)(LPCTSTR)wzc, 30 _tcslen(wzc)*2+1); 31 } LISTING 5.1 : Deaktivieren der Wireless Zero Configuration 11 Bei Beendigung der Anwendung sollte die Ausgangssituation wiederhergestellt werden um bei Bedarf die volle Funktionalität des Connection Managers zu reaktivieren. Diese resultiert aus der Abarbeitung der oben dargestellten Befehlssequenz mit der DLL– Originalbezeichnung. So lange das System mit der Individualkonfiguration arbeitet ergibt sich bei erneutem Ausführen der Anwendung keine Änderung, da die Originaleinstellungen erst mit einem Neustart des Gerätes übernommen werden. Sind die Vorkehrungen für die erfolgreiche Manipulation der WLAN–Adapter durch Deaktivierung des WZC–Dienstes getroffen können die eigentlichen Gerätezugriffe angegangen werden. 5.6 Das NDIS-Benutzermodus-E/A-Protokoll (NDISUIO) NDIS-Benutzermodus-E/A-Protokoll (NDISUIO) ermöglicht Netzwerkadapter– manipulationen durch Anwendungen auf Benutzerebene. In diesem Kapitel werden NDISUIO–Implementierungsgrundlagen vermittelt, die Einordnung dieser Protokollzugriffe innerhalb der Windows 802.11–Netzwerktreiber–Architektur beleuchtet und ein zu wissenschaftlichen Zwecken frei nutzbares Softwaremodul vorgestellt, welches den praktischen Einsatz dieser Hardwareschnittstellen an Hand von Quelltexten demonstriert. 5.6.1 802.11–Netzwerktreiber–Architektur Der so genannte Miniport–Treiber oder MAC–Treiber agiert auf hardwarenähester Ebene und ist für eine Reihe von elementaren Aufgaben konzipiert. Er leistet die Weiterleitung von Paketen an die Netzwerkadapterhardware zur physikalischen Übertragung. Er ruft Pakete ab, welche von der WLAN–Adapterhardware empfangen werden, verwaltet Interrupts und ist 11 WLANConnector – IpSwapper.cpp - 24 - Vorbetrachtungen im allgemeinen WLAN–Szenario für die Durchführung von Hardware–Kontrolloperationen dienlich. Der Miniport–Treiber kommuniziert mit dem so genannten Intermediate–Treiber, welcher auf einer höheren Ebene Schnittstellen für Protokolltreiber zur Verfügung stellt um den Adapter zu konfigurieren und um Pakte über das Netzwerk zu senden und zu empfangen. Abbildung 5.1 : Windows 802.11 Netzwerktreiber–Architektur 12 Ein solcher Protokoll–Treiber ist das NDIS–Benutzermodus–E/A–Protokoll (NDISUIO). Über die Network Driver Interface Specification, kurz NDIS, werden Schnittstellen zwischen Miniport–Treiber, Intermediate–Treiber und Protokoll–Treiber definiert. Der Intermediate– Treiber übernimmt dabei eine vermittelnde Position [WPDN03]. Da das NDIS–Interface sowohl den Miniport–Treiber als auch den Intermediate–Treiber umschließt, wird oft von einem NDIS Wrapper (Hülle) gesprochen. Erste Versionen der Network Driver Interface Specification wurden in Zusammenarbeit von Microsoft und 3COM proprietär für alle gängigen Windows–Systeme entwickelt [WINDIS05]. Um grundsätzliche 802.11–Dienste zu unterstützen werden eine Reihe von NDIS Object Identifiern (OIDs) definiert, welche über NDISUIO Zugriff auf den Miniport–Treiber ermöglichen. Mit Hilfe dieser OIDs können Informationen ausgelesen werden und Adapterkonfigurationen vorgenommen werden, mit welchen es möglich ist, WLAN– Verbindungen zu konkretisieren und Verbindungen aufzubauen. Dabei wird ein fest vorgegebenes Verhalten auf physikalischer Ebene vorausgesetzt [WPDN203]. 12 www.filseclab.com/eng/products/sourcetech.htm - 25 - Vorbetrachtungen im allgemeinen WLAN–Szenario 5.6.2 Implementierungsaspekte Im Folgenden wird zunächst auf allgemeine Implementierungsaspekte im Umgang mit den NDIS–APIs eingegangen, welche sowohl für den Ad–Hoc–Modus sowie für den Infrastruktur–Modus gelten. Des Weiteren schließt sich eine gesonderte Betrachtung der beiden Infrastruktur–Modi an, in welcher verbindungsspezifische Anforderungen für den Betrieb im KFZ in den Vordergrund gerückt werden. Da bei der Softwareentwicklung gesteigerter Wert auf Modularität gelegt wurde, erfolgte die Implementierung der Adapterzugriffe über NDISUIO in der Klasse DeviceControl13. Die „DeviceControl“–Klassenfunktionen „setAdHoc“ und „setInfrastructure“ versetzen das WLAN–Netzwerkinterface in die jeweilige Verbindungsbereitschaft und werden in unterschiedlichen Kontexten der MFC–Anwendung aufgerufen. Die Basis für den Zugriff auf einen Gerätetreiber bildet die Erzeugung einer abstrakten Referenz auf ein Datenobjekt, genannt Handle, welche typisiert und mit entsprechenden Zugriffsrechten versehen werden muss. Diese Datei fungiert als Stellvertreter oder Proxy und wird unter Windows CE vorläufig noch nicht konkretisiert. Es wird lediglich festgelegt, dass es sich um einen NDIS fähigen Protokolltreiber handelt [MSDN05]. Listing 5.1 zeigt eine Implementierungsvariante um das Handle „m_hDeviceHandle“ zu erzeugen. 1 DWORD m_dwBytesReturned = 0; 2 bool retval; 3 4 HANDLE m_hDeviceHandle = CreateFile( 5 NDISUIO_DEVICE_NAME, 6 GENERIC_READ | GENERIC_WRITE, 7 FILE_SHARE_READ | FILE_SHARE_WRITE, 8 NULL, 9 OPEN_EXISTING, 10 FILE_ATTRIBUTE_NORMAL| FILE_FLAG_OVERLAPPED, 11 (HANDLE)INVALID_HANDLE_VALUE 12 ); 14 LISTING 5.2 : Erzeugung eines NDISUIO Handles Um hardwareorientierte Operationen auf einem Gerät auszuführen wird mit Hilfe der DeviceIoControl–API aus der „Winbase.h“ ein Kontrollcode und dessen Spezifizierung in Form eines Datenpuffers an den Gerätetreiber weitergegeben. Zur Anwendung kommen zwei Gerätekontrollcodes, oder IOCTLs (Ein–/Ausgabekontrolle): Die IOCTL–Struktur „IOCTL_NDISUIO_SET_OID_VALUE“ wird zur Konfiguration verwendet und 13 14 „IOCTL_NDISUIO_QUERY_OID_VALUE“ WLANConnector – DeviceControl.cpp WRAPIb2.0 – WRAPI.cpp - 26 - zum Auslesen eines angeforderten Vorbetrachtungen im allgemeinen WLAN–Szenario Datenpuffers [MSDN05]. Diese und weitere IOCTL–Strukturen sind in der „nuioser.h“15 definiert. Der bei diesen Befehlen übertragene Datenpuffer birgt nun den gewünschten NDIS Object Identifier (OID) in sich. Da es sich bei der DeviceIoControl–Funktion16 um eine recht dominante und redundante Operation bei der Interaktion mit dem Miniport–Treiber handelt, möchte ich im Folgenden näher auf die benötigten Parameter und ihre Datentypen eingehen: 1 BOOL DeviceIoControl( 2 // Der Rückgabewert als Boolean: Bei erfolgreicher Ausführung die '0' 3 HANDLE hDevice, 4 // Handle/Verweis auf das Zielgerät – Erzeugung mittels CreateFile() 5 DWORD dwIoControlCode, 6 // Der IOCTL–Kontrollcode: IOCTL_NDISUIO_SET_OID_VALUE oder 7 // IOCTL_NDISUIO_QUERY_OID_VALUE 8 LPVOID lpInBuffer, 9 // Long–Zeiger auf den Datenpuffer, welcher die OID beinhaltet 10 DWORD nInBufferSize, 11 // Größe des Eingabepuffers in Bytes 12 LPVOID lpOutBuffer, 13 // Long–Zeiger auf den Ausgabepuffer bei "IOCTL_NDISUIO_QUERY_OID_VALUE"–Operationen 14 DWORD nOutBufferSize, 15 // Grösse des Ausgabepuffers in Bytes 16 LPDWORD lpBytesReturned, 17 // LongPointer auf eine Variable, welche die Grösse der Datenmenge im Ausgabepuffer 18 LPOVERLAPPED lpOverlapped 19 // Wird ignoriert und mit NULL festgesetzt 20 ); LISTING 5.3 : DeviceIOControl inklusive typisierter Parameter [MSDN05] Die NDIS–OIDs werden innerhalb eines betriebssystemsspezifischen Header–Files mit der Bezeichnung "ntddndis.h" konkretisiert. Es handelt sich hierbei um eine Liste von Define Befehlen, welche eine textuelle Ersetzung der OID–Bezeichnung durch ein 32–Bit Datenwort in hexadezimaler Darstellung vornehmen. 1 #define OID_GEN_HARDWARE_STATUS LISTING 5.4 : Beispiel für die Definition einer NDIS–OID 0x00010102 17 „nuioser.h“ und „ntddndis.h“ müssen im Quellcode inkludiert sein um mit den NDIS User Mode I/O Protocol arbeiten zu können [WPDN203]. 15 nuioser.h - Pocket PC 2003 SDK winbase.h – Embedded Visual Studio 4 17 ntddndis.h – Pocket PC 2003 SDK 16 - 27 - Vorbetrachtungen im allgemeinen WLAN–Szenario 5.6.3 Wireless Research API18 (WRAPI) Bei der Wireless Research API, welche 2002 von der University of California entwickelt wurde, handelt es sich um eine Softwarebibliothek, welche es Programmierern ermöglicht Konfigurationen von 802.11–Netzwerkadaptern auszulesen und diese zu konfigurieren. Die komplette Implementierung basiert auf NDISUIO–Protokollzugriffe und kann als DLL in eigenen C++ Quellcode integriert werden. WRAPI wurde explizit für den Einsatz unter Windows XP entwickelt. Da NDISUIO auf dem NDIS 5.1 Standard arbeitet, wird weitgehende Hardwareunabhängigkeit erreicht. Der Quellcode ist frei zugänglich und kann zu wissenschaftlichen Zwecken nach Belieben genutzt und abgeändert werden. Das vorgefundene Softwaregerüst war eine große Hilfe bei der Erstellung der entwickelten Software und ermöglichte einen konkreten Einblick in die abstrakte NDIUIO–Funktionalität. So konnten benötigte Variablendeklarationen weitgehend übernommen und den Anforderungen entsprechend angepasst werden. Die enthaltenen Funktionen wurden ausgewertet und softwareintern verarbeitet. Hierbei muss berücksichtigt werden, dass die einzelnen Funktionen an sich lediglich einzelne Ausprägungen der 802.11–Adapterkonfiguration auslesen oder konkretisieren. Erst durch die Verwendung im richtigen Kontext wird ein verwertbares Ergebnis erzielt. Weiterhin musste der untersuchte Quelltext auf die Eigenheiten des Betriebssystems Pocket PC 2003 angepasst werden. Kapitel 8 geht daher speziell auf die Besonderheiten unter Windows XP ein. Das komplette WRAPIb2.0–Projekt liegt der angefügten CD–ROM bei. 18 http://sysnet.ucsd.edu/pawn/wrapi/ - 28 - 6. WLAN–Verbindungsaufbau im Ad–hoc–Szenario 6.1 IP–Adressen–Problematik und Lösung Die reine Verbindungsherstellung auf physikalischer / DataLink Ebene reicht für eine praktikable Anwendung noch nicht aus. Es muss weiterhin ein Protokoll definiert und an den Adapter gebunden werden. Folgende Anforderungen müssen an die TCP/IP–Konfiguration gestellt werden: Die IP– Adressen der Netzwerkadapter müssen in einem kompatiblen Netzwerksegment liegen, dürfen jedoch nicht identisch sein. Weiterhin muss die Möglichkeit gegeben sein die Netzwerkadresse der verbundenen Geräte zu verbreiten und untereinander weiterzugeben. Da die IP–Problematik elementarer Bestandteil des automatisierten Verbindungsaufbaus im KFZ ist, muss auch sie automatisiert und softwaregesteuert gelöst werden. 6.1.1 Bewertung konventioneller Verfahren zur IP–Adressvergabe IP–Adressen werden generell auf zwei Arten zugewiesen: Entweder man trägt diese inklusive Subnetzmaske und Gateway im entsprechenden Netzwerkkonfigurationsdialog ein oder man wählt die Konfiguration über einen DHCP–Server. Legt man sich auf das dynamische Zuweisungsverfahren fest und wird kein entsprechender Dienst im Netzwerk angeboten, würde dem Adapter keine funktionelle Adresse zugewiesen. Die meisten Windows–Systeme gehen auf diese Problematik ein, indem sie auf eine so genannte Auto–IP zurückgreifen. Hierbei handelt es sich um eine in der Registrierung abgelegte IP–Adresse aus einem speziell festgelegten Netzwerksegment. Dieses „Automatic Private IP Addressing“ (APIPA) genannte Verfahren vergibt Adressen aus dem Bereich von 169.254.0.0 bis 169.254.255.255, welcher sich bei einer Subnetzmaske von 255.255.0.0. ergibt [AWAP02]. Obwohl diese Automatisierung einen brauchbaren Ansatz für die Lösung der entstandenen IP Problematik bietet, erweist sich die enorme Anzahl potentieller Zuweisungen als nachteilig. Die Tatsache, dass Verbindungen innerhalb TCP/IP–Netzwerken mit Hilfe des bekannten „ping“–Programms überprüft werden können, führte zu der Idee eines Netzwerkscans mittels ICMP–Echo–Requests. Kann dieser Befehl unter Verwendung der zu verifizierenden IP–Adresse erfolgreich ausgeführt werden so kann auf einen erfolgreichen Verbindungsaufbau geschlossen werden. Ein solcher Scan wäre bei 65025 zu überprüfenden Möglichkeiten grenzenlos überfordert und würde eine enorme, nicht zu tolerierende Zeitspanne benötigen. Identische Adresszuweisungen werden per Address Resolution Protocol (ARP) verhindert [AWAP02]. Dennoch spricht Einiges für die - 29 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Verwendung der Auto–IP Option: Da die IP–Adresse bei Betrieb im Infrastruktur–Modus per DHCP geschieht, ist keinerlei Modifizierung der Einstellungen nötig. Der Protokoll–Treiber erkennt den entsprechenden Service, ignoriert die Auto–IP Einstellungen und bezieht die Adresse dynamisch. Doppelte Zuweisungen können hier prinzipiell ausgeschlossen werden. Des Weiteren kann programmatisch eine neue Adresse angefordert werden. Über die Konsole geschieht dies über die Eingabe von „ipconfig /renew“ [MSDN05]. Aus dieser Erkenntnis entstand die Idee, die IP–Adresse als „Auto–IP“ in die Registrierung zu schreiben und dann eine erneute Zuweisung zu erzwingen. Die Werte werden hierbei innerhalb einer überschaubaren Spanne zufällig generiert. Ihre Eindeutigkeit wird überprüft und sichergestellt. 6.1.2 Abwandlung von APIPA durch Registrierungsmanipulation IP–Adressen können aus praktischer Erfahrung in der Registrierung für jeden Netzwerkadapter separat festgelegt werden. Hier wird eine Sammlung von Konfigurationsparametern verwaltet und persistent abgelegt. Diese Erkenntnis macht sich die erstellte Anwendung zu Nutzen, indem, mittels aus der Deaktivierung des WZC–Dienstes bekannten Befehlen, entsprechende Werte in die Registrierung eingetragen werden. Dieses Vorgehen wurde zunächst im Registrierungseditor getestet. Screenshot 6.1 zeigt rotumrandet alle Parameter, welche für die automatisierte Adresszuweisung über das APIPA–Verfahren relevant sind. Während in Screenshot 6.1, Ausschnitt 1, die über die automatisierte IP–Adressvergabe zugewiesenen Werte spezifiziert werden, definieren die Werte aus Ausschnitt 2 die Art der Zuteilung. Der boolesche Wert 1 im Wertefeld „EnableDHCP“ aktiviert die dynamische IP– Adresszuweisung über „DhcpDefaultGateway“, einen DHCP–Server, „DhcpServer“, welcher „DhcpSubnetMask“ durch und die Felder „DhcpIPAddress“ konkretisiert wird. Ist im Wertefeld „AutoCfg“ eine 1 eingetragen, so wird die IP–Konfiguration aus Ausschnitt 1 angewandt. Hierbei nimmt die „DhcpIPAddress“ den im „AutoIP“–Feld eingetragenen Wert an, welcher der letztendlich zuzuweisenden Adresse entspricht. Die Adressspezifikation des DHCP Servers nimmt mit der 255.255.255.255 („DhcpServer“) und der Subnetzmaske („DhcpSubnetMask“) 255.255.255.0 einen für den Broadcast typischen Wert, was lediglich bedeutet das dieser unbekannt ist und nicht spezifiziert wird. - 30 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Screenshot 6.1 : Definition der "WZC"–DLL in der Windows CE – Registrierung Zunächst wird mittels Random–Befehl19 eine Zufallszahl generiert. Über den Modulo– Operator wird ein möglicher Wertebereich von 0 bis 30 erzwungen (Listing 6.1, Zeile 3). Es gibt also 30 mögliche verschiedene IP–Adressen, welche dem Netzwerkadapter zugewiesen werden können. Dieser Wert wurde gewählt, da die Wahrscheinlichkeit, dass zwei Netzwerkadapter identisch adressiert werden recht gering (p = 0,03) und die Anzahl der im schlechtesten Falle zu durchlaufenden Scan–Vorgänge in einem überschaubaren Rahmen bleibt. Die Zahl 0 wird über die Addition der 1 bewusst ausgeklammert, da die 0 an letzter Stelle das komplette Subnetz definiert. 1 int CIpSwapper::createIp() 2 { 3 int checkIp = Random()%30+1; 4 return checkIp; 5 } 20 LISTING 6.1 : Generierung einer Zufallszahl für letztes Segment der IP–Adresse 19 20 winbase.h – Embedded Visual Studio 4 WLANConnector – IpSwapper.cpp - 31 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Der generierte Zufallswert ist vom Datentyp Integer und ist Rückgabewert der createIP– Funktion21. Dieser wird im Hauptdialog als Parameter an die folgende Funktion „swapIp“22 weitergereicht, welche nun die Manipulation der entsprechenden Registrierungseinträge vornimmt. Ziel ist die Vergabe einer IP–Adresse aus der Spanne von 192.168.1.1 bis 192.168.1.31. In Zeile 9 des Listings 6.2 wird der übergebene Wert an den statischen Teil der IP–Adresse angefügt und bildet die zu manifestierende String–Zuweisung. Wie aus Screenshot 6.1 ableitbar, müssen alle Werte welche die Auto–IP spezifizieren an die entsprechende Stelle in der Registrierung geschrieben werden. Dabei handelt es sich um die IP–Adresse („Auto–IP“) an sich, das verwendete Subnetz („AutoSubnet“) und die Subnetzmaske („AutoMask“). 1 void CIpSwapper::swapIp(int j) 2 { 3 HKEY hKey = NULL; 4 DWORD dwDisposition = 0; 5 DWORD dwSizeIp=13; 6 DWORD dwSizeSub=12; 7 DWORD dwSizeMask=14; 8 CString ip; 9 ip.Format(_T("192.168.1.%d"),j); 10 CString subnet = _T("192.168.1.0"); 11 CString mask = _T("255.255.255.0"); 12 CString dhcpip = ip; LISTING 6.2 : Deklaration der Variablen innerhalb der swapIP–Funktion Die Funktion RegCreateKeyEx23 erstellt einen neuen spezifizierten Key oder öffnet ihn, falls dieser bereits existiert. Der erste Parameter (Listing 6.2, Zeile 3) repräsentiert ein Handle (Verweis) auf einen eigens zu spezifizierenden Hauptschlüssel oder einen vordefinierten Eintrag, in unserem Fall HKEY_LOCAL_MACHINE, welcher konfigurationsspezifische Daten des Rechners enthält. Der zu öffnende oder zu erstellende Key ist diesem untergeordnet. Der Begriff Key bezieht sich hierbei auf einen Pfad innerhalb einer dateisystemsähnlichen Ordnerstruktur und ist nicht mit den darin enthaltenen Werten zu verwechseln. Es sei angemerkt, dass der Registrierungspfad (Listing 6.3, Zeile 3) „Comm\\vnetusba1\\Parms\\TCPIP” nicht allgemein gültig ist. Der Parameter „vnetusba1“ steht konkret für die in HP iPAQ 5500 integrierten WLAN– Adapter. Soll die Anwendung für andere Adapter angepasst werden, so muss die Bezeichnung dynamisch ausgelesen werden. Dies kann mit geeigneten NDISUIO–APIs geschehen (Kapitel 8.2). 21 WLANConnector – IpSwapper.cpp WLANConnector – IpSwapper.cpp 23 Winreg.h – Embedded Visual Studio 4 22 - 32 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Das auf der beiliegenden CD enthaltene Programm „ndistools2003“24 liest ebenfalls die Bezeichnungen von aktiven an das NDISUIO–Protokoll gebundenen WLAN–Adaptern auf Pocket PC 2003 Systemen aus und kann bei der Verifizierung von Ergebniswerten Verwendung finden. 1 RegCreateKeyEx( 2 HKEY_LOCAL_MACHINE, 3 _T("Comm\\vnetusba1\\Parms\\TCPIP"), 4 5 0, NULL, 0, 6 KEY_EXECUTE|KEY_READ|KEY_ALL_ACCESS, 7 NULL, 8 &hKey, 9 &dwDisposition ); LISTING 6.3 : Erstellen oder Öffnen eines Registry Keys In Zeile 8 der RegCreateKeyEx–Funktion (Listing 6.3) wird ein Zeiger auf eine Variable gesetzt, welche das Handle auf den geöffneten Key empfängt. Dieses Handle findet nun in der RegSetValueEx–Methode verwendung, indem es den Schlüssel spezifiziert, in welchem ein Wertefeld manipuliert oder erstellt wird. Listing 6.4 erläutert das Verfahren an der Veränderung des Datenfeldes mit der in Zeile 3 definierten Bezeichnung „AutoIP“. Der Zeiger auf den Datensatz, welcher an die angegebene Stelle geschrieben werden soll, wird in Zeile 6 parametrisiert. Hierbei wird die Zeichenkette aus der Initialisierung der Variablen „ip“ (Listing 6.2, Zeile 8) zu einem entsprechenden Datentyp gecastet, was einer Neuinterpretation des Datensatzes entspricht. Beachtung muss hierbei der Informationstyp des Datensatzes finden. In Zeile 5 des Listings 6.4 wird dieser in konkretisiertem Falle als REG_SZ Wert festgelegt, was einer null terminierten Unicode–Zeichenkette entspricht. 1 RegSetValueEx ( 2 hKey, 3 TEXT ("AutoIP"), 4 0, 5 REG_SZ, 6 (LPBYTE)(LPCTSTR)ip, 7 _tcslen(ip)*2+1); LISTING 6.4 : Schreiben der AutoIP–Variablen in CE Registrierung 24 www.pcausa.com/Utilities/ndistools.htm - 33 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Das Schreiben der Werte für „AutoSubnet“, „AutoMask“ und „DhcpIPAddress“ erfolgt starr nach diesem Muster und wird deshalb im Weiteren nicht näher beschrieben. Es ist lediglich die Zeichenkette in Zeile 3 des Listings 6.4 entsprechend abzuändern. Wird das Handle auf den geöffneten Registrierungsschlüssel nicht mehr gebraucht, sollte es durch den RegCloseKey–Befehl wieder freigegeben werden (Listing 6.5) [PPCDA05]. Dies bewirkt das Aufheben einer Zugriffssperre und erlaubt Manipulation durch andere Prozesse. 1 RegCloseKey(hKey); LISTING 6.5 : Freigabe des Handles auf einen geöffneten Key[PPCDA05] Die IP–Adresse des WLAN–Adapters im Ad–Hoc Modus ist somit eindeutig festgelegt, jedoch noch nicht aktiv übernommen. Bevor dies in die Tat umgesetzt werden kann wird zunächst der eigentliche Verbindungsaufbau in die Wege geleitet. 6.1.3 IP–Adresszuweisung mittels IP–Helper–Funktionen Die nun folgenden Operationen basieren auf einer Microsoft Bibliotheksdatei namens „iphlpapi.lib“25, welche die Verwendung der Internet Protocol Helper API ermöglicht. Diese Funktionen stehen dem Anwendungsentwickler innerhalb der zu inkludierenden Headerdatei „Iphlpapi.h“ zur Verfügung und unterstützen das Auslesen von Informationen über lokale Netzwerkadapter. Weiterhin dienen sie der Modifizierung der IP–Konfiguration [MSDN05]. Im Fokus steht die Verwaltung von IP–Adressen auf dem WLAN–Adapter. Es geht darum, die in der Registrierung abgelegte IP–Konfiguration über die DHCP–Adresszuweisung an das entsprechende Device zu binden und somit für die Netzwerkommunikation über das TCP/IP–Protokoll zu aktivieren. Über die Funktion IpRenewAddress aus der „iphlpapi.lib“ „mietet“ sich der Netzwerkadapter eine für ihn bereitgestellte Adresse von einem DHCP–Server. Dieses Verfahren wird in entwickelter Software dazu eingesetzt, eine bereits in der lokalen Registrierung angelegte IP–Konfiguration über Automatic Private IP Addressing (APIPA) umzusetzen. Ein frei verfügbares Programm namens „MyIpConfig“26, welches auf beigelegter CD als Executable und im Quelltext abgelegt wurde, arbeitet mit dieser Bibliothek und wurde zu einer Wrapperklasse umgeschrieben und an die konkreten Anforderungen angepasst. Die angepasste Klasse „CIpHelper“27 wurde in das „WLANConnector“ Embedded Visual Studio Projekt eingebunden. 25 iphlpapi.lib – Embedded Visual Studio 4 http://sourceforge.net/projects/myipconfig 27 WLANConnector – IpHelper.cpp 26 - 34 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Die enthaltene renew–Funktion28 wird nach erfolgtem WLAN–Verbindungsaufbau aufgerufen. Dies macht Sinn, da sich der Adapter erst im Ad–hoc Modus auf die Verwendung des APIPA–Verfahrens einstellt. Da der Adapter eine kurze Zeitspanne zur Verbindungsherstellung im Ad–hoc–Modus benötigt, wurde die Programmausführung über die Sleep–Funktion29 um drei Sekunden verzögert. 30 In Zeile 6 des Listings 6.6 werden durch die GetAdaptersInfo–Funktion verfügbare Netzwerkadapter enumeriert und in einem Array von IP_ADAPTER_INFO–Strukturen31 verwaltet. Diese Strukturen enthalten Informationen wie den Namen des Adapters, Beschreibung, IP–Adresse, Gateway, DHCP Server Adresse usw. Die find–Funktion aus Zeile 7 weist der Variablen „a“ vom Typ „IpAdapter“ den WLAN– Adapter mit Namen „VNETUSBA1“ zu, auf welchem in Zeile 11 die IpRenewAddress– Operation durchgeführt wird. Der Übergabeparameter dieser Funktion ist eine vorgegebene Zeitspanne in Sekunden, in welcher die Adresszuweisung abgeschlossen werden muss. Wird dieser Wert überschritten wird die Operation abgebrochen und ein Fehlercode zurückgegeben. 1 CString CIpHelper::renew() 2 { 3 IpAdapter currentAdapter; 4 IpAdapters* pAdapterInfo; 5 6 pAdapterInfo = IpAdapters::GetAdaptersInfo(); 7 IpAdapter a = pAdapterInfo–>find("VNETUSBA1"); 8 9 Sleep(3000); 10 11 a.IpRenewAddress(3); 12 } LISTING 6.6 : IpRenewAddress – Internet Protocol Helper API 28 WLANConnector – IPHelper.cpp winbase.h – Embedded Visual Studio 4 30 WLANConnector – IpHelper.cpp 31 iptypes.h – Embedded Visual Studio 4 29 - 35 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario 6.2 Der Ad–hoc–Adapterkonfiguration über NDISUIO Verbindungsaufbau innerhalb der ersten zwei Schichten des OSI Kommunikationsmodells wird mittels der in Kapitel 5.6.2 erläuterten NDISUIO–Operationen durchgeführt. IOCTL–Kontrollnachrichten werden innerhalb der angesprochenen DeviceIoControl–Befehle an den Adapter weitergeleitet und versetzen das WLAN–Device in den gewünschten Zustand auf hardwarenaher Ebene. Nachdem, wie in Kapitel 5.6.2 dokumentiert, ein Device–Handle erzeugt und an das NDISUIO–Protokoll gebunden wird, können die Network Driver Interface Specification Object Identifier geschrieben werden. Es ist dabei von der Hardware der WLAN–Adapter abhängig, welche OID–Varianten unterstützt werden. Jede dieser OIDs bewirkt eine in sich gekapselte Konfigurationsänderung. Die folgende Auflistung der Vorgänge und der dazugehörigen OIDs erläutert die Reihenfolge, welche bei der Implementierung Verwendung fand. Es zeigte sich, dass lediglich das Schreiben der SSID die abschließende Operation sein sollte, da mit dieser Aktion Änderungen übernommen werden und der Adapter einen Verbindungsversuch in die Wege leitet [WPDN203]. • Setzen des Infrastrukturmodus [OID_802_11_INFRASTRUCTURE_MODE] • Setzen des Authentifizierungsmodus [OID_802_11_AUTHENTICATION_MODE] • Setzen des WEP Schlüssels (optional) [OID_802_11_ADD_KEY] • Aktivieren der WEP Verschlüsselung [OID_802_11_ADD_WEP] • Setzen der SSID / BSSID / IBSSID [OID_802_11_SSID] Î Adapter übernimmt Netzwerk Konfiguration Um den Umgang mit den OIDs in den angeführten Quelltextauszügen zu verstehen macht es Sinn, sich deren Struktur etwas näher zu betrachten. In Zeile 7, Listing 6.7 wird eine Variable vom Typ PNDISUIO_SET_OID32 deklariert. Die Variablenbezeichnung lässt darauf schließen, dass es sich hierbei um eine Struktur handelt, welche schreibend, also konfigurierend, zugreift. Für Leseoperationen wird der ebenfalls in der „nuiouser.h“ definierte Typ PNDISUIO_QUERY_OID verwendet. Es handelt sich hier wieder um einen Datentyp, welcher untergeordnete Strukturen umschließt und mit zusätzlichen Informationen versehen, in abstrakterem Kontext weiterverwendet [MSDN05]. Wie der Strukturdefinition aus Listing 6.7 zu entnehmen ist, umschließt die PNDISUIO_SET_OID–Struktur die Ausprägung des eigentlichen Object Identifiers vom Typ NDIS_OID (Zeile 2). 32 nuiouser.h – Pocket PC 2003 SDK - 36 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Weiterhin ist ein Zeiger auf einen Datencontainer, welcher den Namen des zu manipulierenden Gerätes entspricht (Zeile 4) und einen Puffer für OID–Werte und Rückgabedaten (Zeile 6) beinhaltet. Das ifdef aus Zeile 3 sagt aus, dass der Gerätename lediglich bei Windows CE und Varianten zur Verfügung steht. Das Kapitel 9 geht näher auf diese Besonderheit ein. 1 typedef struct _NDISUIO_SET_OID { 2 NDIS_OID Oid; 3 #ifdef UNDER_CE 4 PTCHAR ptcDeviceName; 5 #endif 6 UCHAR Data[sizeof(ULONG)]; 7 } NDISUIO_SET_OID, LISTING 6.7 : Struktur NDISUIO_SET_OID 6.2.1 33 Setzen des Infrastrukturmodus Der erste Konfigurationsvorgang bezieht sich auf die Spezifikation des Infrastruktur–Modus. Betätigt man den Softbutton, welcher die Verbindungsbereitschaft im Ad–hoc–Modus aktiviert, so wird die Funktion setAdhoc ausgeführt. Diese Methode ist der Klasse „DeviceControl“ zugehörig und enthält alle NDISUIO–spezifischen Operationen. Alle nötigen Netzwerkparameter sind in diese Funktion statisch integriert. In den Zeilen 9 bis 11, Listing 6.8, wird die NDISUIO_SET_OID–Struktur gefüllt, welche in Zeile 9 dem in den Zeilen 5 bis 6 reservierten Speicherplatz zugeordnet wird. Die Zuweisung des Gerätenamens erfolgt in Zeile 10, wohingegen in Zeile 11 der Object Identifier festgelegt wird. In Zeile 14 und 15 wird der Wert der OID in den Datenpuffer kopiert. Dessen Ausprägung entspricht bei Setzen des Infrastrukturmodus einem Integer Wert, welcher in Zeile 2 festgelegt wird. Die Variablendeklaration Ndis802_11IBSS steht für das Independent Basic Service Set und findet seine Wertezuweisung in der Header–Datei „ntddndis.h“. Mögliche Ausprägungen, welche die OID_802_11_INFRASTRUCTURE_MODE–OID Ndis802_11IBSS für die Ad–hoc–Variante, annehmen Ndis802_11Infrastructure kann sind für den Verbindungsaufbau zu einem AccessPoint und Ndis802_11AutoUnknown, was bedeutet, dass der 802.11–Netzwerkadapter zwischen Ad–hoc und Infrastruktur je nach Bedarf wechseln kann [MSDN05]. Die memcpy34–Funktion kopiert hierbei Binärdaten einer festgelegten Größe von einer durch einen Zeiger definierten Speicheradresse zu einer anderen. Der erste Parameter steht für 33 34 nuiouser.h – Pocket PC 2003 SDK stdlib.h – Embedded Visual Studio 4 - 37 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario die Zieladresse, der zweite Parameter für die Quelladresse, an welcher der zu kopierende Datensatz abgelegt wird und der dritte Parameter bestimmt dessen Größe in Bytes [MSDN05]. Über die DeviceIoControl–Funktion in Zeile 17 wird der bereits gefüllte Puffer an das durch das Handle spezifizierte Device weitergegeben. Eine Ausführliche Abhandlung des Befehles und seine Funktion innerhalb der NDISNetzwerktreiber-Architektur wurde in Kapitel 5.6.2 gegeben. Zur Vereinfachung des Debuggens werden in Zeile 26 bis 30 Fehler bei der Ausführung der DeviveIoControl– Funktion als Rückgabewert der „setAdhoc“–Methode35 ausgegeben. 1 int* pnNetworkMode; 2 int NMode = Ndis802_11IBSS; 3 pnNetworkMode = &NMode; 4 5 UCHAR SetBufferNetM[sizeof(NDIS_OID)+ 6 sizeof(NDIS_802_11_NETWORK_INFRASTRUCTURE) + sizeof(DWORD)]; 7 PNDISUIO_SET_OID pSetOidNetM; 8 9 pSetOidNetM = (PNDISUIO_SET_OID) &SetBufferNetM[0]; 10 pSetOidNetM–>ptcDeviceName = TEXT("VNETUSBA1"); 11 pSetOidNetM–>Oid = OID_802_11_INFRASTRUCTURE_MODE; 12 13 14 memcpy(&pSetOidNetM–>Data[0], 15 pnNetworkMode,sizeof(NDIS_802_11_NETWORK_INFRASTRUCTURE)); 16 17 retval = DeviceIoControl(m_hDeviceHandle, 18 IOCTL_NDISUIO_SET_OID_VALUE, 19 (LPVOID) &SetBufferNetM[0], 20 sizeof(SetBufferNetM), 21 (LPVOID) &SetBufferNetM[0], 22 0, 23 &m_dwBytesReturned, 24 NULL); 25 26 if(!retval) 27 { 28 DWORD m_dwError = GetLastError(); 29 return ("Nach Ad–Hoc failed"); 30 } LISTING 6.8 : Setzen des Infrastrukturmodus auf Ad–hoc 35 36 WLANConnector – DeviceControl.cpp Anpassung der WRAPIb2.0 – WRAPI.cpp - 38 - 36 WLAN–Verbindungsaufbau im Ad–hoc–Szenario 6.2.2 Setzen des Authentifizierungsmodus Nachdem, nach Abarbeitung der obigen Befehlssequenz, die Ausprägung der Infrastruktur festgelegt wurde, erfolgt im nächsten Schritt das Setzen des Authentifizierungsmodus (Listing 6.9). Die Implementierung kann hierbei fast identisch aus Listing 6.8 übernommen werden. Das hier zu definierende Merkmal bestimmt die Art der Zugangskontrolle zu einem Netzwerk, beispielsweise über einen RADIUS (Remote Authentication Dial–In User Service) Server. Sicherheitsmaßnahmen innerhalb kabelloser Netzwerke wurden in Kapitel 2.5 erläutert und sind für diese Arbeit nur am Rande von Bedeutung. Dennoch handelt es sich bei der Verwendung dieser OID um eine obligatorische Maßnahme, ohne die kein Verbindungsaufbau eingeleitet werden kann. Die Ausprägung der NDIS–OID OID_802_11_AUTHENTICATION_MODE über den Wert Ndis802_11AuthModeOpen führt zur Verwendung eines Protokolls für Systeme ohne weitere Zugangskontrolle und wurde in entwickelter Software eingesetzt. Der Einsatz von WEP als Verschlüsselungsstandard wird hierbei nicht beeinflusst [MSDN05]. 1 int pnAuthMode = Ndis802_11AuthModeOpen; 2 UCHAR SetBufferAuth[sizeof(NDIS_OID) + 3 sizeof(NDIS_802_11_AUTHENTICATION_MODE)+sizeof(DWORD)]; 4 PNDISUIO_SET_OID pSetOidAuth; 5 6 pSetOidAuth = (PNDISUIO_SET_OID) &SetBufferAuth[0]; 7 pSetOidAuth–>Oid = OID_802_11_AUTHENTICATION_MODE; 8 pSetOidAuth–>ptcDeviceName = TEXT("VNETUSBA1"); 9 10 memcpy(&pSetOidAuth–>Data[0], 11 &pnAuthMode,sizeof(NDIS_802_11_AUTHENTICATION_MODE)); 12 13 if (!DeviceIoControl( 14 m_hDeviceHandle, 15 IOCTL_NDISUIO_SET_OID_VALUE, 16 (LPVOID) &SetBufferAuth[0], 17 sizeof(SetBufferAuth), 18 (LPVOID) &SetBufferAuth[0], 19 0, 20 &m_dwBytesReturned, 21 22 NULL)) { DWORD m_dwError = GetLastError(); } LISTING 6.9 : Setzen des Authentifizierungsmodus (Anpassung der WRAPI) 37 Anpassung der WRAPIb2.0 – WRAPI.cpp - 39 - 37 WLAN–Verbindungsaufbau im Ad–hoc–Szenario 6.2.3 Setzen der SSID Um den 802.11–Netzwerkadapter endgültig in den Ad–hoc–Modus zu versetzen wird der Service Set Identifier des zu assoziierenden Netzwerkes an den Miniport–Treiber weitergegeben. Unabhängig von der Präsenz eines potentiellen Ad–hoc–Partners wird eine aktive Sende– und Empfangsbereitschaft in die Wege geleitet. Dieses Verhalten liegt in der Natur eines unabhängigen Netzwerkverbundes und unterscheidet sich maßgeblich von einem Verbindungsversuch zu einem AccessPoint, bei welchem ein Statuswechsel von einem verbindungslosen zu einem verbundenen Zustand nur bei Assoziation mit einem entsprechend konfigurierten WLAN–Knoten stattfindet. Die Ausprägung der OID_802_11_SSID wird in diesem Falle nicht durch einen ganzzahligen Wert definiert, sondern über eine eigene Struktur namens NDIS_802_11_SSID. Der Aufbau dieser Struktur sei in Listing 6.10 aufgeschlüsselt. Da die SSID durch eine Zeichenkette von bis zu 32 Buchstaben gebildet werden kann, werden als Strukturelemente zum einen das Unsigned Char Arrays, welches die Zeichenkette beinhaltet (Zeile 4), und zum anderen dessen Länge (Zeile 3) benötigt. 1 typedef struct _NDIS_802_11_SSID 2 { 3 4 5 ULONG SsidLength; UCHAR Ssid[32]; } NDIS_802_11_SSID, *PNDIS_802_11_SSID; LISTING 6.10 : Struktur NDIS_802_11_SSID 38 In Zeile 12 wird eine Instanz dieser Struktur ins Leben gerufen, welcher in Zeile 18 die Länge der SSID Zeichenkette und in Zeile 20 den Inhalt mit Hilfe des vertrauten memcpy–Befehls (vgl. Kapitel 6.2.1) zugewiesen wird. Der weitere Ablauf unterliegt bekanntem Schema. 1 char strSSID[5]; 2 strcpy(strSSID,"AdhocNet"); 3 4 ULONG ISSIdLength; 5 ISSIdLength = strlen(strSSID); 6 7 UCHAR *pSSId = (UCHAR*)strSSID; 8 ULONG& lSSIdLength = ISSIdLength; 9 38 10 UCHAR SetBuffer[sizeof(NDIS_OID) + sizeof(NDIS_802_11_SSID)]; 11 PNDISUIO_SET_OID pSetOid; ntddndis.h – Embedded Visual Studio 4 - 40 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario 12 NDIS_802_11_SSID SSID; 13 14 pSetOid = (PNDISUIO_SET_OID) &SetBuffer[0]; 15 pSetOid–>ptcDeviceName = TEXT("VNETUSBA1"); 16 pSetOid–>Oid = OID_802_11_SSID; 17 18 SSID.SsidLength = ISSIdLength; 19 20 memcpy(&SSID.Ssid[0],pSSId,ISSIdLength); 21 memcpy(&pSetOid–>Data[0], &SSID, sizeof(NDIS_802_11_SSID)); 22 23 retval = DeviceIoControl( 24 m_hDeviceHandle, 25 IOCTL_NDISUIO_SET_OID_VALUE, 26 (LPVOID) &SetBuffer[0], 27 sizeof(SetBuffer), 28 (LPVOID) &SetBuffer[0], 29 0, &m_dwBytesReturned, 30 NULL); 31 32 33 if(!retval) return ("Set SSID failed"); 39 LISTING 6.11 : Setzen der SSID / BSSID / IBSSID Der Adapter wechselt nun in den Ad–hoc–Modus und übernimmt alle spezifizierten Merkmale. Da das charakteristische Ad–hoc–Verhalten auf Grund des auslesbaren Verbindungsstatus keinen Aufschluss über die Existenz eines Gegenübers liefert, musste ein anderweitiger Lösungsansatz entwickelt werden, welcher im nächsten Kapitel erläutert wird. 39 Anpassung der WRAPIb2.0 – WRAPI.cpp - 41 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario 6.3 Netzwerkscan und dynamischer Verbindungsaufbau Da das aktive Scannen nach Netzwerkpartnern ein Vorgang sein sollte, welcher unabhängig von dem Interaktionsprozess auf grafischer Ebene und fortlaufend im Hintergrund geschehen sollte, wurde ein so genannter Worker Thread implementiert. Unter einem Worker Thread versteht man ein unabhängiges Softwaresegment, welches quasi parallel zum eigentlichen Main Thread eine sequentielle Befehlsabarbeitung durchführt. Da das Testen auf Verfügbarkeit von Kommunikationspartnern innerhalb einer Endlosschleife geschieht, würde die grafische Interaktion mit der Software solange unterbunden werden, bis ein vordefiniertes Event das Durchlaufen der Schleife beendet. Man spricht hierbei von aktivem Polling. Dies bedeutet, dass es im Stadium des Suchens keine Möglichkeit gäbe, das Programm in einen anderen Zustand zu versetzen. Ruft man sich die grundlegenden Anforderungen an den automatisierten WLAN– Verbindungsaufbau aus Kapitel 3 ins Gedächtnis zurück, so erkennt man hier die Erfüllung der Notwendigkeit des konfliktfreien Wechsels der Infrastrukturmodi aus Abschnitt 3.4.2. Weiterhin muss es der Software möglich sein, selbst nach einem erfolgreich abgeschlossenen Suchvorgang weiterhin auf Vorhandensein eines Gegenübers zu prüfen um Verbindungsverluste innerhalb einer vorgegebenen Latenzzeit zu erkennen und entsprechende Maßnahmen zu einzuleiten. Dies entspricht der Anforderung an den dynamischen Verbindungsaufbau aus Kapitel 3.5. Die Threadfunktion „ScanIP“40 wird bei der Initialisierung des Hauptdialoges aufgerufen. Das Starten des Programmfadens (Threads) entspricht folgenden Programmzeilen: 1 DWORD dwThreadID1 = 0; 2 hThread2 = CreateThread(NULL, 0,ScanIP, this, 0, &dwThreadID1); LISTING 6.12 : Erzeugen des Worker Threads mit der Threadfunktion ScanIP Parameter 3 konkretisiert die auszuführende Funktion. Über den this–Operator aus Zeile 2 wird ein Zeiger auf das aktuelle Objekt, aus dessen Kontext die CreateThread–Funktion aufgerufen wird, übergeben. Dies ist in konkretem Falle ein Zeiger auf eine Instanz der „CWLANConnectorDlg“–Klasse, welche die Implementierung des MFC–Dialoges verkörpert. Damit wird dem Thread Zugriff auf klasseninterne Funktionen und Variablen ermöglicht [PPCDG05]. Innerhalb der übergeordneten Endlosschleife wird zunächst geprüft, ob sich der Adapter im Ad–hoc–Modus befindet und ob eine aktive Verbindung besteht. Dies wäre nicht der Fall, wenn zwar eine Ad–hoc–Bereitschaft angestrebt, jedoch noch nicht erfolgreich in die Wege geleitet wurde. 40 WLANConnector – WLANConnectorDlg.cpp - 42 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Erst wenn diese beiden Bedingungen erfüllt sind, wird der eigentliche Schleifenkörper in die Befehlsabarbeitung einbezogen. Auch eine Lösung über Mutexe, bzw. Semaphoren oder aktionsabhängiges Starten und Beenden des Threads wären denkbare Ansätze. Über die Zustandsvariable „foundDevice“ wird gespeichert, ob ein Scanvorgang zum Erfolg führte. Der Initialisierungswert ist „keine Verbindung“, also der Zahlenwert 0. In einem Durchlauf der endlosen while–Schleife soll die komplette IP–Adressspanne potentieller Partner überprüft werden. Dies erfolgt innerhalb einer eingebetteten for–Schleife, welche in jedem der 30 Durchläufe einen ICMP Echo Request auf eine Adresse absetzt. Die Schleife startet bei der IP–Adresse 192.168.1.1 und endet im letzten Durchlauf mit der 192.168.1.30. Der Rückgabewert der IcmpSendEcho–API–Funktion41 signalisiert den Erhalt eines ICMP Echo Reply Paketes und damit das Vorhandensein eines antwortenden Ad– hoc–Gerätes. Ist dies der Fall, wird die Zustandsvariable („foundDevice“) auf den Wert 1 eingesetzt und die gefundene IP–Adresse inklusive Signalstärke ausgegeben. Des Weiteren merkt sich das Programm, dass eine Antwort innerhalb des aktuellen Durchlaufes erhalten wurde, in dem ein Fehlerzähler („failureCounter“) auf den Wert 0 zurückgesetzt wird. Diese Information wird genutzt um kurzzeitige Verbindungsunterbrechungen innerhalb der angesprochenen Latenzzeit zu berücksichtigen. Der Wert der Variable wird bei Austritt aus der for–Schleife inkrementiert und speichert die Anzahl erfolgloser Durchläufe. Er wird erst wieder auf 0 zurückgesetzt, wenn eine erneute Antwort eines Hosts eintrifft. Die Zustandsvariable „foundDevice“ nimmt nach einer bestimmten Anzahl erfolgloser Netzwerkscans den Wert „nicht verbunden“ an. Die Latenzzeit kann über Änderung der Rücksetzbedingung dieser Variable gesteuert oder völlig deaktiviert werden. Nach jedem kompletten Scandurchlauf wird die Statusanzeige aktualisiert, in dem die Variable „foundDevice“ grafisch ausgewertet wird. Da ein Quelltext–Listing der „ScanIP“– Funktion42 an dieser Stelle zu umfangreich und unübersichtlich wäre, verdeutlicht das Struktogramm aus Abbildung 6.1 das dargestellte Verhalten. Funktionen und Wertezuweisungen werden innerhalb der abgerundeten Rechtecke visualisiert. Die Rauten weisen auf Programmverzweigungen hin, welche sich durch Erfüllung der jeweiligen Bedingungen an den Pfaden ergeben. Die Ausgabeaktionen sind farbig unterlegt, was der Farbgebung der Indikatorelemente in der entwickelten Software „WLANConnector“ entspricht. Die Farbe grün weist auf das Vorhandensein eines Ad–hoc–Partners hin, während die Farbe rot dessen Fehlen symbolisiert. Das Inkrementieren der IP–Adresse beschränkt sich in der Abbildung der Einfachheit halber auf das letzte Segment dieses Konstruktes, welches softwareintern an seinen statischen Teil angefügt wird. Auch die Parameterübergabe der IcmpSendEcho–Funktion wurde auf das Wesentliche, nämlich den variierende Teil der IP–Kennung, reduziert. 41 42 icmpapi.h – Embedded Visual Studio 4 WLANConnector – WLANConnectorDlg.cpp - 43 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Abbildung 6.1 : Erzeugen des Worker Threads mit der Threadfunktion ScanIP - 44 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario 6.4 SCREENSHOT 6.2 :WLANConnector SCREENSHOT 6.3 : WLANConnector Ad–hoc Netzwerkscan Ad–hoc verbunden Integration einer 3rd Party Voice over IP Anwendung Zum Testen der aufgebauten Ad–hoc–Verbindung wurde eine Voice over IP (VOIP) Anwendung gewählt. Gründe dafür waren der enorme praktische Nutzen für den Einsatz in einem Kraftfahrzeug und der starke Bezug zu einleitendem Tankstellenszenario. 6.4.1 Voraussetzungen Vorraussetzung an die Anwendung war der mögliche Betrieb im Ad–hoc–Modus und die Unterstützung des Betriebssystems Pocket PC 2003. Da die Entwicklung einer eigenen Software den Rahmen dieser Arbeit sprengen und eine eigenständige Abhandlung füllen würde, wurde auf Vorhandenes zurückgegriffen. Das softwarebasierte VOIP–Telefon SJphone® von SJ Labs43 erfüllt die gestellten Voraussetzungen und bietet zudem hervorragende Ergebnisse bezüglich der erreichbaren Sprachqualität. Die Software Skype44 schied bei Betrachtung der oben gestellten Kriterien aus, da ein Betrieb nur mit vorhandener Internetanbindung möglich ist. 43 44 www.sjlabs.com/sjp.html www.skype.com/products/skype/pocketpc/ - 45 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario Die Installation der gewählten VOIP–Anwendung wird mit Hilfe von Active Sync45 auf dem Handheld durchgeführt. Ideal wäre das softwareinterne Starten des VOIP–Telefons mit der IP–Adresse des Netzwerkpartners als Parameter. Unvorteilhafterweise ist diese Option von den Programmierern nicht vorgesehen. Um potentielle Gesprächspartner ausfindig zu machen, arbeitet das Telefon mit dem Neighbourhood Discovery Protocol, welches im Internet Protocol Version 6 (IPv6) Verwendung findet. Eine Telefonkonferenz lässt sich bei gestarteter Anwendung mit einigen wenigen Aktionen einleiten. Dies entspricht nicht dem Idealfall, ist aber zu Zwecken der Verifikation des Verbindungsaufbaues und der Übertragungsqualität im mobilen Einsatz ausreichend. 6.4.2 Implementierung Die Softwareintegration wird durch die „OnTalk“–Funktion46 aus Listing 6.13 umgesetzt. Diese Funktion wird aufgerufen, wenn der entsprechende Softbutton im MFC–Hauptdialog betätigt wird. Die Schaltfläche wird erst aktiviert, wenn sich der Adapter in aktiver Kommunikationsbereitschaft, entweder im Ad–hoc– oder im Infrastruktur–Modus, befindet. In Zeile 7 wird mit Hilfe der CreateProcess–Funktion ein neuer Prozess gestartet, welcher die in Zeile 8 spezifizierte Anwendung ausführt. Die PROCESS_INFORMATION–Struktur aus Zeile 5 enthält Identifikationsinformationen über den neuen Prozess, welche in Zeile 17 geschrieben werden. Alle weiteren Parameter sind nicht weiter von Belang und können bei Bedarf in der Microsoft Developer Network (http://msdn.microsoft.com/) nachgeschlagen werden. 1 #include <Winbase.h> 2 3 void CWLANConnectorDlg::OnTalk() 4 { 5 PROCESS_INFORMATION pInfo; 6 45 46 7 CreateProcess( 8 _T("\\Programme\\SJphone\\SJphone.exe"), 9 NULL, 10 NULL, 11 NULL, 12 FALSE, 13 0, 14 NULL, www.microsoft.com/windowsmobile/downloads/activesync38.mspx WLANConnector – WLANConnectorDlg.cpp - 46 - WLAN–Verbindungsaufbau im Ad–hoc–Szenario 15 NULL, 16 NULL, 17 &pInfo); } LISTING 6.13 : Sofwareinternes Starten der VOIP Anwendung mit Hilfe von CreateProcess 6.4.3 Testdurchführung und Bewertung Das erstellte Programm wurde nach der Integration des VOIP–Telefons einem Praxistest unterzogen. Zwei Autos wurden mit je einem HP iPAQ mit identisch aufgespielter Software ausgestattet. Innerorts und auf der Landstraße sollte eine aktive Ad–hoc–Verbindung hergestellt und die IP–Adresse des Gerätes in dem anderen Fahrzeug ausgelesen werden. Weiterhin sollte dann eine Telefonkonferenz mittels VOIP–Software hergestellt und genutzt werden. Das Ergebnis war recht zufrieden stellend. Bei getesteten Geschwindigkeiten von bis zu 100 km/h war eine Kommunikation möglich. Die überbrückbare Entfernung lag bei circa 50 Metern, wobei unregelmäßiges Annähern und Entfernen des Öfteren Grund für Verbindungsunterbrechungen waren. Die für den Einsatz in einem Kraftfahrzeug relativ geringe Signalreichweite scheint unbefriedigend. Der Einsatz von externen Antennen und Stromversorgung könnte Abhilfe schaffen. SCREENSHOT 6.4 : VOIP Telefon SJphone 47 47 www.sjlabs.com/sjp.html - 47 - 7. WLAN–Verbindungsaufbau im Infrastruktur– Szenario 7.1 Adapterkonfiguration über NDISUIO Die Konfiguration des WLAN–Adapters für die Verwendung im Infrastruktur–Modus entspricht den in Kapitel 6.2 erläuterten DeviceIoControl–Operationen. Die verwendeten OIDs sind identisch. Es müssen lediglich die Ausprägungen der NDIS Object Identifier an den infrastrukturellen Verbindungsaufbau angepasst werden. Beim Setzen des Infrastrukturmodus unter Verwendung des OID_802_11_INFRASTRUCTURE_MODE Object Identifier wird der Integer–Wert, welcher durch die Bezeichnung Ndis802_11Infrastructure konkretisiert wird, in den Datenpuffer der instantiierten PNDISUIO_SET_OID–Struktur kopiert und an den WLAN–Adapter weitergegeben. Danach wird nach gewohntem Muster mit dem Authentifizierungsmodus verfahren. Änderungen sind hier nicht notwendig. Das Schreiben der SSID entspricht ebenfalls dem Quelltextauszug aus Listing 6.11 mit angepasster SSID. Wie im Ad–Hoc–Modus wird nach diesem Vorgang die Konfiguration vom Adapter übernommen. Allerdings ändert sich das Verhalten bei der Verbindungsherstellung grundlegend. Während im Ad–hoc–Modus generell und unabhängig von in Reichweite befindlichen WLAN–Geräten Sende– und Empfangsbereitschaft hergestellt wurde, erfolgt ein Verbindungsaufbau nur bei Vorhandensein eines kompatibel konfigurierten Access Points. Wenn bereits eine Bindung zu einem Access Point mit anderer SSID besteht, so erfolgen Verbindungstrennung und Statuswechsel. Der WLAN–Adapter befindet sich nun in verbindungslosem Zustand. Dies kann über eine Abfrage mit Hilfe der OID_GEN_MEDIA_CONNECT_STATUS–OID überprüft werden, wie im nächsten Kapitel beschrieben. Im Weiteren versucht sich der Adapter mit einem Netzwerk mit vorgegebener SSID zu verbinden. Entspricht sich die Konfiguration, so wird dieser Vorgang erfolgreich abgeschlossen. Dies resultiert in einem Zustandswechsel. Wird die OID geschrieben, wenn eine Assoziation mit einem Netzwerk mit übereinstimmender SSID besteht, so wirkt sich dies in einer Verbindungstrennung und einem erneuten Verbindungsvorgang zu diesem Access Point aus. Dies muss sich nicht in einem Statuswechsel erkenntlich zeigen. Wird nicht explizit über die OID_802_11_NETWORK_TYPE_IN_USE–OID ein Netzwerktyp wie 802.11b oder 802.11g festgelegt und sind alternative Netzwerkentsprechungen vorhanden, so kann der Netzwerkadapter autonom nach bestimmten Kriterien, wie Signalstärke oder Lebensdauer der Batterie, entscheiden [MSDN05]. - 48 - WLAN–Verbindungsaufbau im Infrastruktur–Szenario 7.2 Dynamischer Verbindungsaufbau Ist der Verbindungsversuch nach Schreiben der SSID nicht erfolgreich, so verbleibt der Adapter in unverbundenem Zustand. Verbindungsversuche müssen daher wiederholt eingeleitet werden bis ein entsprechender Access Point gefunden wurde. Zu diesem Zweck wurde ein weiterer Worker Thread, welcher die Thread–Funktion „ScanAP“48 ausführt, implementiert. Innerhalb einer Endlosschleife wird hierbei der Verbindungsstatus abgefragt. Wenn sich die Software in infrastruktureller Verbindungsbereitschaft befindet und die Statusabfrage ergibt, dass keine Netzwerkanbindung besteht, bemüht sich das Programm erneut um Verbindungsaufbau. Eine Verzögerung von fünf Sekunden innerhalb eines Schleifendurchlaufes gewährleistet, dass dem WLAN–Adapter genügend Zeit zur Verfügung gestellt wird, um eine erfolgreiche Access Point Anbindung in die Wege zu leiten. Wird die Verzögerung zu kurz bemessen, wird eine erneute Adapterkonfiguration vorgenommen obwohl ein Verbindungsversuch zu einer verfügbaren Basisstation bereits initiiert wurde. Abbildung 7.1 : Auslesen des Verbindungsstatus über NDISUIO 48 WLANConnector – WLANConnectorDlg.cpp - 49 - WLAN–Verbindungsaufbau im Infrastruktur–Szenario Das SCREENSHOT 7.1 :WLANConnector SCREENSHOT 7.2 : WLANConnector Infrastruktur Netzwerkscan Infrastruktur verbunden Testen auf Verbindung übernimmt die in Listing 7.1 zusammengefasste Befehlssequenz. Über eine IOCTL–Struktur wird diesmal lesend auf den Miniport–Treiber zugegriffen. Das Kopieren der Ausprägungen in den Datenpuffer vor Ausführung des DeviceIoControl–Befehles entfällt daher. In Zeile 6 wird ein Abfragepuffer angelegt und in Zeile 7 eine Instanz einer PNDISUIO_QUERY_OID–Struktur erstellt. Die enthaltene OID wird mit OID_GEN_MEDIA_CONNECT_STATUS konkretisiert (Zeile 11). Die Rückgabedaten werden in den Datenpuffer geschrieben (Zeile 17) und in Zeile 22 in den Adressbereich der hierfür erstellten Variable vom Typ NDIS_MEDIA_STATE kopiert. Dieser Datentyp kann zwei Ausprägungen annehmen: „NdisMediaStateConnected“ oder „NdisMediaStateDisconnected“. Der Rückgabewert der Funktion wird in den Zeilen 24 bis 29 bestimmt. Ist der Netzwerkadapter verbunden so wird ein „wahr“, also eine 1 zurückgegeben, andernfalls ein „falsch“ in Form einer 0. 1 DWORD 2 bool retval; m_dwBytesReturned = 0; 3 4 NDIS_MEDIA_STATE conn; 5 6 UCHAR QueryBufferCheckCon[1024]; 7 PNDISUIO_QUERY_OID pQueryOidCheckCon; 8 9 pQueryOidCheckCon = (PNDISUIO_QUERY_OID)&QueryBufferCheckCon[0]; 10 pQueryOidCheckCon–>ptcDeviceName = TEXT("VNETUSBA1"); 11 pQueryOidCheckCon–>Oid = OID_GEN_MEDIA_CONNECT_STATUS; 12 - 50 - WLAN–Verbindungsaufbau im Infrastruktur–Szenario 13 retval = DeviceIoControl(m_hDeviceHandle, 14 IOCTL_NDISUIO_QUERY_OID_VALUE, 15 (LPVOID) &QueryBufferCheckCon[0], 16 sizeof(QueryBufferCheckCon), 17 (LPVOID) &QueryBufferCheckCon[0], 18 sizeof(QueryBufferCheckCon), 19 &m_dwBytesReturned, 20 NULL); 21 22 memcpy(&conn,&pQueryOidCheckCon–>Data[0],sizeof(NDIS_STATUS)); 23 24 if (conn == NdisMediaStateConnected) 25 { return 1; 26 27 } 28 else return 0; 29 } LISTING 7.1: Auslesen des Verbindungsstatus über NDISUIO 7.3 49 Integration einer Informationsanwendung Bei der Realisierung eines geeigneten Testszenarios wurde ein Weg gesucht, Dateien sowie Informationen von einem Server in einem konventionellen Kabelnetzerk an den Client im KFZ zu senden. Eine Möglichkeit wäre die Implementierung von TCP/IP–Sockets, über welche Datenpakete jeglicher Form übermittelt werden könnten. Um die Informationen verwertbar zu machen müsste dann jedoch eine ausgeklügelte Navigation umgesetzt werden. Eine Software, welche die übersichtliche, strukturierte Visualisierung von Informationen von Natur aus beherrscht, ist der Internetbrowser. Dieser ist zudem noch auf allen gängigen Systemen in der Grundausstattung inbegriffen. Ein Webserver, welcher sich hinter dem Access Point in das Netzwerk integriert, publiziert Daten in Form von HTML–Strukturen und hostet alle Arten von Daten. Über eine angebundene Datenbank lassen sich dynamische Inhalte verwalten. Auch eine Zugriffsverwaltung ist hier problemlos umsetzbar. Die ideale Technik ist vorhanden und muss lediglich in die Anwendung integriert werden. Vergibt man eine spezifizierte IP–Adresse, so lassen sich Webserver an unterschiedlichen Lokalitäten gleichermaßen ansprechen. Listing 7.2 zeigt eine Abwandlung der aus Kapitel 6.4 bekannten CreateProcess–Funktion. Neben dem Konsolenbefehl zum Ausführen des Executables in Zeile 6 werden in Zeile 7 zusätzliche Parameter angegeben. Diese spezifizieren das Protokoll und die IP–Adresse des Servers, von welchem Daten abgerufen werden sollen. Beim Abarbeiten dieser Funktion 49 Anpassung der WRAPIb2.0 – WRAPI.cpp - 51 - WLAN–Verbindungsaufbau im Infrastruktur–Szenario wird der Internet Explorer gestartet und nimmt automatisch Kontakt zum Host mit der IP– Kennung 192.168.1.100 (Zeile 7) auf. Da sich der Internet Explorer stets an der gleichen Stelle im Dateisystem befindet, ist der Pfad aus Zeile 6 universell gültig. 1 void CWLANConnectorDlg::OnInfo() 2 { 3 PROCESS_INFORMATION pInfo; 4 5 CreateProcess( 6 _T("\\Windows\\iexplore.exe"), 7 _T("http://192.168.1.100"), 8 NULL, 9 NULL, 10 FALSE, 11 0, 12 NULL, 13 NULL, 14 NULL, 15 &pInfo);} LISTING 7.2 : Sofwareinternes Starten des Internet Explorers mit spezifizierter Zielhost Um vorgestelltes Verfahren zu testen wurde ein Apache50 Webserver auf einem Windows Rechner installiert. HTML–Dokumente, welche Nachrichten, Verkehrsmeldungen, Wetterinformationen und Musikdateien präsentieren, wurden erstellt und auf dem Server abgelegt. Über ein Navigationsmenü war ein strukturierter, gezielter Zugang zu gewünschten Dokumenten und Software möglich. Die Tatsache, dass es sich bei diesem Browser um ein systemeigenes Werkzeug handelt, bietet weiterhin eine komfortable Möglichkeit zum ersten Aufspielen der Anwendungssoftware. Wird über einen Hyperlink eine Datei angewählt, so wird dem Anwender über einen Dialog ermöglicht, diese Datei mit der zugeordneten Anwendung sofort zu öffnen oder an einer Stelle der Wahl im Dateisystem abzulegen. Es wurden Überlegungen unternommen, diese Option auf eine Aktion zu reduzieren um die Interaktion mit dem System zu minimieren. 50 www.apache.org/ - 52 - WLAN–Verbindungsaufbau im Infrastruktur–Szenario SCREENSHOT 7.3 : Informationsanwendung mittels Webservers - 53 - 8. Anmerkungen zur Entwicklung unter Windows XP 8.1 NDISUIO Schnittstellendefinition Um die Abhandlung der softwareinternen WLAN–Steuerung über das NDISUIO–Protokoll nicht auf Windows CE zu beschränken wird im Folgenden auf Adapterzugriffe unter anderen aktuellen Windows–Varianten eingegangen. Konkret erfolgte eine Portierung der erarbeiteten Softwarefunktionalität auf Windows XP SP1. Diesbezüglich wurde die Konsolenanwendung „WLANConSol“ entwickelt, welche verfügbare Instanzen von 802.11–Adaptern ausliest, diese zur Anzeige bringt und für die weitere Verwertung vorbereitet. Quelltext und ausführbare Programmdatei sind beigelegter CD–ROM zu entnehmen. Um mittels NDISUIO–Zugriffen auf die WLAN–Hardware zuzugreifen, wird in jedem Falle zuerst ein Handle benötigt. Dieses wird als Rückgabewert der CreateFile-Funktion erzeugt und einer Variablen von Typ Handle zugewiesen. Anschließend können unter Pocket PC 2003 Konfigurations- und Informationsbeschaffungsvorgänge durchgeführt werden, indem die Adapterbezeichnung, im Falle des untersuchten HP iPAQ 5500 Pocket PCs „vnetusba1“, in den Strukturen PNDISUIO_SET_OID und PNDISUIO_QUERY_OID platziert wird. Die Variable „ptcDeviceName“, welche einen Zeiger auf einen, den Namen der Adapterinstanz enthaltenden, Puffer empfängt, wird allerdings nur für Windows CE zur Verfügung gestellt. Wird diese konkretisiert, so sind die implementierten DeviceIoControl–Zugriffe nur auf spezifiziertem Gerät durchführbar. Soll der Code variabel gestaltet werden, so kann die „ptcDeviceName“ –Struktur mit dem Wert nur „NULL“ initialisiert werden. Dieses Vorgehen ist auch unter Windows CE praktikabel. Die spezifische Übergabe des Gerätenamens legt die Funktionalität des Quelltextes fest und macht Operationen unnötig, welche für die geräteunabhängige Implementierung eingesetzt werden müssen [MSDN05]. 8.2 Enumeration der WLAN–Adapter Im Vorfeld macht es Sinn, zuerst alle verfügbaren WLAN–Netzwerkadater zu enumerieren und in einer Liste zu veralten. Die gewünschte Hardwareselektion erfolgt in einer separaten Funktion und kann sowohl durch Mensch–Maschine–Interaktion, als auch automatisiert erfolgen. Wird der IOCTL–Kontrollcode IOCTL_NDISUIO_QUERY_BINDING innerhalb der DeviceIoControl–Funktion eingesetzt, so wird es einer Anwendung ermöglicht, den Namen - 54 - Anmerkungen zur Entwicklung unter Windows XP und die Bezeichnung aller an NDISUIO gebunden Netzwerkschnittstellen des ausführenden Systems auszulesen. Die Ergebnisdaten werden in den in Zeile 7 (Listing 8.1) initialisierten Datenpuffer geschrieben. Dieser wird der DeviceIoControl–Funktion in Zeile 20 als Parameter übergeben und verweist auf eine Instanz der NDISUIO_QUERY_BINDING–Struktur, welche die Variablen für den Namen und die Beschreibung der Adapter enthält. Das NDISUIO_QUERY_BINDING–Element „BindingIndex“ dient als Enumerationsindex. In der for–Schleife aus Zeile 15, welche kein eigenes Abbruchkriterium kennt, wird dieser so lange inkrementiert, bis der Rückgabewert der DeviceIoControl–Funktion auf die erfolgte Abarbeitung aller Adapter schließen lässt (Zeile 18) und die break–Anweisung aus Zeile 52 greift. Innerhalb des Schleifenkörpers werden die Adapterdefinitionen mittels memcpy–Operationen in ein Array (Liste) von WRAPI_NDIS_DEVICE–Strukturen, welche den Namen (Zeile 33 bis 35) und die Beschreibung (Zeile 37 bis 39) der Geräte verwalten, eingefügt. Eine variable Zuordnung des benötigten Speicherplatzes für jede Adapterdefinition wird in Zeile 28 bis 31 über die malloc–Funktion vorgenommen. Die Variable lItems, welche in Zeile 2 deklariert und mit dem Wert 0 initialisiert wird, enthält die Anzahl der geführten Listenelemente. 1 WRAPI_NDIS_DEVICE *pDeviceList = NULL; 2 long lItems = 0; 3 4 WRAPI_NDIS_DEVICE **ppDeviceList = &pDeviceList; 5 long *plItems = &lItems; 6 7 CHAR Buf[1024]; 8 DWORD dwBytesWritten, i = 0; 9 10 m_pQueryBinding = (PNDISUIO_QUERY_BINDING)Buf; 11 12 *ppDeviceList = (WRAPI_NDIS_DEVICE *) malloc(NUM_DEVICES * 13 sizeof(WRAPI_NDIS_DEVICE)); 14 15 for (m_pQueryBinding->BindingIndex = i;;m_pQueryBinding->BindingIndex = 16 ++i) 17 { 18 if (DeviceIoControl( 19 m_hFileHandle, 20 IOCTL_NDISUIO_QUERY_BINDING, 21 m_pQueryBinding, 22 sizeof(NDISUIO_QUERY_BINDING), 23 Buf, 24 sizeof(Buf), 25 &dwBytesWritten, - 55 - Anmerkungen zur Entwicklung unter Windows XP NULL)) 26 { 27 28 (*ppDeviceList)[i].pDeviceName = (WCHAR *) 29 malloc(m_pQueryBinding->DeviceNameLength); 30 (*ppDeviceList)[i].pDeviceDescription = (WCHAR *) 31 malloc(m_pQueryBinding->DeviceDescrLength); 32 33 memcpy((*ppDeviceList)[i].pDeviceName, 34 (PUCHAR)m_pQueryBinding+m_pQueryBinding->DeviceNameOffset, 35 m_pQueryBinding->DeviceNameLength); 36 37 memcpy((*ppDeviceList)[i].pDeviceDescription, 38 (PUCHAR)m_pQueryBinding+m_pQueryBinding->DeviceDescrOffset, 39 m_pQueryBinding->DeviceDescrLength); 40 memset(Buf, 0, sizeof(Buf)); 41 42 } 43 else 44 { 45 m_dwError = GetLastError(); 46 if (m_dwError != ERROR_NO_MORE_ITEMS) { 47 48 printf("EnumerateDevices:\n terminated abnormally, error 49 %d\n", m_dwError); 50 m_hRes = E_FAIL; 51 } break; 52 53 } 54 *plItems = i + 1; 55 } LISTING 8.1 : Enumeration der WLAN–Adapter 51 Name und Beschreibung der enumerierten Adapter können nun ausgegeben werden. 1 for ( int j = 0; j < lItems; j++) 2 { 3 printf("Enumerierte NDIS Devices:\n %ws\n 4 pDeviceList[j].pDeviceDescription, pDeviceList[j].pDeviceName); 5 } LISTING 8.2 : Ausgabe der enumerierten WLAN–Adapter über die Konsole 51 52 Anpassung der WRAPIb2.0 – WLANConSol.cpp WLANConSol – WLANConSol.cpp - 56 - 52 - %ws\n", Anmerkungen zur Entwicklung unter Windows XP 8.3 Assoziation des Adapters mit dem NDISUIO Handle Um ohne OID–interne Adapterzuweisung zu arbeiten, muss das erzeugte Geräte–Handle (Kapitel 5.6, Listing 5.2) mit der Hardware assoziiert werden. Dies erfolgt innerhalb eines Hardwarezugriffes in Form einer DeviceIoControl–Funktion, welche durch den IOCTL–Kontrollcode IOCTL_NDISUIO_OPEN_DEVICE definiert wird. Weitere relevante Parameter sind ein Zeiger auf den Adapternamen (Zeile 16) und die Größe des Namenspuffers (Zeile 17) in Bytes. Jede Anwendung kann dabei nur einen Adapter zur selben Zeit beanspruchen [MSDN05]. Listing 8.3 schließt nahtlos an das vorangegangene Listing 8.2 an und bezieht sich auf dessen Geräteenumeration „pDeviceList“. In Zeile 1 wird das Element mit dem Array–Index 1 selektiert. Dieses wird in der for–Schleife (Zeilen 6 bis 9) in den Zeichen–Container „wNdisDeviceName“ transferiert, wobei sich die Länge des Strings in der Variablen „wNameLength“ entsprechend anpasst. DEVICE_LENGTH aus Zeile 2 ist über eine define–Operation dauerhaft mit der Zahl 47 verknüpft, was bedeutet, dass sich die Länge der Gerätebezeichnung auf diesen Wert beschränkt. In Zeile 12 wird die binäre 0 an den String angefügt, um den Abschluss der Zeichenkette zu signalisieren. Nach Ausführung der DeviceIoControl–Operation (Zeilen 14 bis 21), beziehen sich alle weiteren NDISUIO–Zugriffe auf diesen WLAN-Adapter. 1 WCHAR *pwDeviceName = pDeviceList[1].pDeviceName; 2 WCHAR wNdisDeviceName[DEVICE_LENGTH] = {0}; 3 int wNameLength, h = 0; 4 wNameLength = 0; 5 6 for ( h = 0; h < DEVICE_LENGTH-1; h++ ) 7 { 8 wNdisDeviceName[h] = pwDeviceName[h]; 9 wNameLength++; 10 } 11 12 wNdisDeviceName[h] = L'\0'; 13 14 if (!DeviceIoControl(m_hFileHandle, 15 IOCTL_NDISUIO_OPEN_DEVICE, 16 (LPVOID) &wNdisDeviceName[0], 17 sizeof(WCHAR)*wNameLength, 18 NULL, 19 0, 20 &m_dwBytesReturned, 21 NULL)) - 57 - Anmerkungen zur Entwicklung unter Windows XP 22 { 23 m_dwError = GetLastError(); 24 printf("Could not open NDIS Device, error %d\n", m_dwError); 25 m_hRes = E_FAIL; 26 } 27 else 28 { 29 printf("\n\n\nDevice %ws\nerfolgreich geoeffnet\n", 30 pDeviceList[1].pDeviceDescription); 31 } LISTING 8.3 : Assoziation des Handles mit dem WLAN-Adapter 53 Anpassung der WRAPIb2.0 – WLANConSol.cpp - 58 - 53 9. Prioritätsgesteuerter WLAN–Verbindungsaufbau 9.1 Motivation Die bisherigen Konzipierungsüberlegungen zielten darauf ab, durch vorgegebene Merkmale spezifizierte WLAN–Profile softwaregesteuert oder manuell zu aktivieren und dynamisch auf erfolgten Verbindungsaufbau zu prüfen. Hierbei entscheiden die Ressourcenanforderungen des Programms oder der Mensch, welcher Netzwerkzugang angestrebt wird. Die nachstehenden Überlegungen binden einen zusätzlichen Faktor ein: Softwareinterne Selektion des angestrebten WLAN-Netzwerkes nach priorisierten externen Voraussetzungen. Die folgenden Beispiele sollen diesen Gedankengang verdeutlichen. Angenommen eine Anwendung beliebiger Art benötigt Zugriff auf eine Netzwerkressource. Es besteht Kenntnis darüber, dass die Ressource über mehrere, eventuell gekoppelte, WLAN–Knoten erreichbar ist, jedoch eine Netzwerkanbindung nach dem Least Cost Prinzip bevorzugt wird. Gründe hierfür können variierende Übertragungsgeschwindigkeiten, Verbindungskosten, Signalstärke oder generelle Verfügbarkeit sein. Auch softwareinterne Aufgaben können priorisiert werden. Das Versenden einer Mail muss schneller erfolgen als das Empfangen der aktuellen Staumeldungen. Die Software soll nun im Vorfeld sondieren, welche äußeren Bedingungen gegeben sind und diese Auswerten. Senden zwei oder mehrere Zugangspunkte im aktuellen Signalbereich, wird die Verbindung hergestellt, welche das Senden von Mails unterstützt, obwohl ebenfalls Verkehrsnachrichten über ein anderes Netzwerk angerufen werden könnten. Erkennt der Algorithmus unterschiedliche Anbindungsmöglichkeiten mit variierender Signalstärke, so wird der Verbindungsaufbau, der zur besten Übertragungsleistung führt, initiiert. Lässt die Signalstärke darauf schließen, dass ein Positionswechsel stattgefunden hat, reagiert das Programm und präsentiert entsprechende Informationen. Bei einer Messerundfahrt könnten mit Hilfe dieses Verfahrens standortabhängige Funktionen ausgeführt werden. Die Anwendung reagiert weiterhin dynamisch auf Veränderungen der gegebenen Voraussetzungen. Ein Netzwerk, welches sich an einer Stelle durch hervorragende Signalstärke ausgezeichnet hat, kann nach einer Positionsänderung kaum mehr erreichbar sein. Dies wird programmatisch verwertet und eine günstigere Alternative angepeilt. - 59 - Prioritätsgesteuerter WLAN–Verbindungsaufbau 9.2 802.11 Netzwerkscan Um einen prioritätsgesteuerten Verbindungsaufbau in Abhängigkeit von Verfügbarkeit, Signalstärke oder SSID zu ermöglichen, müssen diese Informationen im Vorfeld softwareintern gesammelt werden. Die 802.11–Adapterhardware wird hierbei als Sensor genutzt. Grundsätzlich können Netzwerkscans auf verschiedene Arten durchgeführt werden. Wird ein aktiver Netzwerkscan in die Wege geleitet, so sendet die 802.11–Adapterhardware periodisch Sondierungsanfragen über einen selektierten Kanal an die Broadcast–Adresse und wartet auf die Antwort von erreichten WLAN–Stationen. Eine weitere Variante ist das passive Scannen. In diesem Fall verbreitet der Adapter keine Anfragen, sondern verbleibt in untätigem Zustand bis Rundsendeinformationen von verfügbaren Stationen bei ihm eintreffen. Ein WLAN–Gerät identifiziert sich gegenüber seiner Umwelt mittels so genannter Beacons (Leuchtfeuer). Diese Datenpakete sind für die Netzwerksynchronisation zuständig und werden in vorgegebenen Intervallen ausgesendet um Steuersignale zu übermitteln und das Auffinden von drahtlosen Netzwerken zu erleichtern. Auf einigen Access Points können diese Intervalle individuell angepasst werden. Empfängt ein Adapter ein solches Leuchtfeuer oder eine Antwort auf eine Sondierunganfrage, so hinterlegt er diese Informationen in einer BSSID–Liste [MSDN05]. 9.3 Implementierung eines BSSID List Scans Dies wird über einen Gerätezugriff mittels OID_802_11_BSSID_LIST_SCAN veranlasst. Erhält ein Adapter diese Kontrollstruktur, so reagiert er nach vorgegebenem Schema. Zunächst wird der bisherige Inhalt der geführten BBSID–Liste verworfen. Unabhängig vom aktuellen Infrastrukturmodus werden sowohl infrastrukturelle, als auch Ad–hoc–Netzwerke gesucht. Hierbei werden alle Frequenzkanäle und Netzwerktypisierungen mit einbezogen. Um die korrekte Initialisierung dieser Operation bereits nach kurzer Zeit zu evaluieren, erfolgt eine Statusrückmeldung schon bevor der Scanvorgang beendet wurde. Die erhaltenen Informationen werden in die dafür reservierte Speicherstruktur eingepflegt. Listing 9.1 zeigt die konkrete Implementierung für eine Anwendung unter Windows XP. Die folgenden Quelltextauszüge wurden größtenteils der „GetAPList“–Funktion aus der Wireless Research API entnommen und an das eigens erstellte Programmgerüst „WLANConSol“ angepasst. Die OID–Spezifikation wird in bekannter PNDISUIO_QUERY_OID–Struktur abgelegt (Zeile 5) und innerhalb der DeviceIoControl–Funktion an den Adapter gesendet (Zeile 7 bis 14). - 60 - Prioritätsgesteuerter WLAN–Verbindungsaufbau 1 PNDISUIO_SET_OID pSetOidList; 2 UCHAR QueryBuffer[1024]; 3 4 pSetOidList = (PNDISUIO_SET_OID) &QueryBuffer[0]; 5 pSetOidList->Oid = OID_802_11_BSSID_LIST_SCAN; 6 7 DeviceIoControl(m_hFileHandle, 8 IOCTL_NDISUIO_SET_OID_VALUE, 9 (LPVOID) &QueryBuffer[0], 10 sizeof(QueryBuffer), 11 (LPVOID) &QueryBuffer[0], 12 0, 13 &m_dwBytesReturned, 14 NULL); LISTING 9.1 : Initiierung eines BSSID LIST SCANS 54 Aktives als auch passives erneuern der BSSID_LIST–Struktur führ zu einer vollständigen Auffrischung des Tabelleninhaltes. Man spricht deshalb von expliziter Netzwerkerkundung. Weiterhin führt das 802.11–Device implizite Scans durch. Dies bedeutet, dass der Adapter eine eigenständige Aktualisierung der BSSID–Liste durchführt. Auf das Aussenden von Broadcast–Nachrichten wird verzichtet. Die Einträge werden hierbei lediglich ergänzt. Greift man innerhalb von sechs Sekunden nach Initiierung eines Scans lesend auf den BSSID– Cachespeicher zu, so wird dessen vollständiger Inhalt zurückgegeben. Das Auslesen erfolgt über eine OID mit der Ausprägung OID_802_11_BSSID_LIST. Wird der Zugriff nach der erwähnten Zeitspanne durchgeführt, so muss das Ergebnis alle, auch durch implizite Abfragen erlangte, Einträge preisgeben. Wurde zuvor kein expliziter Scan in die Wege geleitet, werden WLAN–Knoten in Abhängigkeit der aktuellen Konfiguration ausgegeben. Wenn sich der Adapter im Ad–hoc– Modus befindet, beschränkt sich der zurückgegebene Inhalt daher auf Peer–to–Peer– Knoten [MSDN05]. Das vorangegangene Listing PNDISUIO_SET_OID–Struktur, 9.1 erläutert wohingegen den schreibenden das Zugriff nachfolgende über Listing die über PNDISUIO_QUERY_OID lesend auf den WLAN-Adapter zugreift. Es müssen daher erst einmal Container bereitgestellt werden, um die ausgelesenen Daten unterzubringen. Es handelt es sich hierbei um ein Array von Informationsstrukturen, welche den auszulesenden Daten entsprechen müssen. Nach erfolgtem Gerätezugriff über DeviceIoControl (Zeilen 17 bis 24), werden die bisher untypisierten Rückgabedaten, wie gewohnt, in den dafür angelegten „QueryBuffer“ (Zeile 9) geschrieben. In Zeile 26 wird der Inhalt des Datensegmentes als PNDIS_802_11_BSSID_LIST–Struktur interpretiert und dem dafür dynamisch allokierten Speicherbereich (Zeile 7) zugewiesen. Die PNDIS_802_11_BSSID_LIST–Spezifikation enthält einen „NumberOfItems” –Zähler und ein 54 Anpassung der WRAPIb2.0 – WLANConSol.cpp - 61 - Prioritätsgesteuerter WLAN–Verbindungsaufbau Array von NDIS_WLAN_BSSID–Strukturen, dessen Aufbau in Listing 9.2 aufgeschlüsselt wird. Wie der Rest der für das NDISUIO–Protokoll relevanten Strukturen findet auch dieses Element ihre Definition im „ntddndis.h“ Header–File. Die enthaltenen Merkmale treffen eine Aussage darüber, welche Informationen über erkundete WLAN–Devices ausgelesen werden können. Es handelt sich hierbei um die MAC–Adresse (Zeile 3), die SSID (Zeile 5), die Signalstärke (Zeile 7), den Netzwerktyp (Zeile 8), die Konfigurationsspezifikationen (Zeile 9), den Infrastrukturmodus (Zeile 10) und die unterstützten Übertragungsraten (Zeile 11). Alle diese Merkmale können beim priorisierten Verbindungsaufbau Berücksichtigung finden. 1 struct _NDIS_WLAN_BSSID { 2 ULONG Length; 3 NDIS_802_11_MAC_ADDRESS MacAddress; 4 Uchar Reserved[2]; 5 NDIS_802_11_SSID Ssid; 6 ULONG Privacy; 7 NDIS_802_11_RSSI Rssi; 8 NDIS_802_11_NETWORK_TYPE NetworkTypeInUse; 9 NDIS_802_11_CONFIGURATION Configuration; 10 NDIS_802_11_NETWORK_INFRASTRUCTURE InfrastructureMode; 11 NDIS_802_11_RATES SupportedRates; 12 } NDIS_WLAN_BSSID, *PNDIS_WLAN_BSSID; LISTING 9.2 : Aufschlüsselung der NDIS_WLAN_BSSID–Struktur 55 Die Daten müssen anschließend für die weitere Verwendung aufbereitet und in entsprechenden Variablen gespeichert werden. Die BSSID–Liste ist nicht beständig, da sie vom Adapter eigenständig aktualisiert wird. Zu diesem Zweck ist das Erstellen eigener Datencontainer nötig. In konkreten Falle handelt es sich um ein Array von „AP_DATA“–Strukturen, welches in Zeile 1 mit einem Zeiger auf den Speicherbereich versehen wird. wird. Die long–Variable „lItemsList” zählt dessen Elemente. Der Aufbau von „AP_DATA“ wird innerhalb der „WLanExports.h“–Datei, welche dem Quelltext der WRAPI beiliegt, definiert und den Bedürfnissen entsprechend angepasst. Es werden nur Informationen übernommen, welche für die Weiterverwendung von Bedeutung sind. Der hierfür benötigte Speicherplatz wird in den Zeilen 30 und 31 allokiert. In der for–Schleife von Zeile 33 bis 47 wird das Array gefüllt. Diese wird sooft durchlaufen, wie WLAN–Geräte eingelesen wurden. Die eingebettete Schleife von Zeile 35 bis Zeile 39 liest hierbei die MAC–Adresse in ein Array ein, wohingegen die Schleife von Zeile 41 bis 45 für die SSID zuständig ist. 55 ntddndis.h – Windows XP SP1 DDK - 62 - Prioritätsgesteuerter WLAN–Verbindungsaufbau Für die entwickelte Testapplikation wurde zusätzlich eine Strukturvariable „ssid“ für das Speichern des Service Set Identifiers integriert (Zeile 46). Da die Strukturen mehrfach ineinander verschaltet sind, ist es bei der Auswertung der Informationen notwendig, dessen Elemente bis auf die unterste Ebene der Grunddatentypen zu durchleuchten. Bei der SSID handelt es sich beispielsweise um ein Array von bis zu 32 uchar–Werten (unsigned character). Die SSID lässt sich auf ein Array von sechs unsigned char Werten zurückführen und die Signalstärke besteht aus einer long–Zuweisung. 1 AP_DATA *pAP_data = NULL; 2 long 3 AP_DATA **ppAP_data =&pAP_data; 4 long *plItemsList =&lItemsList; lItemsList; 5 6 PNDISUIO_QUERY_OID pQueryOid; 7 PNDIS_802_11_BSSID_LIST pBssid_List; 8 9 UCHAR QueryBuffer[1024]; 10 11 ULONG k = 0; 12 Int l = 0; 13 14 pQueryOid = (PNDISUIO_QUERY_OID) &QueryBuffer[0]; 15 pQueryOid->Oid = OID_802_11_BSSID_LIST; 16 17 DeviceIoControl(m_hFileHandle, 18 IOCTL_NDISUIO_QUERY_OID_VALUE, 19 (LPVOID) &QueryBuffer[0], 20 sizeof(QueryBuffer), 21 (LPVOID) &QueryBuffer[0], 22 sizeof(QueryBuffer), 23 &m_dwBytesReturned, 24 NULL); 25 26 pBssid_List = (PNDIS_802_11_BSSID_LIST)pQueryOid->Data; 27 28 *plItemsList = pBssid_List->NumberOfItems; 29 30 *ppAP_data = (AP_DATA *)calloc(pBssid_List->NumberOfItems, 31 sizeof(AP_DATA)); 32 33 for ( k = 0; k < pBssid_List->NumberOfItems; k++ ) 34 { 35 for ( l = 0; l < 6; l++ ) 36 { 37 (*ppAP_data)[k].mac_addr[l] = - 63 - Prioritätsgesteuerter WLAN–Verbindungsaufbau 38 (pBssid_List->Bssid[k]).MacAddress[l]; 39 } 40 41 for ( l = 0; l < 32; l++ ) 42 { 43 (*ppAP_data)[k].ssid[l] = 44 (pBssid_List->Bssid[k]).Ssid.Ssid[l]; 45 } 46 (*ppAP_data)[k].Rssi = (pBssid_List->Bssid[k]).Rssi; 47 } LISTING 9.3 : Auslesen der in der BSSID–Liste enumerierten WLAN–Geräte 9.4 56 Verwertung der gesammelten Geräteinformationen Das folgende Listing 9.4 demonstriert den prioritätsgesteuerten Verbindungsaufbau an Hand einer SSID–Auswertung. Der Service Set Identifier lässt hierbei auch auf den Infrastrukturmodus schließen. Das vorgestellte Programmgerüst (Listing 9.4) bezieht sich direkt auf das Anstoßen des aktiven BSSID_LIST_SCAN–Vorgangs (Listing 9.1) und das Auslesen der BSSID–Liste (Listing 9.3). Das Array, welches durch den Zeiger „pAP_data” gekennzeichnet wird, wurde in Listing 9.3 mit Variablendeklarationen Informationen seien in über angestelltem verfügbare WLAN–Geräte Softwaregerüst auf Grund gefüllt. seines exemplarischen Charakters außen vor gelassen. Der Quelltextauszug ist Teil der entwickelten „WLANConSol“–Anwendung, welche auf beigefügter CD–ROM zu finden ist. Das Verhalten der Anwendung lässt sich wie folgt beschreiben: Wird beim Auslesen der BSSID–Liste ein Device mit der SSID „AdhocNet“ oder „InfraNet“ erkannt, so wird eine entsprechende Verbindung angestrebt. Sind beide WLAN–Konfigurationen auffindbar, so wird das „AdhocNet“ höher priorisiert. Dies wirkt sich dahingehend aus, dass selbst wenn zuvor eine Assoziation mit den „InfraNet“ besteht, diese Netzwerkanbindung durch eingeleiteten Verbindungsaufbau zu entdecktem „AdhocNet“ unterbrochen wird. Ist bereits eine Anbindung im Sinne der vergebenen Prioritäten erfolgt, werden weitere Verbindungsoperationen unterbunden. Die rahmende for–Schleife arbeitet alle in der „AP_data“–Liste geführten Einträge sequentiell ab. Die if–Abfrage aus Zeile 3 vergleicht zunächst die SSID des ausgewählten Geräteeintrags aus der „AP_data“–Liste mit dem String „AdhocNet“. Wird eine Entsprechung erkannt, so wird der Verbindungsstatus geprüft. Befindet sich der 802.11–Adapter bereits in kompatiblem Zustand, so wird dies lediglich durch eine Konsolenausgabe visualisiert 56 Anpassung der WRAPIb2.0 – WLANConSol.cpp - 64 - Prioritätsgesteuerter WLAN–Verbindungsaufbau (Zeile 7). Ist dies nicht der Fall wird eine Konfigurationsänderung eingeleitet (Zeile 13) und die Zustandsvariable angepasst (Zeile 14). Die verwendeten Methoden „setAdhoc“ und „setInfrastructure“ wurden in Kapitel 6.2 ausführlich behandelt. Führt der if–Vergleich (Zeile 3) nicht zum Erfolg wird das else–Modul (Zeilen 17 bis 30) in die Programmausführung mit einbezogen. Über eine weitere strcmp– Funktion (string compare) in Zeile 18 wird nun getestet, ob die SSID des zu überprüfenden Gerätes der Zeichenkette „InfraNet“ gleichsetzbar ist. Bei Rückgabe des Wertes true wird ein entsprechender infrastruktureller Verbindungsaufbau in die Wege geleitet (Zeile 27), falls dies noch nicht geschehen ist (Zeile 20). 1 for (m = 0;m< k; m++) 2 { 3 if(!strcmp((const char*)pAP_data[m].ssid,"AdhocNet")) 4 { 5 if(status==1) 6 { printf("\nBereits im Ad-Hoc Modus ..."); 7 8 } 9 else 10 { 11 printf("\nEs wurde ein priorisiertes Device gefunden\n 12 Initiiere Ad-Hoc Modus\n"); 13 setAdHoc(); 14 status = 1; } 15 16 else 17 { 18 if(!strcmp((const char*)pAP_data[m].ssid,"InfraNet")) 19 { 20 if(status == 2) 21 { 22 printf("\nBereits im Infrastruktur Modus ..."); 23 } 24 else 25 { 26 printf("\nInitiiere Infrastruktur Modus\n"); 27 setInfrastructure(); 28 status = 2; } 29 30 } 31 } LISTING 9.4 : Prioritätsgesteuerter Verbindungsaufbau 57 WLANConSol – WLANConSol.cpp - 65 - 57 Prioritätsgesteuerter WLAN–Verbindungsaufbau Um den priorisierten Verbindungsaufbau dynamisch zu gestalten, müssen innerhalb eines vorgegebenen Zeitfensters neu erkannte WLAN–Adapter aufgespürt und verwertet werden. Dies kann mit Hilfe einer übergeordneten Endlosschleife geschehen, in welcher der Netzwerkscan, das Auslesen der BSSID–Liste und prioritätsgesteuerten Verbindungsaufbau integriert werden. - 66 - der Algorithmus für den 10. WLAN–Integration eines Embedded Automotive Frameworks unter QNX 10.1 Systembedingte Voraussetzungen Ein weiterer Aspekt meiner Untersuchungen beschäftigt sich mit der kabellosen Netzwerkanbindung von Embedded Automotive Frameworks unter dem echtzeitfähigen Betriebssystem QNX. Diese Systeme, ausgerüstet mit einem SH4 Prozessor, bieten eine experimentelle Plattform für die Softwareentwicklung auf ressourcenbeschränkter Hardware und sind für die Steuerung von Multimediaelementen im KFZ ausgelegt. Grundsätzlich besteht ein solches Infotainment–System aus einer Headunit, welche die Rechenarbeit übernimmt und darüber hinaus diverse Bedienelemente inklusive Display zur Verfügung stellt, sowie typischen Multimediakomponenten (Audiokomponenten, Videokomponenten, Kommunikationsdevices, Navigationssystem, etc.) [JW04]. Auf Grund des experimentellen Charakters dieser Geräte entsteht die Notwendigkeit Hardwarekomponenten hinzuzufügen, Software aufzuspielen und Prozessabläufe zu überwachen. Da das eigentliche Framework keine Schnittstellen für die Manipulation von Programmen und Kontrolle von Systemzuständen oder Abläufen bietet ist die Kommunikation mit externen Entwicklungssystemen obligatorisch. Hierzu wird ein Ethernet–Netzwerk verwendet, welches alle Framework–Targets umfasst, sowie eine Reihe von konventionellen Rechnern, welche mit der QNX Momentics IDE58 (Integrated Development Environment) ausgestattet sind um das Ausführen und Debuggen von Programmen über das Netzwerkinterface zu ermöglichen. Im Gegensatz zu statischen Netzwerkknoten eines herkömmlichen Kabelnetzwerkes in einem Labor, stellt der Einsatz in einer mobilen Umgebung weit komplexere Anforderungen an das Kommunikationsmedium. Der Notwendigkeit einer kabellosen Netzwerkanbindung, welche auch über größere Entfernungen und unabhängig von physikalischen Hindernissen wie Wänden oder Karosserie aufrecht erhalten werden kann, wird man im Folgenden durch den Einsatz von WLAN gerecht. 58 www.qnx.com - 67 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX Auch das bereits in der Einleitung angeführte Tankstellen–Szenario soll entsprechend den erarbeiteten Anforderungen an den automatisierten Verbindungsaufbau im KFZ nachgebildet werden können. So soll die Infotainmenteinheit an speziell eingerichteten Verteilungspunkten Zugriff auf digitale Medieninhalte wie mp3s, Software, Informationen, Systemupdates und Patches erlangen. Die folgenden Ausführungen basieren auf praktischen Erfahrungen, welche im Laufe des Projektseminares gesammelt wurden, und sollen ein grundlegendes Verständnis für die Integration von Netzwerkkomponenten im Allgemeinen, sowie WLAN–Geräten auf einem eingebetteten System unter dem Betriebssystem QNX im Speziellen vermitteln. Ebenso wird auf im Laufe der Entwicklung auftretende Probleme und Fragen eingegangen um einen einführenden Leitfaden für Installation, Integration und Implementierung bei ähnlichen Problemstellungen zu vermitteln. 10.2 Realisierung mittels WLAN Karte Da die Mainboards sowohl mit einer PCMCIA–Schnittstelle, sowie mit einem PCI–Interface ausgestattet sind, konzentrierten sich die Bemühungen zunächst auf die Installation interner Steckkarten. 10.2.1 Verbindungsaufbau mittels Systembefehlen Einen einschränkenden Faktor bei der Inbetriebnahme und Installation stellt die Tatsache dar, dass sämtliche Kommandos von einem zweiten Rechner mit entsprechenden Ein– und Ausgabeeinheiten abgesetzt werden müssen. Dies bedeutet, dass die Funktionstüchtigkeit des Ethernet–Interfaces in jedem Falle gewährleistet bleiben muss, um die Kontrolle über die Geräte aufrechtzuerhalten. Gravierende Änderungen der Netzwerkkonfiguration können dazu führen, dass die Einheit von Außen nicht mehr zugänglich ist und ein Wiederaufspielen eines Systemimages nötig wird. Die Befehle zum Starten der benötigten Netzwerkdienste und Aktivierung der Netzwerkkarten werden während des Bootvorganges über ein Bootscript abgearbeitet. Befehle, die während der Systemlaufzeit ausgeführt werden sollen, werden innerhalb einer Telnet–Session abgesetzt. Der Telnet–Dienst basiert auf einem unverschlüsselten eigenständigen Protokoll auf der Anwendungsschicht und ermöglicht den Zugang auf die Kommandozeile eines Fremdrechners via TCP/IP [WITEL05]. Unter QNX, ähnlich wie bei anderen Variationen von UNIX Systemen, bietet der IO–NET– Dienst die Basis für grundsätzliche Netzwerkfunktionen. Ist dieser Dienst gestartet können entsprechende Geräte gemountet werden. Unter diesem Begriff versteht man in der Regel das optionale Einbinden von Ein– und Ausgabegeräten. Ein gemountetes Device kann über - 68 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX den unmount–Befehl wieder aus dem System entfernt werden. Alle Devices, welche in ein laufendes System eingebunden wurden, sind als symbolische Einträge an statisch definierter Stelle im Dateisystem zu finden. Der Pfad zu den Netzwerkkarten ist in unserem System \dev\io–net\. Jedes Device benötigt eine spezifische Beschreibung seiner individuellen herstellerabhängigen Hardwarezugriffsfunktionen. Eine solche Sammlung von APIs wird durch ein so genanntes Shared Objekt File zur Verfügung gestellt und ist mit der Dateiendung .so versehen. Abstrakt gesehen handelt es sich hierbei um einen Gerätetreiber. Shared Objects können als Pendant zu DLLs unter Windows gesehen werden und sind ein C++ Kompilat meist mehrerer Quellcode–Dateien, welche sich an fest vorgegebenen Strukturen und Funktionen orientieren müssen um eine standardisierte Systemintegration zu ermöglichen. Wird eine .so–Datei ohne expliziten Speicherort beispielsweise innerhalb eines mount–Befehles angegeben, so wird diese in ihrem Standardpfad \etc\dll\ gesucht. Es empfiehlt sich diese Vorgabe bei der Installation von Drittanbieter–Treibern zu übernehmen, um die Verwirrung nicht zusätzlich zu steigern [QNX05]. Treiber für WLAN–Karten werden von QNX nur bedingt zur Verfügung gestellt. Einige fertig kompilierte Treiber–Dateien werden bei der lizenzierten Version von QNX Momentics 6.3 distributiert und unterstützen diverse WLAN–Karten59 einiger weniger Hersteller. Eine weiterführende Problematik ergibt sich aus der Tatsache das Treiber für QNX auf Grund des Nischencharakters kaum von den Herstellerfirmen direkt angeboten werden. Oben angesprochene Shared Object Dateien für WLAN–Karten, welche bei QNX auf der Liste der unterstützen Hardware zu finden sind, können ausschließlich von X86er Prozessoren verarbeitet werden. Quellcodes werden aus kommerziellen Gründen nicht publiziert und können daher nicht auf andere Architekturen, wie unsere SH4 Prozessoren übertragen werden. Der Versuch im Internet veröffentlichte Quellcodedateien60 anzupassen und zu kompilieren scheiterte an internen Architekturänderungen, welche im Laufe von Versionsweiterführungen des QNX Frameworks durchgeführt wurden. Bei den zum freien Download angebotenen Quellen handelte es sich um Portierungen von Linux–Treibern für WLAN–Karten mit Chipsatz der Firma ATMEL, welcher auf einigen Karten unterschiedlicher Hersteller zum Einsatz kommt. Diese Erkenntnis wurde zusätzlich durch Korrespondenz mit dem Entwickler61 untermauert. Ein Treiber im Experimentalstadium, welcher von der Firma Becker entwickelt und vertrieben wurde, führte ebenfalls nicht zum gewünschten Ziel. Zur Verfügung standen eine PCI– und eine PCMCIA-WLAN-Karte. Nach umfangreichen Bemühungen in Zusammenarbeit mit dem laborinternen Systemintegrationsteam, die Karte mit unterschiedlichsten Parametern zu mounten, konnte lediglich das PCI–Gerät erkannt 59 www.qnx.com/developers/hardware_support/ www.qnxzone.com/%7Ephearbear/?go=Atmel%20Wi-Fi 61 [email protected] 60 - 69 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX werden. Jedoch wurde der Adapter nicht als Netzwerk–Device an entsprechender Stelle im System angezeigt und konnte daher nicht konfiguriert und in Betrieb genommen werden. Um einen erfolgreichen mount–Vorgang zu bewerkstelligen müssen unter Umständen etliche Parameter wie IRQ, Speicherbereiche, usw. angegeben werden. Dies ist größtenteils vom Grad der automatisierten Hardwareerkennung abhängig und kann sich bei jedem Gerät individuell unterscheiden [QNX05]. Die folgenden Ausführungen wurden auf Grund der oben dargestellten Treiberproblematik theoretisch erarbeitet und teilweise mit herkömmlichen Ethernetkarten, für welche bekanntermaßen funktionstüchtige Treiber existieren, auf QNX–Systemen getestet. Wie bereits erwähnt basiert jeglicher Netzwerkkartenbetrieb unter QNX auf dem IO–NET–Dienst. Ist bereits ein Netzwerk–Device in das System integriert und wird dieses beim Bootvorgang initialisiert, so ist dieser Dienst bereits gestartet. Im Falle unserer Projekt–Frameworks wird dieser Vorgang innerhalb eines Skriptes, welches beim Hochfahren der Systeme ausgeführt wird, sequentiell abgearbeitet. Ist der Service noch nicht gestartet, so kann dies mit angeführtem Kommando geschehen: / io–net $ Ebenso können bei der Ausführung dieses Befehls zusätzliche Parameter angegeben werden um direkt angegebene Netzwerkgeräte über ihre Shared–Objekt–Files zu mounten. Das Präfix der Shared Object Bezeichnung „devn“ weißt darauf hin, dass es sich um ein Netzwerkdevice handelt. Wird dieser Befehl erfolgreich ausgeführt, werden die Geräte symbolisch innerhalb des Dateisystems als typisiertes Modul geführt. / io–net /lib/dll/devn-bcm43xx.so Läuft bereits eine Instanz von IO–NET, so ist das erneute Starten dieses Dienstes nicht ratsam. Es kann zu Systeminstabilität führen und die komplette Netzwerkanbindung beeinträchtigen. Alternativ ist es praktikabel in einem solchen Falle den mount–Befehl zu bemühen. Der Parameter „–T io-net“ spezifiziert das angegebene Gerät als Netzwerkdevice. / mount -T io-net /lib/dll/devn-bcm43xx.so Wird das Entfernen eines Netzwerkgerätes angestrebt, kann dies über die unmount– Anwendung geschehen. Die Typisierung des Gerätes wird über die explizite Angabe des symbolischen Pfades im Dateisystem konkretisiert. Hierbei steht die Modulbezeichnung „en0“ für das Ethernet–Modul mit Index 0. / umount /dev/io-net/en0 - 70 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX Anders als bei Windows–Systemen muss keine komplizierte Adapterkonfiguration vorgenommen werden, da das Device in einem konkreten Zustand gemountet werden kann. Alle für die Definition eines WLAN–Netzwerkes relevanten und aus vorangestellten Kapiteln dieser Arbeit wohl vertrauten Parameter können hierbei übergeben werden. Es handelt sich hierbei um die SSID, den Infrastruktur–Modus, den Authentifizieruns–Modus und die Verschlüsselung. Optionale gerätespezifische Parameter können durch Voranstellen des „-o“ –Flags angegeben werden. Das angestellte Systemkommando mountet eine Netzwerk Interface Card (NIC), konkretisiert dessen SSID mit der Kennung „work“ und setzt den Infrastrukturmodus durch Angabe von „mode=ibss“ auf Ad–hoc (Independent Basic Service Set). Weiterhin wird die Authentifizierung mittels „authtype=open“ deaktiviert. Das Flag „-p“ spezifiziert die Art des anzubindenden Protokolls, in konkretem Falle den kompletten TCP/IP–Protokollstapel [QNX05]. / mount -T io-net /lib/dll/devn-bcm43xx.so -o ssid=work mode=ibss authtype=open -p tcpip Eine ähnliche Konfiguration im Infrastruktur–Modus wird durch Ändern der „mode“– Ausprägung auf „bss“ (Basic Service Set) erzielt. / mount -T io-net /lib/dll/devn-bcm43xx.so -o ssid=work mode=bss authtype=open -p tcpip Will man beispielsweise vom Ad–Hoc–Modus in den Infrastruktur–Modus wechseln muss man lediglich das Device, welches auf IBBS konfiguriert wurde mit Hilfe des unmount– Kommandos aus dem System entfernen um es im nächsten Schritt mit den Parametern für den Infrastruktur–Modus einzubinden. Der Zugriff über komplizierte APIs, wie bei der Network Driver Interface Specification unter Windows, wird weitgehend unnötig. Auch das Zuweisen einer kompatiblen IP–Adresse ist von erstaunlicher Einfachheit: / ifconfig en0 192.168.1.3 Die erläuterten Operationen können innerhalb eines QNX–Skriptes zusammengefasst und ausgeführt werden. Aber auch eine softwareinterne Verwertung ist denkbar. Damit können die Systemaufrufe in Abhängigkeit von Programmzuständen automatisiert werden, wir das nächste Kapitel zeigt. - 71 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX 10.2.2 Integration der Systemkommandos Will man aufgeführte Konsolenkommandos programmatisch verwerten, so kann man sich der C++ system–Funktion bedienen und die Rückgabewerte abfragen, um auf Erfolg zu prüfen. Das angestellte C++ Quellcode–Fragment demonstriert das Starten des IO–Net–Dienstes, das Einbinden eines WLAN–Adapters und das Zuweisen einer IP–Adresse auf entsprechendem Interface. Um die Quellcodefragmente so verständlich wie möglich zu halten wird auf Embedded Speicherkonzepte, wie das Verbot dynamischer Speicherallokation verzichtet. 1 if((rc = system("mount -T io-net devn-speedo.so"))== -1) 2 { printf("Kommando konnte nicht ausgeführt werden\n"); 3 4 } 5 else 6 { printf("Network Device Unmount erfolgreich\n\n"); 7 8 }; 9 10 srand((int) time( NULL )); 11 12 int IPlast = rand()%50; 13 14 char cd1[30]; 15 char ddest[40]; 16 17 strcpy(cd1,"ifconfig en0 192.168.1."); 18 19 sprintf(ddest,"%s%d",cd1,IPlast); 20 21 if((system(ddest))== -1) 22 { printf("Kommando konnte nicht ausgefuehrt werden\n"); 23 24 } 25 else 26 { 27 printf("IP Adressvergabe auf 192.168.1.%d erfolgreich\n\n",IPlast); 28 }; Listing 10.1 : Softwareinterne Integration von WLAN–Systembefehlen 62 WLANConCheck – WLANConCheck.cpp - 72 - 62 WLAN–Integration eines Embedded Automotive Frameworks unter QNX Aufgeführte Systemkommandos ermöglichen eine recht unkomplizierte Konfiguration der WLAN–Devices. Jedoch kann die volle Funktionalität der Gerätezugriffe nach Art der NDIS– APIs mit Konsolenkommandos nicht erreicht werden. Es ist nicht möglich erweiterte Informationen auszulesen oder in die Konfiguration zu schreiben, wie in entsprechendem Kapitel erläutert. Weiterhin kann es von Nachteil sein bei jeder Modusänderung das komplette Device aus dem System zu entfernen um es mit anderen Einstellungen wieder zu integrieren. 10.2.3 Verbindungsaufbau mittels DeviceControl Zugriffen Auf Unix–Systemen und speziell unter QNX bietet die devctl–Funktion eine Möglichkeit Geräte nach NDISUIO–Art zu manipulieren. Diese DeviceControl–Funktion sendet gerätespezifische Kommandos an verwaltende Prozesse, welche als File–Handles in Form einer symbolischen Datei erzeugt werden. Eine Portierung des unter Linux verfügbaren Programms "iwconfig"63, welches unter der GNU LGPL im Internet zu finden war zeigt die Art und Weise dieser Zugriffe und ist auf beigelegter CD–ROM abgelegt. Bei Einsatz der Software wird vorausgesetzt dass der Netzwerkadapter bereits vom System erkannt und in der Netzwerkgeräteliste im Pfad /dev/io–net/ aufgeführt wird. Das Programm konnte daher bei der WLAN–Anbindung der Framework–Targets nicht eingesetzt werden. 10.3 Realisierung mittels Ethernet–WLAN–Bridge Da manche Systeme, welche grundsätzlich über Ethernet–Funktionalität verfügen, auf Grund einschränkender Faktoren, welche sowohl auf verfügbare Hardware als auch Software zurückzuführen sind, nicht systemintern erweiterbar sind, bieten Ethernet–WLAN– Brücken dennoch die Möglichkeit einer räumlich flexiblen Netzwerkanbindung. 10.3.1 Beschaffenheit der Netzwerkgeräte und Integration in das bestehende Kabelnetzwerk Um sowohl infrastrukturelle als auch Ad–Hoc–Szenarien nachbilden zu können, werden zwei Ethernet–WLAN–Adapter und ein Access Point benötigt. Die Ethernet–WLAN–Brücken sind für den Betrieb an je einem Framework gedacht, der Access Point soll die Verbindung zum bestehenden Kabelnetzwerk herstellen. 63 www.hpl.hp.com/personal/Jean_Tourrilhes/Linux/Tools.html - 73 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX Die kompakten Adapter sind jeweils mit zwei Netzwerkschnittstellen oder Interfaces ausgestattet und fungieren als "externe" WLAN–Karten. Das 802.11–Interface übernimmt die eigentliche WLAN–Funktionalität, wohingegen die Ethernet–Schnittstelle die kabelgebundene Überbrückung der Geräte gewährleistet. Die Kombination von Ethernet– WLAN–Adapter und Framework ergibt einen in sich geschlossenen, mobilen Netzwerkknoten [WIEW05]. Abbildung 10.1 stellt die Einbindung der WLAN–fähigen Targets in das bestehende Labornetzwerk an Hand eines Netzwerkdiagrammes dar. Da sich die Framework–Targets, als auch die Labor–PCs in einem eigenständigen Netzwerksegment befinden, wird die netzübergreifende Kommunikation mit Hilfe eines Routers realisiert. Die Targets agieren hierbei im Netz 172.16.166.0, während die Workstations IP–Adressen aus dem 141.100.47.0 Segment zugewiesen bekommen. Die IP– Adressvergabe erfolgt in beiden Fällen durch einen DHCP–Server mit der Adresse 141.100.47.200. Über das Gateway 141.100.47.254 erfolgt die Anbindung an das Hochschulnetz, welches den Internetzugang des Labors gewährleistet. Ziel der Target–WLAN–Integration ist die vollständige Erhaltung der bestehenden Funktionalität im Kabelnetz. Dies bezieht sich auf die Erreichbarkeit der Workstations, dynamische Konfiguration über den DHCP–Server und Zugang zu übergeordneten Netzen, wie Hochschulnetz und Internet. Da die Targets für den Betrieb in einem Kraftfahrzeug konzipiert wurden, schafft man durch eine drahtlose Netzwerkanbindung eine praxisnahe Testumgebung. Unter realen Bedingungen können entwickelte Erweiterungen verifiziert und an den mobilen Einsatz angepasst werden. Weiterhin wird es möglich hardwarespezifische Anforderungen zu erkennen und umzusetzen. Die Konfiguration der Ethernet–WLAN–Brücken und des Access Points wird in den folgenden Kapiteln beschrieben. - 74 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX Abbildung 10.1 : WLAN Integration ICM Labor FH–Darmstadt - 75 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX 10.3.2 Interface–Bridging Jedem Interface ist eine weltweit eindeutige Netzwerkkennung zugewiesen. Bei den vorliegenden Geräten werden die Netzwerkschnittstellen über das so genannte Bridging–Verfahren überbrückt. So werden zwei physikalische Interfaces mit nur einer IP– Kennung adressiert. Das geräteinterne Routing der Daten–Pakete wird somit verschleiert und die Konfiguration vereinfacht. Für jeden kabellosen Netzwerkteilnehmer müsste ansonsten eine eigene Adresse für das Ethernet Interface und zwei für die Schnittstellen des Adapters reserviert werden, was bei mehreren Geräten zu einem enormen Verwaltungsaufwand führen kann. 10.3.3 Konfiguration des AccessPoints Auf dem Access Point werden alle nötigen Netzwerkparameter vergeben. Die Clients, in diesem Fall die Ethernet–WLAN–Brücken, müssen dieser Konfiguration vollständig entsprechen. Da das Gerät ab Werk mit einer vorgegebenen IP–Adresse konfiguriert ist, kann es noch nicht in das vorhandene Netzwerk integriert werden. Ist das Gerät physikalisch über ein Netzwerkkabel in das LAN eingegliedert, muss der Rechner, welcher für die Konfiguration genutzt werden soll, mit einer kompatiblen Netzwerkkennung versehen werden. Identifiziert sich der Access Point beispielsweise über die Adresse 192.168.2.5 bei einer Subnetzmaske von 255.255.255.0, so muss die IP–Kennung des Netzwerkpartners aus dem Bereich 192.168.2.X gewählt werden, wobei der Variablen X eine Zahl zwischen 1 und 254 zugewiesen werden kann. Die 5 muss ausgeklammert werden, da die Pakete ansonsten kollidieren würden. Die 0 und die 255 dürfen nicht vergeben werden, da es sich hierbei um reservierte Adressen handelt, welche für die Netzwerkverwaltung von Bedeutung sind. Die 0 spezifiziert das komplette Netzwerksegment und die 255 definiert einen Broadcast. Über das ping–Kommando kann nun die Kommunikation getestet werden. Der Konfigurationsdialog des Access Points kann mit jedem beliebigen HTTP–Browser geöffnet werden, in dem die entsprechende IP–Adresse in das Adressfeld eingegeben wird. In den meisten Fällen ist ein Standardpasswort vergeben, welches der beiliegenden Konfigurationsanleitung zu entnehmen ist. Ist der Zugang gewährleistet wird das drahtlose Netz eingerichtet. Obligatorisch ist die Spezifikation der SSID, über welche sich das Netzwerk identifiziert. Das Rundsenden dieser Kennung kann optional unterbunden werden. Weiterhin kann der Netzwerktyp spezifiziert werden. Hierbei wird zwischen dem 802.11b oder dem abwärts kompatiblen 802.11g Standard gewählt. Im Weiteren muss eine netzinterne IP–Adresse vergeben werden. Diese wird aus dem Adressbereich des Kabelnetzwerkes gewählt und muss auf jeden Fall individuell sein. Um grundlegende Sicherheitsvorkehrungen zu treffen wird danach eine Verschlüsselungs– und - 76 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX Authentifizierungsvariante64 spezifiziert. Hat man sich diesbezüglich festgelegt kann der Access Point in Betrieb genommen werden. 10.3.4 Konfiguration der Ethernet–WLAN Adapter Die Vergabe der IP–Adressen kann entweder manuell oder per DHCP erfolgen. In jedem Fall müssen die vergebenen IP–Adressen zwingenden Vorgaben entsprechen. Sie müssen sich alle im selben Subnetz befinden, was einer fest vorgegebenen Spanne von Adressfolgen entspricht. Die Anzahl der möglichen Adressierungen ergibt sich aus der Subnetzmaske. In unserem speziellen Falle wurde die manuelle Zuweisung vorgezogen um über die spezifische Adresse einfacher auf den integrierten Webserver zwecks Konfiguration zuzugreifen. Wenn eine beständige Integration der Geräte erfolgreich abgeschlossen wurde, können diese jedoch auch ohne weiteres auf dynamisch vergebene IP–Adressen umgestellt werden, da ein expliziter Zugriff nur noch bei Änderung der Einstellungen von Nöten ist. Der Zugang zu den eigentlich wichtigen Endgeräten wird in beiden Fällen über deren statische Adressierung gewährleistet. Diese sind von jedem Netzwerknoten aus erreichbar. 10.3.5 Dynamische IP–Adresszuweisung für Endgeräte Im Kabelnetzwerk wurden die Automotive Frameworks über den DHCP Server mit einer eindeutigen IP–Adresse versorgt. Der Netzwerkadapter identifiziert sich im Laufe des Verbindungsvorganges über seine MAC Kennung. Der eigentliche Vorteil dieser etwas umständlich erscheinenden Zuweisungsvariante liegt darin, dass die Konfiguration von zentraler Stelle durchgeführt, geändert und überwacht werden kann. Gerade bei Systemen, welche nur indirekt gewartet werden können und das Einstellen von Parametern umfangreiche Arbeitsvorgänge erfordert, geht man dazu über, identische Images zu erstellen und aufzuspielen. Die individuelle IP–Adresse ergibt sich dann aus der hardwareabhängigen MAC Adressierung. 64 siehe Kapitel 2.5 - 77 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX 10.4 Verbindungsgesteuerte Client–Server–Kommunikation Unabhängig der 802.11–Anbindungsrealisierung der Embedded Automotive Framework Targets soll nun im Folgenden das Prinzip einer verbindungsgesteuerten Client–Server– Anwendung unter QNX erläutert werden. Hierbei nimmt das Target die Rolle des Clients ein, Netzwerkanbindung eine TCP/IP–Socketvebindung initiiert und welcher bei erkannter eine Anfrage an einen Server sendet. Dieser kann Bestandteil eines Kabelnetzes sein und reagiert auf die empfangene Nachricht, in dem ein Datenstrom an den Client gesendet wird. Das Target nimmt die Daten entgegen und legt sie in seinem Speicher ab. Dies kann sowohl die Festplatte, als auch der Arbeitsspeicher des Gerätes sein. Angedacht ist die Übertragung einer digitalen Bilddatei, welche automatisiert auf dem Human–Machine–Interface (HMI) zur Anzeige kommt. Die softwaretechnische Realisierung dieses Szenarios wird in fünf logische Komponenten zerlegt: o WLAN–Verbindungsaufbau o Identifikation des Netzwerkpartners o Initiierung einer Socket–Verbindung o Übertragung einer Datei o Anzeige der Datei auf der HMI Der WLAN–Verbindungsaufbau wird über die Ethernet–WLAN–Brücken bewerkstelligt. Es ist sowohl ein Einsatz im Ad–Hoc–Modus denkbar, als auch eine infrastrukturelle Netzwerkanbindung. Auf Grund des Client–Server–Prinzips ist die Verwendung einer Access–Point–Lösung vorzuziehen, da mehrere Clients zu einem Server verbinden können und findet Entsprechung im einleitenden Tankstellenszenario. Die Einstellungen der Ethernet–WLAN–Adapter werden im Vorfeld der Konfiguration des Access Points angepasst. Bei Installation der Targets inklusive Ethernet–WLAN–Brücken im Kraftfahrzeug erfolgt ein Verbindungsaufbau, wenn sich die mobile WLAN–Station innerhalb des Signalbereiches des Access Points befindet. Durch die externe WLAN–Lösung ist es dem Target nicht möglich durch Gerätezugriffe auf einen erfolgten Verbindungsaufbau zu prüfen. Dies wird über die bekannten ICMP Echo Requests gelöst. Beim Einsatz der infrastrukturellen Netzwerkanbindug erfolgt die IP–Adressvergabe über den eingebundenen DHCP–Server oder manuell. Die Identifikation des Netzwerkpartners ist trivial, da die IP–Adresse des Servers eindeutig spezifiziert wurde. Es wäre beispielsweise eine Vergabe der 192.168.0.1 denkbar. Das Target beschränkt sich daher lediglich auf die Erkennung von ICMP Echo Replys dieser IP–Kennung. - 78 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX Auf der Server–Seite ist das Auslesen der Client–IP–Adresse belanglos, da die softwareinterne Angabe dieser nur beim Initiieren der Socket–Verbindung durch den Client angegeben werden muss. Der Server ist so konfiguriert, dass ein Verbindungsaufbau von jeder beliebigen Adresse akzeptiert wird. Eine einfache Verbindungserkennung über eine spezifizierte IP–Adresse könnte folgendermaßen implementiert werden (Listing 10.2). Der hier implementierte Netzwerkscan orientiert sich an der Windows CE Lösung aus Kapitel 6.3, Listing 6.12, und erlaubt das Erkunden von ganzen Adressbereichen. Innerhalb einer Endlosschleife (Zeile 6) wird die komplett verfügbare Adressspanne durchlaufen. Dies geschieht im Körper der for–Schleife (Zeile 9 bis 38). Der Schleifenzähler „j“ definiert sowohl die Anzahl der durchgeführten Schleifendurchläufe, als auch das letzte Segment der zu testenden IP–Adresse. Über diesen Indexwert kann die zu testende Adressspanne beliebig angepasst werden. Die ICMP Echo Requests werden durch Integration des ping–Kommandos, welches softwareintern mit Hilfe der system–Funktion (Zeile 20) ausgeführt wird, durchgeführt. In den Zeilen 11 bis 14 werden char–Arrays initialisiert, welche durch das strcpy–Kommando gefüllt (Zeile 16 bis 18) und in Zeile 19 im Container „cdest“ mit Hilfe der sprintf–Funktion zusammengeführt werden. Der daraus resultierende String enthält das komplette Systemkommando „ping -c 1 -w 1 192.168.1.j >NULL“, wobei „j“ durch den aktuellen Wert des Schleifenzählers ersetzt werden muss. Die Parameter des ping–Befehls lassen sich wie folgt aufschlüsseln: -c 1 Abbruch nach senden „eines“ ECHO_RESPONSE Paketes -w 1 Abbruch nach „einer“ Sekunde Zeitüberschreitung Die Zeitspanne zwischen zwei ping–Vorgängen wird durch Anagabe dieser Parameter wesentlich verkürzt, was ein schnelleres Auffinden des WLAN–Partners garantiert. Über Angabe von „>NULL“ wird die komplette Konsolenausgabe ins Nichts umgeleitet. Der Rückgabewert des system–Befehls, welcher als Integer–Wert interpretierbar ist, lässt auf den Erfolg der eingebetteten Anwendung schließen. Ist dieser -1, so konnte das Kommando nicht ordnungsgemäß ausgeführt werden. Andernfalls kann über das WEXITSTATUS–Macro (Zeile 28) der Status des spezifizierten Kommandos ermittelt werden. Dieser wird in Zeile 28 ausgewertet. Bei Rückgabe des Wertes 0 wurde ein ICMP Echo Response Paket empfangen und ein Netzwerkpartner identifiziert (Quelle: QNX Momentics V6.3 Documentation). - 79 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX 1 int rz; 2 int j = 0; 3 4 printf("Scanne nach WLAN Partnern\n"); 5 6 while(true) 7 { 8 9 for(j=1;j<=50;j++) 10 { 11 char cs1[20]; 12 char cs2[10]; 13 char cs3[5]; 14 char cdest[40]; 15 16 strcpy(cs1,"ping -c 1 -w 1 "); 17 strcpy(cs2,"192.168.1."); 18 strcpy(cs3,">NULL"); 19 sprintf(cdest,"%s%s%d%s",cs1,cs2,j,cs3); 20 rz = system(cdest); 21 22 if( rz == -1 ) 23 { printf( "Kommando konnte nicht ausgefuehrt werden\n" ); 24 25 } 26 else 27 { 28 if(WEXITSTATUS( rz )==0) 29 { 30 printf("WLAN Device 192.168.1.%d verfuegbar\n",j); 31 break; 32 } 33 else 34 { printf("Scanning... IP 192.168.1.%d\n",j); 35 } 36 } 37 } 38 39 40 } 41 42 printf("Socketverbindung zu Server wird initiiert...\n"); Listing 10.2 : Softwareinterne Identifikation des Netzwerkpartners - 80 - WLAN–Integration eines Embedded Automotive Frameworks unter QNX Das in Listing 10.2 dargestellte Schleifenkonstrukt ist auf der angehängten CD–Beilage im Quelltext der „WLANConCheck“–Anwendung eingebunden, welches eigenständig zu Testzwecken entwickelt wurde. Nachdem eine Netzwerkanbindung erkannt wurde (Zeile 28 bis 32) kann der Schleifenkörper über eine break–Anweisung verlassen werden. Das Programm ist nun in Kenntnis der Server– IP–Adresse und kann den entsprechenden Socket aufbauen. Hierzu können die ebenfalls beiliegenden Quelltexte für Client und Server in das Projekt integriert werden, welche ebenfalls für die Datenübertragung verwendet werden. Der Client schickt hierbei nach Initiierung der Socket–Verbindung eine Anfrage in Form von GETFILE [Dateiname], auf welche der Server entweder mit NOTFOUND reagiert, falls die Datei nicht vorhanden ist, oder die Datenübertragung in die Wege leitet. Die Datei wird hierbei in Pakete von 1024 Bytes unterteilt. Die Anzahl der Pakete lässt sich daher als Quotient der Dateilänge in Bytes und dem Wert 1024 bestimmen. Abschließend werden die empfangenen Daten interpretiert und auf der HMI mit Hilfe des systemeigenen QNX Photon microGUI Windowing-Systems zur Anzeige gebracht. Beschriebene verbindungsgesteuerte Client–Server–Anwendung wurde bis dato komponentenweise realisiert und getestet, eine vollständige Realisierung und Präsentation befindet sich in Arbeit. - 81 - 11. Ergebnis 11.1 Zusammenfassung Ziel der Arbeit war es die WLAN–Technologie im Bezug auf den Einsatz im KFZ zu durchleuchten und softwaretechnische Lösungsstrategien aufzuzeigen. Eine Verifizierung vorhandener Verbindungsmanager nach speziellen Kriterien, welche der mobile Einsatz im Kraftfahrzeug mit sich bringt, bot hierbei die Grundlage für die entwickelten Implementierungsstrategien. Die Notwendigkeit eine softwareinterne WLAN– Verbindungsverwaltung zu schaffen um Netzwerkanbindungen in Abhängigkeit von spezifischen Zuständen und Anforderungen anzustreben, führte zur Entwicklung der Anwendung "WLANConnector" für das Embedded Betriebssystem Pocket PC 2003. Hierbei bot das NDISUIO–Protokoll die benötigten Schnittstellen zur hardwarenahen Manipulation der WLAN–Adapter. Der Umgang mit diesen APIs stellte sich dabei als recht kompliziert heraus, da sich die Gerätezugriffe über mehrfach verschachtelte Strukturen als sehr abstrakt erwiesen. Das Microsoft Developer Network (MSDN) bot hierbei zwar eine recht ausführliche Beschreibung des Befehlssatzes und seiner Funktion, jedoch wurde dies kaum mit praxisnahen Beispielen und Quelltextausschnitten untermauert. Zusätzliche Korrespondenz in fachspezifischen Foren65 erwies sich als außerordentlich hilfreich. Die bei umfangreichen Internetrecherchen ausfindig gemachte Wireless Research API (WRAPI), welche wesentliche WLAN–spezifische NDISUIO–Operationen in modularer Form enthält, konnte als implementierungstechnische Grundlage genutzt werden. Hierbei wurden die aufgeführten Funktionen, welche für den Einsatz auf Windows XP entwickelt wurden, an das Betriebssystem Pocket PC 2003 angepasst und in den entsprechenden Kontexten verwertet. Unterschiede, die sich bei der Nutzung auf diesen Plattformen ergaben, wurden berücksichtigt und sind in dieser Arbeit ausführlich dokumentiert. Die Tatsache, dass sich das Verhalten von WLAN–Geräten in den zwei Infrastrukturmodi grundlegend unterscheidet, führte zu gesonderter Untersuchung und Softwarekonzipierung. Das Bestreben, eine vollständig einsatzfähige Anwendung zu entwickeln, welche Benutzerinteraktion weitgehend vermeidet, band die weiterführende Betrachtung der IP-Adressvergabe in das Projekt ein. Die entwickelte Software konnte durch Integration von softwareintern eingebundenen Anwendungskomponenten auf Praktikabilität getestet werden. Schwachstellen wurden daher in den verschiedenen Implementierungsphasen erkannt und ausgemerzt. Eine Portierung des entwickelten Softwaregerüstes für den Einsatz in einem Embedded Automotive Framework, unter den Betriebssystem QNX, wurde durch grundlegende systemspezifische Faktoren beeinträchtigt. 65 www.pocketpcdn.com/forum/ - 82 - Ergebnis Der Versuch interne WLAN–Adapter einzubinden scheiterte an der Tatsache, dass keine funktionstüchtigen Treiber zur Verfügung standen. Um einen Einstieg in die Geräteverwaltung im Allgemeinen und den Umgang mit Netzwerkadaptern im Besonderen zu bieten, setzt sich die Arbeit im Weiteren mit systemspezifischen Kommandos und ihren Funktionen auseinander. Eine alternative Lösung zur drahtlosen Netzwerkanbindung wurde durch den Einsatz von externen Ethernet–WLAN–Adaptern geschaffen. Damit war eine vollständige WLAN– Integration in das vorhandene Labornetzwerk möglich. Nachteilig an diesem Verfahren ist die eingeschränkte Konfigurierbarkeit dieser Geräte. Dem angeschlossenen Target sind keine Möglichkeiten gegeben Adapterkonfigurationen vorzunehmen. Hiermit konnte das einleitende Tankstellenszenario nachgebildet werden. Über eine Anwendung, welche eine hergestellte Netzwerkanbindung dynamisch erkennt, wird eine Client-Server-Kommunikation in die Wege geleitet, welche die Möglichkeit bietet automatisiert Daten auf das Target zu transferieren. 11.2 Bewertung Es wurde bewiesen, dass der WLAN–Einsatz in Kraftfahrzeugen mit individuellen Softwarelösungen problemlos realisierbar ist. Weiterhin konnten vorteilhafte Nutzungsszenarien vorgestellt werden, welche auf Tank– und Raststätten, ebenso wie im privaten oder geschäftlichen Umfeld, umsetzbar sind und eine komfortable dynamische WLAN–Netzwerkanbindung ermöglichen. 11.3 Ausblick Beständige Weiterentwicklung des WLAN–Standards im Bezug auf Dynamik und Signalreichweite erhöhen die Attraktivität der vorgestellten Lösungen. So soll die Entwicklung eines 802.11p Standards speziell für den Einsatz im KFZ zugeschnitten werden. Hierbei kommen eigens entwickelte Routingprotokolle zum Einsatz, welche die Kommunikation über mehrere Netzwerkstationen hinweg ermöglichen sollen. Diese so genannten Mesh–Netze [WIMAH05] wurden bereits in der Einleitung erwähnt. Durch erweiterte Abtastverfahren, Netzwerkpartnern erkundet Sekundenbruchteilen wird, ermöglicht bei denen soll eine werden. Ein 66 Geschwindigkeiten wird dadurch realisierbar. die Umgebung Kommunikation nach verfügbaren innerhalb Verbindungsaufbau bei von hohen Einige Ansätze, welche auch bei der Erforschung dieser zukunftsorientierten Technik von Bedeutung sind, wurden in dieser Arbeit aufgezeigt und erläutert. 66 siehe: http://www.funkschau.de/heftarchiv/pdf/2005/fs13/fs_0513_s45.pdf - 83 - Ergebnis Ein weiterer Vorzug der WLAN–Technologie ist die Unabhängigkeit von kommerziellen Vermittlungsinstanzen. UMTS (Universal Mobile Telecommunications System) bietet Datenübertragungsraten von bis zu 2 Mbit/s und ist deutschlandweit großflächig verfügbar. Internetzugang kann somit fast von überall erlangt werden. Die Tatsache, dass die Kommunikation über zentrale Vermittlungsstellungen gesteuert wird, schließt jegliche direkte Interaktion mit Netzwerkknoten von vorneherein aus und ist daher für das behandelte Einsatzgebiet bedeutungslos. Abschließend kann gesagt werden, dass der WLAN–Technologie, gerade im mobilen Bereich eine viel versprechende Zukunft prophezeit werden kann. WLAN – Eine Technik mit Zukunft - 84 - A Abbildungsverzeichnis 2.1 Einordnung von IEEE 802.11 im ISO OSI Kommunikationsmodell . . . . . . . . . . 6 2.2 Infrastruktur–Szenario . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.3 Ad–hoc–Szenario . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 5.1 Windows 802.11 Netzwerktreiber–Architektur . . . . . . . . . . . . . . . . . . . . . . . . . . 25 6.1 Erzeugen des Worker Threads mit der Threadfunktion „ScanIP“ . . . . . . . . . . . . 44 7.1 Auslesen des Verbindungsstatus über NDISUIO . . . . . . . . . . . . . . . . . . . . . . . . 49 10.1 WLAN Integration ICM Labor FH–Darmstadt . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 B Screenshots 5.1 WZC–DLL in der Windows CE Registrierung . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 6.1 Definition der "WZC"–DLL in der Windows CE – Registrierung . . . . . . . . . . . . . 31 6.2 WLANConnector – Ad–hoc Netzwerkscan . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 6.3 WLANConnector – Ad–hoc verbunden . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 6.4 VOIP Telefon SJphone . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 7.1 WLANConnector – Infrastruktur Netzwerkscan . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.2 WLANConnector – Infrastruktur verbunden . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7.3 Informationsanwendung mit Webserver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 - 85 - C Listings 5.1 Deaktivieren der Wireless Zero Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . 23 5.2 Erzeugung eines NDISUIO–Handles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 5.3 DeviceIoControl inklusive typisierter Parameter [MSDN05] . . . . . . . . . . . . . . . . 27 5.4 Beispiel für die Definition einer NDIS–OID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 6.1 Generierung einer Zufallszahl für letztes Segment der IP–Adresse . . . . . . . . . . 31 6.2 Deklaration der Variablen innerhalb der swapIP–Funktion . . . . . . . . . . . . . . . . . 32 6.3 Erstellen oder Öffnen eines Registry Keys . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 6.4 Schreiben der AutoIP–Variablen in CE Registrierung . . . . . . . . . . . . . . . . . . . . 33 6.5 Freigabe des Handles auf einen geöffneten Key . . . . . . . . . . . . . . . . . . . . . . . . 34 6.6 IpRenewAddress – Internet Protocol Helper API . . . . . . . . . . . . . . . . . . . . . . . . 35 6.7 Struktur NDISUIO_SET_OID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 6.8 Setzen des Infrastrukturmodus auf Ad–hoc . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 6.9 Setzen des Authentifizierungsmodus (Anpassung der WRAPI) . . . . . . . . . . . . . 39 6.10 Struktur NDIS_802_11_SSID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 6.11 Setzen der SSID / BSSID / IBSSID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 6.12 Erzeugen des Worker Threads mit der Threadfunktion „ScanIP“ . . . . . . . . . . . . 42 6.13 Sofwareinternes Starten der VOIP–Anwendung mit Hilfe von CreateProcess . . 46 7.1 Auslesen des Verbindungsstatus über NDISUIO . . . . . . . . . . . . . . . . . . . . . . . . 51 7.2 Sofwareinternes Starten des Internet Explorers mit spezifizierter Zielhost . . . . . 52 8.1 Enumeration der WLAN–Adapter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 8.2 Ausgabe der enumerierten WLAN–Adapter über die Konsole . . . . . . . . . . . . . . 56 8.3 Assoziation des Handles mit dem WLAN-Adapter . . . . . . . . . . . . . . . . . . . . . . . 57 9.1 Initiierung eines BSSID LIST SCANS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 9.2 Aufschlüsselung der NDIS_WLAN_BSSID–Struktur . . . . . . . . . . . . . . . . . . . . . 62 9.3 Auslesen der in der BSSID–Liste enumerierten WLAN–Geräte . . . . . . . . . . . . . 64 9.4 Prioritätsgesteuerter Verbindungsaufbau . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 10.1 Softwareinterne Integration von WLAN–Systembefehlen . . . . . . . . . . . . . . . . . . 72 10.2 Softwareinterne Identifikation des Netzwerkpartners . . . . . . . . . . . . . . . . . . . . . 80 - 86 - D Quellenverzeichnis [AWAP02] Arnold Willemer: APIPA – Automatic Private IP Addressing http://www.willemer.de/informatik/net/apipa.htm [JW04] Joachim Wietzke, Manh Tien Tran: Softwareentwicklung für Embedded Systeme, 2004 [MLMMS04] Dr. Marie-Louise Moschgath: Script zur Vorlesung „Sicherheit in der Mobilkommunikation“, 2004 [MSDN05] Microsoft Developer Network – http://msdn.microsoft.com/ [PPCDG05] Pocket PC 2003 Help - Pocket PC 2003 Development Guide [PPCDA05] Pocket PC Developer Network – Article: Working with registry on Pocket PC http://www.pocketpcdn.com/articles/registry.html [PPCDF05] PC Developer Network – Forum – http://www.pocketpcdn.com/forum/ [QNX05] QNX Momentics (v6.3) Documentation [WIEW05] http://de.wikipedia.org/wiki/Wireless_Adapter [WIOSI05] http://de.wikipedia.org/wiki/ISO-OSI-Referenzmodell [WIMFC05] http://de.wikipedia.org/wiki/Microsoft_Foundation_Classes [WINDIS05] http://de.wikipedia.org/wiki/NDIS [WIMAH05] http://de.wikipedia.org/wiki/Mobiles_Ad-hoc-Netzwerk [WITEL05] http://de.wikipedia.org/wiki/Telnet [WPDN103] Windows Platform Design Notes - Native 802.11 Frameworks for IEEE 802.11 Networks, Microsoft 2003 [WPDN203] Windows Platform Design Notes - IEEE 802.11 Network Adapter Design Guidelines for Windows XP [WRAPI05] WRAPI Documentation http://sysnet.ucsd.edu/pawn/wrapi/doc.html - 87 - E Eigenständigkeitserklärung Hiermit erkläre ich, dass ich die vorliegende Bachelorarbeit selbständig und nur mit den angegebenen Hilfsmitteln erstellt habe. Darmstadt, den 18. Oktober 2005 Dirk Andres - 88 -