/* Editor Settings: expandtabs and use 4 spaces for indentation * ex: set softtabstop=4 tabstop=8 expandtab shiftwidth=4: * * -*- mode: c, c-basic-offset: 4 -*- */ /* * Copyright Likewise Software * All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or (at * your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. You should have received a copy of the GNU General * Public License along with this program. If not, see * . * * LIKEWISE SOFTWARE MAKES THIS SOFTWARE AVAILABLE UNDER OTHER LICENSING * TERMS AS WELL. IF YOU HAVE ENTERED INTO A SEPARATE LICENSE AGREEMENT * WITH LIKEWISE SOFTWARE, THEN YOU MAY ELECT TO USE THE SOFTWARE UNDER THE * TERMS OF THAT SOFTWARE LICENSE AGREEMENT INSTEAD OF THE TERMS OF THE GNU * GENERAL PUBLIC LICENSE, NOTWITHSTANDING THE ABOVE NOTICE. IF YOU * HAVE QUESTIONS, OR WISH TO REQUEST A COPY OF THE ALTERNATE LICENSING * TERMS OFFERED BY LIKEWISE SOFTWARE, PLEASE CONTACT LIKEWISE SOFTWARE AT * license@likewisesoftware.com */ /* * Copyright (C) Likewise Software. All rights reserved. * * Module Name: * * thread_worker.c * * Abstract: * * Likewise Posix File System Driver (PVFS) * * Worker thread pool * * Authors: Gerald Carter */ #include "pvfs.h" /* File Globals */ static PVFS_WORKER_POOL gWorkPool; /* Forward declarations */ static PVOID PvfsWorkerDoWork( PVOID pArgs ); /* Code */ /************************************************************ **********************************************************/ NTSTATUS PvfsInitWorkerThreads( VOID ) { NTSTATUS ntError = STATUS_UNSUCCESSFUL; int i = 0; int unixerr = 0; int ret = 0; /* Both of these will be blocking queues */ ntError = PvfsInitWorkQueue( &gpPvfsInternalWorkQueue, 0, /* unlimited */ (PPVFS_LIST_FREE_DATA_FN)PvfsFreeWorkContext, TRUE); BAIL_ON_NT_STATUS(ntError); ntError = PvfsInitWorkQueue( &gpPvfsIoWorkQueue, PVFS_WORKERS_MAX_WORK_ITEMS, (PPVFS_LIST_FREE_DATA_FN)PvfsFreeWorkContext, TRUE); BAIL_ON_NT_STATUS(ntError); ntError = PvfsAllocateMemory( (PVOID*)&gWorkPool.IoWorkers, PVFS_WORKERS_NUMBER_THREADS * sizeof(PVFS_WORKER)); BAIL_ON_NT_STATUS(ntError); /* I/O Worker Threads */ gWorkPool.PoolSize = PVFS_WORKERS_NUMBER_THREADS; for (i=0; ibIsIrpContext) { pIrpCtx = (PPVFS_IRP_CONTEXT)pWorkCtx->pContext; PvfsQueueCancelIrpIfRequested(pIrpCtx); bActive = PvfsIrpContextMarkIfNotSetFlag( pIrpCtx, PVFS_IRP_CTX_FLAG_CANCELLED, PVFS_IRP_CTX_FLAG_ACTIVE); if (bActive) { ntError = pWorkCtx->pfnCompletion(pWorkCtx->pContext); } else { ntError = STATUS_CANCELLED; } /* Check to to see if the request was requeued */ if (ntError != STATUS_PENDING) { pIrpCtx->pIrp->IoStatusBlock.Status = ntError; PvfsAsyncIrpComplete(pIrpCtx); } } else { ntError = pWorkCtx->pfnCompletion(pWorkCtx->pContext); } PvfsFreeWorkContext(&pWorkCtx); } return NULL; } /* local variables: mode: c c-basic-offset: 4 indent-tabs-mode: nil tab-width: 4 end: */