Blame source/vdo/kernel/threadDevice.h

Packit Service d40955
/*
Packit Service d40955
 * Copyright (c) 2020 Red Hat, Inc.
Packit Service d40955
 *
Packit Service d40955
 * This program is free software; you can redistribute it and/or
Packit Service d40955
 * modify it under the terms of the GNU General Public License
Packit Service d40955
 * as published by the Free Software Foundation; either version 2
Packit Service d40955
 * of the License, or (at your option) any later version.
Packit Service d40955
 * 
Packit Service d40955
 * This program is distributed in the hope that it will be useful,
Packit Service d40955
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service d40955
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service d40955
 * GNU General Public License for more details.
Packit Service d40955
 * 
Packit Service d40955
 * You should have received a copy of the GNU General Public License
Packit Service d40955
 * along with this program; if not, write to the Free Software
Packit Service d40955
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
Packit Service d40955
 * 02110-1301, USA. 
Packit Service d40955
 *
Packit Service d40955
 * $Id: //eng/vdo-releases/aluminum/src/c++/vdo/kernel/threadDevice.h#1 $
Packit Service d40955
 */
Packit Service d40955
Packit Service d40955
#include "kernelLayer.h"
Packit Service d40955
Packit Service d40955
/**
Packit Service d40955
 * Temporarily register the current thread as being associated with a
Packit Service d40955
 * VDO device id number, for logging purposes.
Packit Service d40955
 *
Packit Service d40955
 * Any such registered thread must later be unregistered via
Packit Service d40955
 * unregisterThreadDeviceID.
Packit Service d40955
 *
Packit Service d40955
 * The pointed-to ID number should be nonzero.
Packit Service d40955
 *
Packit Service d40955
 * @param newThread  RegisteredThread structure to use for the current thread
Packit Service d40955
 * @param idPtr      Location where the ID number is stored
Packit Service d40955
 **/
Packit Service d40955
void registerThreadDeviceID(RegisteredThread *newThread, unsigned int *idPtr);
Packit Service d40955
Packit Service d40955
/**
Packit Service d40955
 * Temporarily register the current thread as being associated with an
Packit Service d40955
 * existing VDO device, for logging purposes.
Packit Service d40955
 *
Packit Service d40955
 * Any such registered thread must later be unregistered via
Packit Service d40955
 * unregisterThreadDeviceID.
Packit Service d40955
 *
Packit Service d40955
 * @param newThread  RegisteredThread structure to use for the current thread
Packit Service d40955
 * @param layer      The KernelLayer object for the VDO device
Packit Service d40955
 **/
Packit Service d40955
static inline void registerThreadDevice(RegisteredThread *newThread,
Packit Service d40955
                                        KernelLayer      *layer)
Packit Service d40955
{
Packit Service d40955
  registerThreadDeviceID(newThread, &layer->instance);
Packit Service d40955
}
Packit Service d40955
Packit Service d40955
/**
Packit Service d40955
 * Cancel registration of the current thread as being associated with
Packit Service d40955
 * a VDO device or device ID number.
Packit Service d40955
 **/
Packit Service d40955
void unregisterThreadDeviceID(void);
Packit Service d40955
Packit Service d40955
/**
Packit Service d40955
 * Get the VDO device ID number temporarily associated with the
Packit Service d40955
 * current thread, if any.
Packit Service d40955
 *
Packit Service d40955
 * @return  the device ID number, if any, or -1
Packit Service d40955
 **/
Packit Service d40955
int getThreadDeviceID(void);
Packit Service d40955
Packit Service d40955
/**
Packit Service d40955
 * Initialize the thread device-ID registry.
Packit Service d40955
 **/
Packit Service d40955
void initializeThreadDeviceRegistry(void);