Adaptation/GUID-9D4B8CDF-60D7-5952-AAAF-94A3C1E8908F.dita
author Graeme Price <GRAEME.PRICE@NOKIA.COM>
Fri, 15 Oct 2010 14:32:18 +0100
changeset 15 307f4279f433
permissions -rw-r--r--
Initial contribution of the Adaptation Documentation.

<?xml version="1.0" encoding="utf-8"?>
<!-- Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies) All rights reserved. -->
<!-- This component and the accompanying materials are made available under the terms of the License 
"Eclipse Public License v1.0" which accompanies this distribution, 
and is available at the URL "http://www.eclipse.org/legal/epl-v10.html". -->
<!-- Initial Contributors:
    Nokia Corporation - initial contribution.
Contributors: 
-->
<!DOCTYPE concept
  PUBLIC "-//OASIS//DTD DITA Concept//EN" "concept.dtd">
<concept id="GUID-9D4B8CDF-60D7-5952-AAAF-94A3C1E8908F" xml:lang="en"><title>Architecture</title><shortdesc>Explains architecture of the User-Side Hardware Abstraction (HAL)
component.</shortdesc><prolog><metadata><keywords/></metadata></prolog><conbody>
<fig id="GUID-38D3E959-F627-592D-A05F-9F907B6DB95C">
<image href="GUID-FF2ABA1D-1F71-5A9C-AFD5-A0CED39BFD86_d0e39571_href.png" placement="inline"/>
</fig>
<ul>
<li id="GUID-47670BE0-64BD-53E8-A7EF-6735FC5C0DC5"><p>Specific items of hardware
related information are called <xref href="GUID-9AE254D4-AA60-579E-8D9D-F2797106A413.dita#GUID-9AE254D4-AA60-579E-8D9D-F2797106A413/GUID-174A663C-3943-5D36-B507-D97A687C168C">attributes</xref>. </p> <p>The base port customises the <filepath>hal.dll</filepath> library to
set which attributes can be used on a device. </p> <p>Some attributes are
simple values, but some attributes must be read and set with a function. These
functions are called accessor functions. The base port sets identifiers for
the accessor functions to use. </p> </li>
<li id="GUID-380B5157-C605-5231-AF98-A08FC974F812"><p>User-side programs use
the <xref href="GUID-9AE254D4-AA60-579E-8D9D-F2797106A413.dita#GUID-9AE254D4-AA60-579E-8D9D-F2797106A413/GUID-F1F21DDA-DEA0-502E-83DB-84DDCFA5CBF8">user-side
interface</xref> <xref href="GUID-BD00E7FC-C234-3111-87A5-10F79EB0F2B8.dita"><apiname>HAL</apiname></xref> class in <filepath>hal.dll</filepath> to
get and set information about attributes. </p> </li>
<li id="GUID-9795E5E7-88AC-56DA-8269-CD4C9493E2C4"><p>The accessor functions
are implemented on the kernel side by functions called <xref href="GUID-9AE254D4-AA60-579E-8D9D-F2797106A413.dita#GUID-9AE254D4-AA60-579E-8D9D-F2797106A413/GUID-1B59A40C-D023-5555-8E5E-DF18D653D321">HAL handlers</xref>. </p> <p>The variant DLL and many device drivers in a
base port can implement HAL handlers. </p> </li>
<li id="GUID-0C70C3D4-3FD0-5CD8-A7C0-A28C77417460"><p>Kernel-side programs
can use the <xref href="GUID-9AE254D4-AA60-579E-8D9D-F2797106A413.dita#GUID-9AE254D4-AA60-579E-8D9D-F2797106A413/GUID-042A8840-2260-5951-8951-E6E2A83F378E">Kernel-side
interface</xref> <xref href="GUID-C6946ECB-775F-3EC2-A56F-78F25B9FBE3D.dita#GUID-C6946ECB-775F-3EC2-A56F-78F25B9FBE3D/GUID-DA115709-A225-3E2A-BCCD-6E2BB15979B9"><apiname>Kern::HalFunction()</apiname></xref> function to call HAL
handler functions. </p> </li>
</ul>
</conbody></concept>