1 /*************************************************************************** 2 * CVSID: $Id$ 3 * 4 * osspec.h : OS Specific interface 5 * 6 * Copyright (C) 2003 David Zeuthen, <david@fubar.dk> 7 * 8 * Licensed under the Academic Free License version 2.1 9 * 10 * This program is free software; you can redistribute it and/or modify 11 * it under the terms of the GNU General Public License as published by 12 * the Free Software Foundation; either version 2 of the License, or 13 * (at your option) any later version. 14 * 15 * This program is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU General Public License for more details. 19 * 20 * You should have received a copy of the GNU General Public License 21 * along with this program; if not, write to the Free Software 22 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 23 * 24 **************************************************************************/ 25 26 #ifndef OSSPEC_H 27 #define OSSPEC_H 28 29 #include <stdarg.h> 30 #include <stdint.h> 31 #include <dbus/dbus.h> 32 33 #include "device.h" 34 35 /** Initialize the kernel specific parts of the daemon */ 36 void osspec_init (void); 37 38 /** Probe all devices present in the system and build the device list */ 39 void osspec_probe (void); 40 41 /* Called by kernel specific parts when probing is done */ 42 void osspec_probe_done (void); 43 44 gboolean osspec_device_rescan (HalDevice *d); 45 46 gboolean osspec_device_reprobe (HalDevice *d); 47 48 /* Called to refresh mount state for a device object of capability volume */ 49 void osspec_refresh_mount_state_for_block_device (HalDevice *d); 50 51 /** Called when the org.freedesktop.Hal service receives a messaged that the generic daemon 52 * doesn't handle. Can be used for intercepting messages from kernel or core OS components. 53 * 54 * @param connection D-BUS connection 55 * @param message Message 56 * @param user_data User data 57 * @return What to do with the message 58 */ 59 DBusHandlerResult osspec_filter_function (DBusConnection *connection, DBusMessage *message, void *user_data); 60 61 #endif /* OSSPEC_H */ 62