/** IRQ handler arguments and return type and values */
#define DRM_IRQ_ARGS int irq, void *arg
/** backwards compatibility with old irq return values */
-#ifndef IRQ_HANDLED
+#if !defined(IRQ_HANDLED) && LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,29)
typedef void irqreturn_t;
#define IRQ_HANDLED /* nothing */
#define IRQ_NONE /* nothing */
#endif
+#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,25)
+static inline const char *dev_name(const struct device *dev)
+{
+ return dev->bus_id;
+}
+static inline int dev_set_name(struct device *dev, const char *name, ...)
+{
+ va_list vargs;
+
+ va_start(vargs, name);
+ vsnprintf(dev->bus_id, sizeof(dev->bus_id), name, vargs);
+ va_end(vargs);
+
+ return 0;
+}
+#endif
+
/** AGP types */
#if __OS_HAS_AGP
#define DRM_AGP_MEM struct agp_memory
minor->kdev.release = drm_sysfs_device_release;
minor->kdev.devt = minor->device;
minor_str = "card%d";
-
- snprintf(minor->kdev.bus_id, BUS_ID_SIZE, minor_str, minor->index);
+
+ err = dev_set_name(&minor->kdev, minor_str, minor->index);
+ if (err) {
+ DRM_ERROR("device set name failed: %d\n", err);
+ goto err_out;
+ }
err = device_register(&minor->kdev);
if (err) {