Merge remote branch 'nouveau/for-airlied' into drm-linus
[safe/jmp/linux-2.6] / drivers / usb / wusbcore / pal.c
index cc126b4..d0b172c 100644 (file)
  */
 #include "wusbhc.h"
 
+static void wusbhc_channel_changed(struct uwb_pal *pal, int channel)
+{
+       struct wusbhc *wusbhc = container_of(pal, struct wusbhc, pal);
+
+       if (channel < 0)
+               wusbhc_stop(wusbhc);
+       else
+               wusbhc_start(wusbhc);
+}
+
 /**
  * wusbhc_pal_register - register the WUSB HC as a UWB PAL
  * @wusbhc: the WUSB HC
@@ -26,7 +36,12 @@ int wusbhc_pal_register(struct wusbhc *wusbhc)
 {
        uwb_pal_init(&wusbhc->pal);
 
-       return uwb_pal_register(wusbhc->uwb_rc, &wusbhc->pal);
+       wusbhc->pal.name   = "wusbhc";
+       wusbhc->pal.device = wusbhc->usb_hcd.self.controller;
+       wusbhc->pal.rc     = wusbhc->uwb_rc;
+       wusbhc->pal.channel_changed = wusbhc_channel_changed;
+
+       return uwb_pal_register(&wusbhc->pal);
 }
 
 /**
@@ -35,5 +50,5 @@ int wusbhc_pal_register(struct wusbhc *wusbhc)
  */
 void wusbhc_pal_unregister(struct wusbhc *wusbhc)
 {
-       uwb_pal_unregister(wusbhc->uwb_rc, &wusbhc->pal);
+       uwb_pal_unregister(&wusbhc->pal);
 }