<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"> <HTML ><HEAD ><TITLE >parport_register_driver</TITLE ><META NAME="GENERATOR" CONTENT="Modular DocBook HTML Stylesheet Version 1.7"><LINK REL="HOME" TITLE="The Linux 2.4 Parallel Port Subsystem" HREF="book1.html"><LINK REL="UP" TITLE=" Linux parallel port driver API reference " HREF="a950.html"><LINK REL="PREVIOUS" TITLE="parport_find_class" HREF="r1097.html"><LINK REL="NEXT" TITLE="parport_unregister_driver" HREF="r1177.html"></HEAD ><BODY CLASS="REFENTRY" BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#840084" ALINK="#0000FF" ><DIV CLASS="NAVHEADER" ><TABLE SUMMARY="Header navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TH COLSPAN="3" ALIGN="center" >The Linux 2.4 Parallel Port Subsystem</TH ></TR ><TR ><TD WIDTH="10%" ALIGN="left" VALIGN="bottom" ><A HREF="r1097.html" ACCESSKEY="P" ><<< Previous</A ></TD ><TD WIDTH="80%" ALIGN="center" VALIGN="bottom" ></TD ><TD WIDTH="10%" ALIGN="right" VALIGN="bottom" ><A HREF="r1177.html" ACCESSKEY="N" >Next >>></A ></TD ></TR ></TABLE ><HR ALIGN="LEFT" WIDTH="100%"></DIV ><H1 ><A NAME="AEN1138" ></A ><SPAN CLASS="phrase" ><SPAN CLASS="PHRASE" >parport_register_driver</SPAN ></SPAN ></H1 ><DIV CLASS="REFNAMEDIV" ><A NAME="AEN1142" ></A ><H2 >Name</H2 >parport_register_driver -- register a parallel port device driver </DIV ><DIV CLASS="REFSYNOPSISDIV" ><A NAME="AEN1145" ></A ><H2 >Synopsis</H2 ><DIV CLASS="FUNCSYNOPSIS" ><A NAME="AEN1147" ></A ><P ></P ><P ><CODE ><CODE CLASS="FUNCDEF" >int <TT CLASS="FUNCTION" >parport_register_driver </TT ></CODE >(struct parport_driver * <TT CLASS="PARAMETER" ><I >drv</I ></TT >);</CODE ></P ><P ></P ></DIV ></DIV ><DIV CLASS="REFSECT1" ><A NAME="AEN1153" ></A ><H2 >Arguments</H2 ><P ></P ><DIV CLASS="VARIABLELIST" ><DL ><DT ><TT CLASS="PARAMETER" ><I >drv</I ></TT ></DT ><DD ><P > structure describing the driver </P ></DD ></DL ></DIV ></DIV ><DIV CLASS="REFSECT1" ><A NAME="AEN1161" ></A ><H2 >Description</H2 ><P > This can be called by a parallel port device driver in order to receive notifications about ports being found in the system, as well as ports no longer available. </P ><P > The <TT CLASS="PARAMETER" ><I >drv</I ></TT > structure is allocated by the caller and must not be deallocated until after calling <TT CLASS="FUNCTION" >parport_unregister_driver</TT >. </P ><P > The driver's <TT CLASS="FUNCTION" >attach</TT > function may block. The port that <TT CLASS="FUNCTION" >attach</TT > is given will be valid for the duration of the callback, but if the driver wants to take a copy of the pointer it must call <TT CLASS="FUNCTION" >parport_get_port</TT > to do so. Calling <TT CLASS="FUNCTION" >parport_register_device</TT > on that port will do this for you. </P ><P > The driver's <TT CLASS="FUNCTION" >detach</TT > function may not block. The port that <TT CLASS="FUNCTION" >detach</TT > is given will be valid for the duration of the callback, but if the driver wants to take a copy of the pointer it must call <TT CLASS="FUNCTION" >parport_get_port</TT > to do so. </P ><P > Returns 0 on success. Currently it always succeeds. </P ></DIV ><DIV CLASS="NAVFOOTER" ><HR ALIGN="LEFT" WIDTH="100%"><TABLE SUMMARY="Footer navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" ><A HREF="r1097.html" ACCESSKEY="P" ><<< Previous</A ></TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="book1.html" ACCESSKEY="H" >Home</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" ><A HREF="r1177.html" ACCESSKEY="N" >Next >>></A ></TD ></TR ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" ><SPAN CLASS="phrase" ><SPAN CLASS="PHRASE" >parport_find_class</SPAN ></SPAN ></TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="a950.html" ACCESSKEY="U" >Up</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" ><SPAN CLASS="phrase" ><SPAN CLASS="PHRASE" >parport_unregister_driver</SPAN ></SPAN ></TD ></TR ></TABLE ></DIV ></BODY ></HTML >