187d2adbcSAndrew Rist /**************************************************************
2cdf0e10cSrcweir *
387d2adbcSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
487d2adbcSAndrew Rist * or more contributor license agreements. See the NOTICE file
587d2adbcSAndrew Rist * distributed with this work for additional information
687d2adbcSAndrew Rist * regarding copyright ownership. The ASF licenses this file
787d2adbcSAndrew Rist * to you under the Apache License, Version 2.0 (the
887d2adbcSAndrew Rist * "License"); you may not use this file except in compliance
987d2adbcSAndrew Rist * with the License. You may obtain a copy of the License at
10cdf0e10cSrcweir *
1187d2adbcSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir *
1387d2adbcSAndrew Rist * Unless required by applicable law or agreed to in writing,
1487d2adbcSAndrew Rist * software distributed under the License is distributed on an
1587d2adbcSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
1687d2adbcSAndrew Rist * KIND, either express or implied. See the License for the
1787d2adbcSAndrew Rist * specific language governing permissions and limitations
1887d2adbcSAndrew Rist * under the License.
19cdf0e10cSrcweir *
2087d2adbcSAndrew Rist *************************************************************/
2187d2adbcSAndrew Rist
22cdf0e10cSrcweir //#define INCL_DOSERRORS
23cdf0e10cSrcweir #include "system.h"
24cdf0e10cSrcweir
25cdf0e10cSrcweir #include <osl/pipe.h>
26cdf0e10cSrcweir #include <osl/diagnose.h>
27cdf0e10cSrcweir #include <osl/thread.h>
28cdf0e10cSrcweir #include <osl/mutex.h>
29cdf0e10cSrcweir #include <osl/semaphor.h>
30cdf0e10cSrcweir #include <osl/conditn.h>
31cdf0e10cSrcweir #include <osl/interlck.h>
32cdf0e10cSrcweir #include <osl/process.h>
33cdf0e10cSrcweir #include <rtl/ustring.hxx>
34cdf0e10cSrcweir
35cdf0e10cSrcweir #define PIPENAMEMASK "OSL_PIPE_%s"
36cdf0e10cSrcweir #define SECPIPENAMEMASK "OSL_PIPE_%s_%s"
37cdf0e10cSrcweir
38cdf0e10cSrcweir typedef enum {
39cdf0e10cSrcweir MSG_SYN,
40cdf0e10cSrcweir MSG_FIN,
41cdf0e10cSrcweir MSG_DATA,
42cdf0e10cSrcweir MSG_UNKNOWN
43cdf0e10cSrcweir } MessageType;
44cdf0e10cSrcweir
45cdf0e10cSrcweir struct oslPipeImpl {
46cdf0e10cSrcweir oslInterlockedCount m_Reference;
47cdf0e10cSrcweir HPIPE hPipe;
48cdf0e10cSrcweir HMTX m_NamedObject;
49cdf0e10cSrcweir APIRET nLastError;
50cdf0e10cSrcweir //oslSecurity m_Security;
51cdf0e10cSrcweir sal_Bool m_bClosed;
52cdf0e10cSrcweir };
53cdf0e10cSrcweir
54cdf0e10cSrcweir /* default size for input/output buffer */
55cdf0e10cSrcweir static const ULONG ulBufSize = 4096;
56cdf0e10cSrcweir
57cdf0e10cSrcweir /* OS/2 path for pipes */
58cdf0e10cSrcweir static const CHAR pszPipePath[] = "\\PIPE\\";
59cdf0e10cSrcweir static const UCHAR nPipePathLen = sizeof (pszPipePath) - 1;
60cdf0e10cSrcweir
61cdf0e10cSrcweir /* global last error value to be returned from oslGetLastPipeError */
62cdf0e10cSrcweir static APIRET ngLastError;
63cdf0e10cSrcweir
64cdf0e10cSrcweir using rtl::OString;
65cdf0e10cSrcweir using rtl::OUString;
66cdf0e10cSrcweir using rtl::OUStringToOString;
67cdf0e10cSrcweir
68cdf0e10cSrcweir /*****************************************************************************/
69cdf0e10cSrcweir /* osl_create/destroy-PipeImpl */
70cdf0e10cSrcweir /*****************************************************************************/
71cdf0e10cSrcweir
72cdf0e10cSrcweir static oslInterlockedCount nPipes = 0;
73cdf0e10cSrcweir
__osl_createPipeImpl(void)74cdf0e10cSrcweir oslPipe __osl_createPipeImpl(void)
75cdf0e10cSrcweir {
76cdf0e10cSrcweir oslPipe pPipe;
77cdf0e10cSrcweir
78cdf0e10cSrcweir pPipe = (oslPipe) calloc(1,sizeof(struct oslPipeImpl));
79cdf0e10cSrcweir
80cdf0e10cSrcweir pPipe->m_bClosed = sal_False;
81cdf0e10cSrcweir pPipe->m_Reference = 1;
82cdf0e10cSrcweir pPipe->hPipe = NULL;
83cdf0e10cSrcweir pPipe->m_NamedObject = NULL;
84cdf0e10cSrcweir
85cdf0e10cSrcweir return pPipe;
86cdf0e10cSrcweir }
87cdf0e10cSrcweir
__osl_destroyPipeImpl(oslPipe pPipe)88cdf0e10cSrcweir void __osl_destroyPipeImpl(oslPipe pPipe)
89cdf0e10cSrcweir {
90cdf0e10cSrcweir if (pPipe != NULL)
91cdf0e10cSrcweir {
92cdf0e10cSrcweir DosCloseMutexSem( pPipe->m_NamedObject);
93cdf0e10cSrcweir free(pPipe);
94cdf0e10cSrcweir }
95cdf0e10cSrcweir }
96cdf0e10cSrcweir
97cdf0e10cSrcweir
98cdf0e10cSrcweir /*****************************************************************************/
99cdf0e10cSrcweir /* osl_createPipe */
100cdf0e10cSrcweir /*****************************************************************************/
osl_createPipe(rtl_uString * ustrPipeName,oslPipeOptions Options,oslSecurity Security)101cdf0e10cSrcweir oslPipe SAL_CALL osl_createPipe(rtl_uString *ustrPipeName, oslPipeOptions Options,
102cdf0e10cSrcweir oslSecurity Security)
103cdf0e10cSrcweir {
104cdf0e10cSrcweir oslPipe pPipe;
105cdf0e10cSrcweir
106cdf0e10cSrcweir ULONG ulAction;
107cdf0e10cSrcweir CHAR strPipeNameBuffer [CCHMAXPATHCOMP];
108cdf0e10cSrcweir rtl_String* strPipeName=0;
109cdf0e10cSrcweir sal_Char* pszPipeName=0;
110cdf0e10cSrcweir
111cdf0e10cSrcweir /* check parameters */
112cdf0e10cSrcweir OSL_ASSERT( ustrPipeName );
113cdf0e10cSrcweir //YD 17/04/06 OSL_ASSERT( Security == 0 );
114cdf0e10cSrcweir
115cdf0e10cSrcweir /* allocate impl-structure */
116cdf0e10cSrcweir pPipe = __osl_createPipeImpl();
117cdf0e10cSrcweir if (!pPipe)
118cdf0e10cSrcweir {
119cdf0e10cSrcweir OSL_TRACE( "osl_createPipe failed allocating memory.\n" );
120cdf0e10cSrcweir return NULL;
121cdf0e10cSrcweir }
122cdf0e10cSrcweir
123cdf0e10cSrcweir /* create pipe name */
124cdf0e10cSrcweir OString sPipe = OUStringToOString(ustrPipeName, RTL_TEXTENCODING_ASCII_US);
125cdf0e10cSrcweir #if OSL_DEBUG_LEVEL>0
126cdf0e10cSrcweir debug_printf("osl_createPipe options 0x%x\n", Options);
127cdf0e10cSrcweir #endif
128cdf0e10cSrcweir
129cdf0e10cSrcweir switch( Options )
130cdf0e10cSrcweir {
131cdf0e10cSrcweir case osl_Pipe_OPEN:
132cdf0e10cSrcweir {
133cdf0e10cSrcweir APIRET fPipeAvailable;
134cdf0e10cSrcweir
135cdf0e10cSrcweir sprintf (strPipeNameBuffer, "\\PIPE\\OSL_PIPE_%s", sPipe.getStr());
136cdf0e10cSrcweir #if OSL_DEBUG_LEVEL>0
137cdf0e10cSrcweir debug_printf("osl_createPipe %s\n", strPipeNameBuffer);
138cdf0e10cSrcweir #endif
139cdf0e10cSrcweir ngLastError = DosOpen( (PCSZ)strPipeNameBuffer,
140cdf0e10cSrcweir &(pPipe->hPipe), &ulAction,
141cdf0e10cSrcweir 0, FILE_NORMAL, FILE_OPEN,
142cdf0e10cSrcweir OPEN_ACCESS_READWRITE | OPEN_SHARE_DENYREADWRITE,
143cdf0e10cSrcweir (PEAOP2) NULL);
144cdf0e10cSrcweir // if pipe is busy, wait for it
145cdf0e10cSrcweir if (ngLastError == ERROR_PIPE_BUSY)
146cdf0e10cSrcweir do
147cdf0e10cSrcweir {
148cdf0e10cSrcweir /* free instance should be available first */
149cdf0e10cSrcweir fPipeAvailable = DosWaitNPipe( (PCSZ)strPipeNameBuffer, -1);
150cdf0e10cSrcweir /* first try to open system pipe */
151cdf0e10cSrcweir if ( fPipeAvailable == NO_ERROR )
152cdf0e10cSrcweir {
153cdf0e10cSrcweir // We got it !
154cdf0e10cSrcweir ngLastError = NO_ERROR;
155cdf0e10cSrcweir break;
156cdf0e10cSrcweir }
157*2f91ea97Smseidel // Pipe instance maybe caught by another client -> try again
158cdf0e10cSrcweir printf("osl_createPipe wait for Pipe available\n");
159cdf0e10cSrcweir } while ( fPipeAvailable );
160cdf0e10cSrcweir }
161cdf0e10cSrcweir break;
162cdf0e10cSrcweir case osl_Pipe_CREATE:
163cdf0e10cSrcweir {
164cdf0e10cSrcweir sprintf (strPipeNameBuffer, "\\SEM32\\OSL_SEM_%s", sPipe.getStr());
165*2f91ea97Smseidel // check if semaphore exists (pipe create must fail for existing pipes)
166cdf0e10cSrcweir ngLastError = DosCreateMutexSem( (PCSZ)strPipeNameBuffer, &(pPipe->m_NamedObject), 0, TRUE );
167cdf0e10cSrcweir if (ngLastError)
168cdf0e10cSrcweir break;
169cdf0e10cSrcweir
170cdf0e10cSrcweir sprintf (strPipeNameBuffer, "\\PIPE\\OSL_PIPE_%s", sPipe.getStr());
171cdf0e10cSrcweir #if OSL_DEBUG_LEVEL>0
172cdf0e10cSrcweir debug_printf("osl_createPipe %s\n", strPipeNameBuffer);
173cdf0e10cSrcweir #endif
174cdf0e10cSrcweir ngLastError = DosCreateNPipe( (PCSZ)strPipeNameBuffer,
175cdf0e10cSrcweir &(pPipe->hPipe),
176cdf0e10cSrcweir NP_ACCESS_DUPLEX, /* open pipe for read and write access */
177cdf0e10cSrcweir 0xFF, /* allow unlimited number of instances */
178cdf0e10cSrcweir ulBufSize, /* output buffer size */
179cdf0e10cSrcweir ulBufSize, /* input buffer size */
180cdf0e10cSrcweir 0L /* use default time-out time */
181cdf0e10cSrcweir );
182cdf0e10cSrcweir }
183cdf0e10cSrcweir break;
184cdf0e10cSrcweir default:
185cdf0e10cSrcweir ngLastError = ERROR_INVALID_PARAMETER;
186cdf0e10cSrcweir }
187cdf0e10cSrcweir
188cdf0e10cSrcweir /* if failed, release allocated memory */
189cdf0e10cSrcweir if (ngLastError)
190cdf0e10cSrcweir {
191cdf0e10cSrcweir OSL_TRACE( "osl_createPipe failed %s the pipe %s, Error Code %d.\n",
192cdf0e10cSrcweir Options == osl_Pipe_OPEN ? "opening" : "creating",
193cdf0e10cSrcweir strPipeNameBuffer,
194cdf0e10cSrcweir ngLastError );
195cdf0e10cSrcweir __osl_destroyPipeImpl(pPipe);
196cdf0e10cSrcweir return NULL;
197cdf0e10cSrcweir }
198cdf0e10cSrcweir
199cdf0e10cSrcweir pPipe->m_Reference= 1;
200cdf0e10cSrcweir pPipe->m_bClosed = sal_False;
201cdf0e10cSrcweir //pPipe->m_Security = Security;
202cdf0e10cSrcweir pPipe->nLastError = NO_ERROR;
203cdf0e10cSrcweir return (oslPipe)pPipe;
204cdf0e10cSrcweir }
205cdf0e10cSrcweir
206cdf0e10cSrcweir /*****************************************************************************/
207cdf0e10cSrcweir /* osl_copyPipe */
208cdf0e10cSrcweir /*****************************************************************************/
osl_copyPipe(oslPipe pPipe)209cdf0e10cSrcweir oslPipe SAL_CALL osl_copyPipe(oslPipe pPipe)
210cdf0e10cSrcweir {
211cdf0e10cSrcweir //oslPipe* pPipe = (oslPipe*) Pipe;
212cdf0e10cSrcweir oslPipe pNewPipe;
213cdf0e10cSrcweir
214cdf0e10cSrcweir
215cdf0e10cSrcweir /* check parameter */
216cdf0e10cSrcweir OSL_ASSERT (pPipe);
217cdf0e10cSrcweir
218cdf0e10cSrcweir /* allocate impl-structure */
219cdf0e10cSrcweir pNewPipe = __osl_createPipeImpl();
220cdf0e10cSrcweir if (!pNewPipe) return NULL;
221cdf0e10cSrcweir
222cdf0e10cSrcweir /* create new handle */
223cdf0e10cSrcweir pNewPipe->hPipe = (HPIPE) -1;
224cdf0e10cSrcweir ngLastError = DosDupHandle( pPipe->hPipe, &(pNewPipe->hPipe) );
225cdf0e10cSrcweir
226cdf0e10cSrcweir /* if failed, release allocated memory */
227cdf0e10cSrcweir if (ngLastError)
228cdf0e10cSrcweir {
229cdf0e10cSrcweir OSL_TRACE( "osl_copyPipe failed duplicating pipe handle, Error-Code: %d.\n",
230cdf0e10cSrcweir ngLastError );
231cdf0e10cSrcweir free (pNewPipe);
232cdf0e10cSrcweir return NULL;
233cdf0e10cSrcweir }
234cdf0e10cSrcweir
235cdf0e10cSrcweir pNewPipe->nLastError = NO_ERROR;
236cdf0e10cSrcweir return (oslPipe)pNewPipe;
237cdf0e10cSrcweir }
238cdf0e10cSrcweir
osl_acquirePipe(oslPipe pPipe)239cdf0e10cSrcweir void SAL_CALL osl_acquirePipe( oslPipe pPipe )
240cdf0e10cSrcweir {
241cdf0e10cSrcweir osl_incrementInterlockedCount( &(pPipe->m_Reference) );
242cdf0e10cSrcweir }
243cdf0e10cSrcweir
osl_releasePipe(oslPipe pPipe)244cdf0e10cSrcweir void SAL_CALL osl_releasePipe( oslPipe pPipe )
245cdf0e10cSrcweir {
246cdf0e10cSrcweir // OSL_ASSERT( pPipe );
247cdf0e10cSrcweir
248cdf0e10cSrcweir if( 0 == pPipe )
249cdf0e10cSrcweir return;
250cdf0e10cSrcweir
251cdf0e10cSrcweir if( 0 == osl_decrementInterlockedCount( &(pPipe->m_Reference) ) )
252cdf0e10cSrcweir {
253cdf0e10cSrcweir if( ! pPipe->m_bClosed )
254cdf0e10cSrcweir osl_closePipe( pPipe );
255cdf0e10cSrcweir
256cdf0e10cSrcweir __osl_destroyPipeImpl( pPipe );
257cdf0e10cSrcweir }
258cdf0e10cSrcweir }
259cdf0e10cSrcweir
260cdf0e10cSrcweir /*****************************************************************************/
261cdf0e10cSrcweir /* osl_destroyPipe */
262cdf0e10cSrcweir /*************close****************************************************************/
osl_closePipe(oslPipe pPipe)263cdf0e10cSrcweir void SAL_CALL osl_closePipe(oslPipe pPipe)
264cdf0e10cSrcweir {
265cdf0e10cSrcweir //oslPipe* pPipe = (oslPipe*) Pipe;
266cdf0e10cSrcweir /* check parameter */
267cdf0e10cSrcweir OSL_ASSERT (pPipe);
268cdf0e10cSrcweir
269cdf0e10cSrcweir if( pPipe && ! pPipe->m_bClosed )
270cdf0e10cSrcweir {
271cdf0e10cSrcweir pPipe->m_bClosed = sal_True;
272cdf0e10cSrcweir /* if we have a system pipe close it */
273cdf0e10cSrcweir if (pPipe->hPipe != 0)
274cdf0e10cSrcweir {
275cdf0e10cSrcweir /* disconnect client */
276cdf0e10cSrcweir DosDisConnectNPipe (pPipe->hPipe);
277cdf0e10cSrcweir
278cdf0e10cSrcweir /* close the pipe */
279cdf0e10cSrcweir DosClose (pPipe->hPipe);
280cdf0e10cSrcweir }
281cdf0e10cSrcweir }
282cdf0e10cSrcweir }
283cdf0e10cSrcweir
284cdf0e10cSrcweir /*****************************************************************************/
285cdf0e10cSrcweir /* osl_acceptPipe */
286cdf0e10cSrcweir /*****************************************************************************/
osl_acceptPipe(oslPipe pPipe)287cdf0e10cSrcweir oslPipe SAL_CALL osl_acceptPipe(oslPipe pPipe)
288cdf0e10cSrcweir {
289cdf0e10cSrcweir
290cdf0e10cSrcweir #define PINFO ((PIPEINFO *) &PipeInfoBuffer)
291cdf0e10cSrcweir
292cdf0e10cSrcweir ///oslPipe* pPipe = (oslPipe*) Pipe;
293cdf0e10cSrcweir oslPipe pNewPipe;
294cdf0e10cSrcweir BYTE PipeInfoBuffer[sizeof(PIPEINFO) + CCHMAXPATHCOMP];
295cdf0e10cSrcweir
296cdf0e10cSrcweir /* check parameter */
297cdf0e10cSrcweir OSL_ASSERT (pPipe);
298cdf0e10cSrcweir
299cdf0e10cSrcweir /* get pipe information */
300cdf0e10cSrcweir pPipe->nLastError = DosQueryNPipeInfo(pPipe->hPipe,
301cdf0e10cSrcweir 1,
302cdf0e10cSrcweir (PVOID) &PipeInfoBuffer,
303cdf0e10cSrcweir sizeof(PipeInfoBuffer));
304cdf0e10cSrcweir
305cdf0e10cSrcweir if (pPipe->nLastError)
306cdf0e10cSrcweir {
307cdf0e10cSrcweir OSL_TRACE( "osl_acceptPipe failed for requesting pipe information.\n",
308cdf0e10cSrcweir pPipe->nLastError );
309cdf0e10cSrcweir return NULL;
310cdf0e10cSrcweir }
311cdf0e10cSrcweir
312cdf0e10cSrcweir /* create a new instance of the pipe if possible */
313cdf0e10cSrcweir if (PINFO->cbMaxInst == -1 || /* unlimited instances */
314cdf0e10cSrcweir PINFO->cbMaxInst > PINFO->cbCurInst)
315cdf0e10cSrcweir {
316cdf0e10cSrcweir HPIPE hPipe;
317cdf0e10cSrcweir
318cdf0e10cSrcweir pNewPipe = __osl_createPipeImpl();
319cdf0e10cSrcweir
320cdf0e10cSrcweir if (!pNewPipe)
321cdf0e10cSrcweir {
322cdf0e10cSrcweir OSL_TRACE( "osl_acceptPipe failed creating new instance.\n", ngLastError );
323cdf0e10cSrcweir free(pNewPipe);
324cdf0e10cSrcweir return NULL;
325cdf0e10cSrcweir }
326cdf0e10cSrcweir
327cdf0e10cSrcweir //pNewPipe->m_Security = pPipe->m_Security;
328cdf0e10cSrcweir
329cdf0e10cSrcweir pNewPipe->nLastError =
330cdf0e10cSrcweir DosCreateNPipe( (PCSZ)PINFO->szName,
331cdf0e10cSrcweir &(pNewPipe->hPipe),
332cdf0e10cSrcweir NP_ACCESS_DUPLEX, /* open pipe for read and write access */
333cdf0e10cSrcweir 0xFF, /* allow unlimited number of instances */
334cdf0e10cSrcweir ulBufSize, /* output buffer size */
335cdf0e10cSrcweir ulBufSize, /* input buffer size */
336cdf0e10cSrcweir 0L /* use default time-out time */
337cdf0e10cSrcweir );
338cdf0e10cSrcweir
339cdf0e10cSrcweir if (pNewPipe->nLastError)
340cdf0e10cSrcweir {
341cdf0e10cSrcweir OSL_TRACE( "osl_acceptPipe failed creating new named pipe, Error-Code: %d.\n",
342cdf0e10cSrcweir pNewPipe->nLastError );
343cdf0e10cSrcweir free(pNewPipe);
344cdf0e10cSrcweir return NULL;
345cdf0e10cSrcweir }
346cdf0e10cSrcweir
347cdf0e10cSrcweir /* switch pipe handles */
348cdf0e10cSrcweir hPipe = pPipe->hPipe;
349cdf0e10cSrcweir pPipe->hPipe = pNewPipe->hPipe;
350cdf0e10cSrcweir pNewPipe->hPipe = hPipe;
351cdf0e10cSrcweir
352cdf0e10cSrcweir /* connect new handle to client */
353cdf0e10cSrcweir pNewPipe->nLastError = DosConnectNPipe( pNewPipe->hPipe );
354cdf0e10cSrcweir
355cdf0e10cSrcweir /* if failed, release allocated memory */
356cdf0e10cSrcweir if (pNewPipe->nLastError)
357cdf0e10cSrcweir {
358cdf0e10cSrcweir OSL_TRACE( "osl_acceptPipe failed connecting pipe to client, Error-Code: %d.\n",
359cdf0e10cSrcweir pNewPipe->nLastError );
360cdf0e10cSrcweir
361cdf0e10cSrcweir osl_closePipe((oslPipe)pNewPipe);
362cdf0e10cSrcweir return NULL;
363cdf0e10cSrcweir }
364cdf0e10cSrcweir return (oslPipe)pNewPipe;
365cdf0e10cSrcweir }
366cdf0e10cSrcweir else
367cdf0e10cSrcweir {
368cdf0e10cSrcweir /* connect original handle to client */
369cdf0e10cSrcweir pPipe->nLastError = DosConnectNPipe( pPipe->hPipe );
370cdf0e10cSrcweir
371cdf0e10cSrcweir if (pPipe->nLastError)
372cdf0e10cSrcweir {
373cdf0e10cSrcweir OSL_TRACE( "osl_acceptPipe failed connecting pipe to client, Error-Code: %d.\n",
374cdf0e10cSrcweir pPipe->nLastError );
375cdf0e10cSrcweir return NULL;
376cdf0e10cSrcweir }
377cdf0e10cSrcweir
378cdf0e10cSrcweir return (oslPipe)pPipe;
379cdf0e10cSrcweir }
380cdf0e10cSrcweir }
381cdf0e10cSrcweir
382cdf0e10cSrcweir /*****************************************************************************/
383cdf0e10cSrcweir /* osl_receivePipe */
384cdf0e10cSrcweir /*****************************************************************************/
osl_receivePipe(oslPipe pPipe,void * pBuffer,sal_Int32 BytesToRead)385cdf0e10cSrcweir sal_Int32 SAL_CALL osl_receivePipe(oslPipe pPipe,
386cdf0e10cSrcweir void* pBuffer,
387cdf0e10cSrcweir sal_Int32 BytesToRead)
388cdf0e10cSrcweir {
389cdf0e10cSrcweir //oslPipe* pPipe = (oslPipe*) Pipe;
390cdf0e10cSrcweir ULONG ulActual;
391cdf0e10cSrcweir
392cdf0e10cSrcweir /* check parameter */
393cdf0e10cSrcweir OSL_ASSERT (pPipe);
394cdf0e10cSrcweir
395cdf0e10cSrcweir /* read data from pipe */
396cdf0e10cSrcweir pPipe->nLastError = DosRead( pPipe->hPipe, pBuffer, BytesToRead, &ulActual );
397cdf0e10cSrcweir
398cdf0e10cSrcweir /* return -1 if failed */
399cdf0e10cSrcweir if( pPipe->nLastError )
400cdf0e10cSrcweir {
401cdf0e10cSrcweir OSL_TRACE( "osl_receivePipe failed receiving from Pipe, Error-Code: %d.\n",
402cdf0e10cSrcweir pPipe->nLastError );
403cdf0e10cSrcweir return -1;
404cdf0e10cSrcweir }
405cdf0e10cSrcweir
406cdf0e10cSrcweir return ulActual;
407cdf0e10cSrcweir }
408cdf0e10cSrcweir
409cdf0e10cSrcweir
410cdf0e10cSrcweir /*****************************************************************************/
411cdf0e10cSrcweir /* osl_sendPipe */
412cdf0e10cSrcweir /*****************************************************************************/
osl_sendPipe(oslPipe pPipe,const void * pBuffer,sal_Int32 BytesToSend)413cdf0e10cSrcweir sal_Int32 SAL_CALL osl_sendPipe(oslPipe pPipe,
414cdf0e10cSrcweir const void* pBuffer,
415cdf0e10cSrcweir sal_Int32 BytesToSend)
416cdf0e10cSrcweir {
417cdf0e10cSrcweir //oslPipe* pPipe = (oslPipe*) Pipe;
418cdf0e10cSrcweir ULONG ulActual;
419cdf0e10cSrcweir
420cdf0e10cSrcweir /* check parameter */
421cdf0e10cSrcweir OSL_ASSERT (pPipe);
422cdf0e10cSrcweir
423cdf0e10cSrcweir /* read data from pipe */
424cdf0e10cSrcweir pPipe->nLastError = DosWrite( pPipe->hPipe, (PVOID) pBuffer, BytesToSend, &ulActual );
425cdf0e10cSrcweir
426cdf0e10cSrcweir /* return -1 if failed */
427cdf0e10cSrcweir if( pPipe->nLastError )
428cdf0e10cSrcweir {
429cdf0e10cSrcweir OSL_TRACE( "osl_receivePipe failed writing to Pipe, Error-Code: %d.\n",
430cdf0e10cSrcweir pPipe->nLastError );
431cdf0e10cSrcweir return -1;
432cdf0e10cSrcweir }
433cdf0e10cSrcweir
434cdf0e10cSrcweir return ulActual;
435cdf0e10cSrcweir }
436cdf0e10cSrcweir
437cdf0e10cSrcweir
438cdf0e10cSrcweir /*****************************************************************************/
439cdf0e10cSrcweir /* osl_getLastPipeError */
440cdf0e10cSrcweir /*****************************************************************************/
441cdf0e10cSrcweir
osl_getLastPipeError(oslPipe pPipe)442cdf0e10cSrcweir oslPipeError SAL_CALL osl_getLastPipeError(oslPipe pPipe)
443cdf0e10cSrcweir {
444cdf0e10cSrcweir //oslPipe* pPipe = (oslPipe*) Pipe;
445cdf0e10cSrcweir APIRET rc;
446cdf0e10cSrcweir
447cdf0e10cSrcweir /* return local error value if possible */
448cdf0e10cSrcweir if (pPipe)
449cdf0e10cSrcweir {
450cdf0e10cSrcweir rc = pPipe->nLastError;
451cdf0e10cSrcweir pPipe->nLastError = NO_ERROR;
452cdf0e10cSrcweir } else
453cdf0e10cSrcweir rc = ngLastError;
454cdf0e10cSrcweir
455cdf0e10cSrcweir /* map OS/2 error values */
456cdf0e10cSrcweir switch (rc)
457cdf0e10cSrcweir {
458cdf0e10cSrcweir case NO_ERROR: return osl_Pipe_E_None;
459cdf0e10cSrcweir case ERROR_PATH_NOT_FOUND: return osl_Pipe_E_NotFound;
460cdf0e10cSrcweir case ERROR_NOT_ENOUGH_MEMORY: return osl_Pipe_E_NoBufferSpace;
461cdf0e10cSrcweir default: return osl_Pipe_E_invalidError;
462cdf0e10cSrcweir }
463cdf0e10cSrcweir }
464cdf0e10cSrcweir
465cdf0e10cSrcweir /*****************************************************************************/
466cdf0e10cSrcweir
osl_writePipe(oslPipe pPipe,const void * pBuffer,sal_Int32 n)467cdf0e10cSrcweir sal_Int32 SAL_CALL osl_writePipe( oslPipe pPipe, const void *pBuffer , sal_Int32 n )
468cdf0e10cSrcweir {
46986e1cf34SPedro Giffuni /* loop until all desired bytes were send or an error occurred */
470cdf0e10cSrcweir sal_Int32 BytesSend= 0;
471cdf0e10cSrcweir sal_Int32 BytesToSend= n;
472cdf0e10cSrcweir
473cdf0e10cSrcweir OSL_ASSERT(pPipe);
474cdf0e10cSrcweir while (BytesToSend > 0)
475cdf0e10cSrcweir {
476cdf0e10cSrcweir sal_Int32 RetVal;
477cdf0e10cSrcweir
478cdf0e10cSrcweir RetVal= osl_sendPipe(pPipe, pBuffer, BytesToSend);
479cdf0e10cSrcweir
48086e1cf34SPedro Giffuni /* error occurred? */
481cdf0e10cSrcweir if(RetVal <= 0)
482cdf0e10cSrcweir {
483cdf0e10cSrcweir break;
484cdf0e10cSrcweir }
485cdf0e10cSrcweir
486cdf0e10cSrcweir BytesToSend -= RetVal;
487cdf0e10cSrcweir BytesSend += RetVal;
488cdf0e10cSrcweir pBuffer= (sal_Char*)pBuffer + RetVal;
489cdf0e10cSrcweir }
490cdf0e10cSrcweir
491cdf0e10cSrcweir return BytesSend;
492cdf0e10cSrcweir }
493cdf0e10cSrcweir
osl_readPipe(oslPipe pPipe,void * pBuffer,sal_Int32 n)494cdf0e10cSrcweir sal_Int32 SAL_CALL osl_readPipe( oslPipe pPipe, void *pBuffer , sal_Int32 n )
495cdf0e10cSrcweir {
49686e1cf34SPedro Giffuni /* loop until all desired bytes were read or an error occurred */
497cdf0e10cSrcweir sal_Int32 BytesRead= 0;
498cdf0e10cSrcweir sal_Int32 BytesToRead= n;
499cdf0e10cSrcweir
500cdf0e10cSrcweir OSL_ASSERT( pPipe );
501cdf0e10cSrcweir while (BytesToRead > 0)
502cdf0e10cSrcweir {
503cdf0e10cSrcweir sal_Int32 RetVal;
504cdf0e10cSrcweir RetVal= osl_receivePipe(pPipe, pBuffer, BytesToRead);
505cdf0e10cSrcweir
50686e1cf34SPedro Giffuni /* error occurred? */
507cdf0e10cSrcweir if(RetVal <= 0)
508cdf0e10cSrcweir {
509cdf0e10cSrcweir break;
510cdf0e10cSrcweir }
511cdf0e10cSrcweir
512cdf0e10cSrcweir BytesToRead -= RetVal;
513cdf0e10cSrcweir BytesRead += RetVal;
514cdf0e10cSrcweir pBuffer= (sal_Char*)pBuffer + RetVal;
515cdf0e10cSrcweir }
516cdf0e10cSrcweir return BytesRead;
517cdf0e10cSrcweir }
518cdf0e10cSrcweir
519cdf0e10cSrcweir
520cdf0e10cSrcweir /******************************************************************************
521cdf0e10cSrcweir *
522cdf0e10cSrcweir * New io resource transfer functions
523cdf0e10cSrcweir *
524cdf0e10cSrcweir *****************************************************************************/
525cdf0e10cSrcweir
526cdf0e10cSrcweir
527cdf0e10cSrcweir /**********************************************
528cdf0e10cSrcweir osl_sendResourcePipe
529cdf0e10cSrcweir *********************************************/
530cdf0e10cSrcweir
osl_sendResourcePipe(oslPipe pPipe,oslSocket pSocket)531cdf0e10cSrcweir sal_Bool osl_sendResourcePipe(oslPipe pPipe, oslSocket pSocket)
532cdf0e10cSrcweir {
533cdf0e10cSrcweir sal_Bool bRet = sal_False;
534cdf0e10cSrcweir
535cdf0e10cSrcweir return bRet;
536cdf0e10cSrcweir }
537cdf0e10cSrcweir
538cdf0e10cSrcweir /**********************************************
539cdf0e10cSrcweir osl_receiveResourcePipe
540cdf0e10cSrcweir *********************************************/
541cdf0e10cSrcweir
osl_receiveResourcePipe(oslPipe pPipe)542cdf0e10cSrcweir oslSocket osl_receiveResourcePipe(oslPipe pPipe)
543cdf0e10cSrcweir {
544cdf0e10cSrcweir oslSocket pSocket=0;
545cdf0e10cSrcweir
546cdf0e10cSrcweir return (oslSocket) pSocket;
547cdf0e10cSrcweir }
548cdf0e10cSrcweir
549*2f91ea97Smseidel /* vim: set noet sw=4 ts=4: */
550