mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-14 00:25:17 +00:00
407a281a8e
This reverts commit e4b980c853d2114b25fa805a84ea288384416221. When a binary links against a .a archive (as opposed to a shared library), any symbols which are marked as 'weak' get silently dropped. As a result when the binary later runs, those 'weak' functions have an address of 0x0 and thus crash when run. This happened with virtlogd and virtlockd because they don't link to libvirt.so, but instead just libvirt_util.a and libvirt_rpc.a. The virRandomBits symbols was weak and so left out of the virtlogd & virtlockd binaries, despite being required by virHashTable functions. Various other binaries like libvirt_lxc, libvirt_iohelper, etc also link directly to .a files instead of libvirt.so, so are potentially at risk of dropping symbols leading to a later runtime crash. This is normal linker behaviour because a weak symbol is not treated as undefined, so nothing forces it to be pulled in from the .a You have to force the linker to pull in weak symbols using -u$SYMNAME which is not a practical approach. This risk is silent bad linkage that affects runtime behaviour is not acceptable for a fix that was merely trying to fix the test suite. So stop using __weak__ again. Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
67 lines
3.0 KiB
C
67 lines
3.0 KiB
C
/*
|
|
* virscsivhost.h: helper APIs for managing host scsi_host devices
|
|
*
|
|
* Copyright (C) 2016 IBM Corporation
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library 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
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library. If not, see
|
|
* <http://www.gnu.org/licenses/>.
|
|
*
|
|
* Authors:
|
|
* Eric Farman <farman@linux.vnet.ibm.com>
|
|
*/
|
|
|
|
#ifndef __VIR_SCSIHOST_H__
|
|
# define __VIR_SCSIHOST_H__
|
|
|
|
# include "internal.h"
|
|
# include "virobject.h"
|
|
# include "virutil.h"
|
|
|
|
typedef struct _virSCSIVHostDevice virSCSIVHostDevice;
|
|
typedef virSCSIVHostDevice *virSCSIVHostDevicePtr;
|
|
typedef struct _virSCSIVHostDeviceList virSCSIVHostDeviceList;
|
|
typedef virSCSIVHostDeviceList *virSCSIVHostDeviceListPtr;
|
|
|
|
typedef int (*virSCSIVHostDeviceFileActor)(virSCSIVHostDevicePtr dev,
|
|
const char *name, void *opaque);
|
|
|
|
int virSCSIVHostDeviceFileIterate(virSCSIVHostDevicePtr dev,
|
|
virSCSIVHostDeviceFileActor actor,
|
|
void *opaque);
|
|
const char *virSCSIVHostDeviceGetName(virSCSIVHostDevicePtr dev);
|
|
const char *virSCSIVHostDeviceGetPath(virSCSIVHostDevicePtr dev);
|
|
virSCSIVHostDevicePtr virSCSIVHostDeviceListGet(virSCSIVHostDeviceListPtr list,
|
|
int idx);
|
|
size_t virSCSIVHostDeviceListCount(virSCSIVHostDeviceListPtr list);
|
|
virSCSIVHostDevicePtr virSCSIVHostDeviceListSteal(virSCSIVHostDeviceListPtr list,
|
|
virSCSIVHostDevicePtr dev);
|
|
virSCSIVHostDevicePtr virSCSIVHostDeviceListFind(virSCSIVHostDeviceListPtr list,
|
|
virSCSIVHostDevicePtr dev);
|
|
int virSCSIVHostDeviceListAdd(virSCSIVHostDeviceListPtr list,
|
|
virSCSIVHostDevicePtr dev);
|
|
void virSCSIVHostDeviceListDel(virSCSIVHostDeviceListPtr list,
|
|
virSCSIVHostDevicePtr dev);
|
|
virSCSIVHostDeviceListPtr virSCSIVHostDeviceListNew(void);
|
|
virSCSIVHostDevicePtr virSCSIVHostDeviceNew(const char *name);
|
|
int virSCSIVHostDeviceSetUsedBy(virSCSIVHostDevicePtr dev,
|
|
const char *drvname,
|
|
const char *domname);
|
|
void virSCSIVHostDeviceGetUsedBy(virSCSIVHostDevicePtr dev,
|
|
const char **drv_name,
|
|
const char **dom_name);
|
|
void virSCSIVHostDeviceFree(virSCSIVHostDevicePtr dev);
|
|
int virSCSIVHostOpenVhostSCSI(int *vhostfd) ATTRIBUTE_NOINLINE;
|
|
|
|
#endif /* __VIR_SCSIHOST_H__ */
|