2  * UWB reservation management.
 
   4  * Copyright (C) 2008 Cambridge Silicon Radio Ltd.
 
   6  * This program is free software; you can redistribute it and/or
 
   7  * modify it under the terms of the GNU General Public License version
 
   8  * 2 as published by the Free Software Foundation.
 
  10  * This program is distributed in the hope that it will be useful,
 
  11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  13  * GNU General Public License for more details.
 
  15  * You should have received a copy of the GNU General Public License
 
  16  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
  18 #include <linux/version.h>
 
  19 #include <linux/kernel.h>
 
  20 #include <linux/uwb.h>
 
  22 #include "uwb-internal.h"
 
  24 static void uwb_rsv_timer(unsigned long arg);
 
  26 static const char *rsv_states[] = {
 
  27         [UWB_RSV_STATE_NONE]          = "none",
 
  28         [UWB_RSV_STATE_O_INITIATED]   = "initiated",
 
  29         [UWB_RSV_STATE_O_PENDING]     = "pending",
 
  30         [UWB_RSV_STATE_O_MODIFIED]    = "modified",
 
  31         [UWB_RSV_STATE_O_ESTABLISHED] = "established",
 
  32         [UWB_RSV_STATE_T_ACCEPTED]    = "accepted",
 
  33         [UWB_RSV_STATE_T_DENIED]      = "denied",
 
  34         [UWB_RSV_STATE_T_PENDING]     = "pending",
 
  37 static const char *rsv_types[] = {
 
  38         [UWB_DRP_TYPE_ALIEN_BP] = "alien-bp",
 
  39         [UWB_DRP_TYPE_HARD]     = "hard",
 
  40         [UWB_DRP_TYPE_SOFT]     = "soft",
 
  41         [UWB_DRP_TYPE_PRIVATE]  = "private",
 
  42         [UWB_DRP_TYPE_PCA]      = "pca",
 
  46  * uwb_rsv_state_str - return a string for a reservation state
 
  47  * @state: the reservation state.
 
  49 const char *uwb_rsv_state_str(enum uwb_rsv_state state)
 
  51         if (state < UWB_RSV_STATE_NONE || state >= UWB_RSV_STATE_LAST)
 
  53         return rsv_states[state];
 
  55 EXPORT_SYMBOL_GPL(uwb_rsv_state_str);
 
  58  * uwb_rsv_type_str - return a string for a reservation type
 
  59  * @type: the reservation type
 
  61 const char *uwb_rsv_type_str(enum uwb_drp_type type)
 
  63         if (type < UWB_DRP_TYPE_ALIEN_BP || type > UWB_DRP_TYPE_PCA)
 
  65         return rsv_types[type];
 
  67 EXPORT_SYMBOL_GPL(uwb_rsv_type_str);
 
  69 static void uwb_rsv_dump(struct uwb_rsv *rsv)
 
  71         struct device *dev = &rsv->rc->uwb_dev.dev;
 
  72         struct uwb_dev_addr devaddr;
 
  73         char owner[UWB_ADDR_STRSIZE], target[UWB_ADDR_STRSIZE];
 
  75         uwb_dev_addr_print(owner, sizeof(owner), &rsv->owner->dev_addr);
 
  76         if (rsv->target.type == UWB_RSV_TARGET_DEV)
 
  77                 devaddr = rsv->target.dev->dev_addr;
 
  79                 devaddr = rsv->target.devaddr;
 
  80         uwb_dev_addr_print(target, sizeof(target), &devaddr);
 
  82         dev_dbg(dev, "rsv %s -> %s: %s\n", owner, target, uwb_rsv_state_str(rsv->state));
 
  86  * Get a free stream index for a reservation.
 
  88  * If the target is a DevAddr (e.g., a WUSB cluster reservation) then
 
  89  * the stream is allocated from a pool of per-RC stream indexes,
 
  90  * otherwise a unique stream index for the target is selected.
 
  92 static int uwb_rsv_get_stream(struct uwb_rsv *rsv)
 
  94         struct uwb_rc *rc = rsv->rc;
 
  95         unsigned long *streams_bm;
 
  98         switch (rsv->target.type) {
 
  99         case UWB_RSV_TARGET_DEV:
 
 100                 streams_bm = rsv->target.dev->streams;
 
 102         case UWB_RSV_TARGET_DEVADDR:
 
 103                 streams_bm = rc->uwb_dev.streams;
 
 109         stream = find_first_zero_bit(streams_bm, UWB_NUM_STREAMS);
 
 110         if (stream >= UWB_NUM_STREAMS)
 
 113         rsv->stream = stream;
 
 114         set_bit(stream, streams_bm);
 
 119 static void uwb_rsv_put_stream(struct uwb_rsv *rsv)
 
 121         struct uwb_rc *rc = rsv->rc;
 
 122         unsigned long *streams_bm;
 
 124         switch (rsv->target.type) {
 
 125         case UWB_RSV_TARGET_DEV:
 
 126                 streams_bm = rsv->target.dev->streams;
 
 128         case UWB_RSV_TARGET_DEVADDR:
 
 129                 streams_bm = rc->uwb_dev.streams;
 
 135         clear_bit(rsv->stream, streams_bm);
 
 139  * Generate a MAS allocation with a single row component.
 
 141 static void uwb_rsv_gen_alloc_row(struct uwb_mas_bm *mas,
 
 142                                   int first_mas, int mas_per_zone,
 
 145         struct uwb_mas_bm col;
 
 148         bitmap_zero(mas->bm, UWB_NUM_MAS);
 
 149         bitmap_zero(col.bm, UWB_NUM_MAS);
 
 150         bitmap_fill(col.bm, mas_per_zone);
 
 151         bitmap_shift_left(col.bm, col.bm, first_mas + zs * UWB_MAS_PER_ZONE, UWB_NUM_MAS);
 
 153         for (z = zs; z <= ze; z++) {
 
 154                 bitmap_or(mas->bm, mas->bm, col.bm, UWB_NUM_MAS);
 
 155                 bitmap_shift_left(col.bm, col.bm, UWB_MAS_PER_ZONE, UWB_NUM_MAS);
 
 160  * Allocate some MAS for this reservation based on current local
 
 161  * availability, the reservation parameters (max_mas, min_mas,
 
 162  * sparsity), and the WiMedia rules for MAS allocations.
 
 164  * Returns -EBUSY is insufficient free MAS are available.
 
 166  * FIXME: to simplify this, only safe reservations with a single row
 
 167  * component in zones 1 to 15 are tried (zone 0 is skipped to avoid
 
 168  * problems with the MAS reserved for the BP).
 
 170  * [ECMA-368] section B.2.
 
 172 static int uwb_rsv_alloc_mas(struct uwb_rsv *rsv)
 
 174         static const int safe_mas_in_row[UWB_NUM_ZONES] = {
 
 175                 8, 7, 6, 5, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 2, 1,
 
 178         struct uwb_mas_bm mas;
 
 182          * Search all valid safe allocations until either: too few MAS
 
 183          * are available; or the smallest allocation with sufficient
 
 186          * The top of the zones are preferred, so space for larger
 
 187          * allocations is available in the bottom of the zone (e.g., a
 
 188          * 15 MAS allocation should start in row 14 leaving space for
 
 189          * a 120 MAS allocation at row 0).
 
 191         for (n = safe_mas_in_row[0]; n >= 1; n--) {
 
 194                 num_mas = n * (UWB_NUM_ZONES - 1);
 
 195                 if (num_mas < rsv->min_mas)
 
 197                 if (found && num_mas < rsv->max_mas)
 
 200                 for (r = UWB_MAS_PER_ZONE-1;  r >= 0; r--) {
 
 201                         if (safe_mas_in_row[r] < n)
 
 203                         uwb_rsv_gen_alloc_row(&mas, r, n, 1, UWB_NUM_ZONES);
 
 204                         if (uwb_drp_avail_reserve_pending(rsv->rc, &mas) == 0) {
 
 214         bitmap_copy(rsv->mas.bm, mas.bm, UWB_NUM_MAS);
 
 218 static void uwb_rsv_stroke_timer(struct uwb_rsv *rsv)
 
 220         int sframes = UWB_MAX_LOST_BEACONS;
 
 223          * Multicast reservations can become established within 1
 
 224          * super frame and should not be terminated if no response is
 
 227         if (rsv->is_multicast) {
 
 228                 if (rsv->state == UWB_RSV_STATE_O_INITIATED)
 
 230                 if (rsv->state == UWB_RSV_STATE_O_ESTABLISHED)
 
 234         rsv->expired = false;
 
 237                  * Add an additional 2 superframes to account for the
 
 238                  * time to send the SET DRP IE command.
 
 240                 unsigned timeout_us = (sframes + 2) * UWB_SUPERFRAME_LENGTH_US;
 
 241                 mod_timer(&rsv->timer, jiffies + usecs_to_jiffies(timeout_us));
 
 243                 del_timer(&rsv->timer);
 
 247  * Update a reservations state, and schedule an update of the
 
 248  * transmitted DRP IEs.
 
 250 static void uwb_rsv_state_update(struct uwb_rsv *rsv,
 
 251                                  enum uwb_rsv_state new_state)
 
 253         rsv->state = new_state;
 
 254         rsv->ie_valid = false;
 
 258         uwb_rsv_stroke_timer(rsv);
 
 259         uwb_rsv_sched_update(rsv->rc);
 
 262 static void uwb_rsv_callback(struct uwb_rsv *rsv)
 
 268 void uwb_rsv_set_state(struct uwb_rsv *rsv, enum uwb_rsv_state new_state)
 
 270         if (rsv->state == new_state) {
 
 271                 switch (rsv->state) {
 
 272                 case UWB_RSV_STATE_O_ESTABLISHED:
 
 273                 case UWB_RSV_STATE_T_ACCEPTED:
 
 274                 case UWB_RSV_STATE_NONE:
 
 275                         uwb_rsv_stroke_timer(rsv);
 
 278                         /* Expecting a state transition so leave timer
 
 286         case UWB_RSV_STATE_NONE:
 
 287                 uwb_drp_avail_release(rsv->rc, &rsv->mas);
 
 288                 uwb_rsv_put_stream(rsv);
 
 289                 uwb_rsv_state_update(rsv, UWB_RSV_STATE_NONE);
 
 290                 uwb_rsv_callback(rsv);
 
 292         case UWB_RSV_STATE_O_INITIATED:
 
 293                 uwb_rsv_state_update(rsv, UWB_RSV_STATE_O_INITIATED);
 
 295         case UWB_RSV_STATE_O_PENDING:
 
 296                 uwb_rsv_state_update(rsv, UWB_RSV_STATE_O_PENDING);
 
 298         case UWB_RSV_STATE_O_ESTABLISHED:
 
 299                 uwb_drp_avail_reserve(rsv->rc, &rsv->mas);
 
 300                 uwb_rsv_state_update(rsv, UWB_RSV_STATE_O_ESTABLISHED);
 
 301                 uwb_rsv_callback(rsv);
 
 303         case UWB_RSV_STATE_T_ACCEPTED:
 
 304                 uwb_drp_avail_reserve(rsv->rc, &rsv->mas);
 
 305                 uwb_rsv_state_update(rsv, UWB_RSV_STATE_T_ACCEPTED);
 
 306                 uwb_rsv_callback(rsv);
 
 308         case UWB_RSV_STATE_T_DENIED:
 
 309                 uwb_rsv_state_update(rsv, UWB_RSV_STATE_T_DENIED);
 
 312                 dev_err(&rsv->rc->uwb_dev.dev, "unhandled state: %s (%d)\n",
 
 313                         uwb_rsv_state_str(new_state), new_state);
 
 317 static struct uwb_rsv *uwb_rsv_alloc(struct uwb_rc *rc)
 
 321         rsv = kzalloc(sizeof(struct uwb_rsv), GFP_KERNEL);
 
 325         INIT_LIST_HEAD(&rsv->rc_node);
 
 326         INIT_LIST_HEAD(&rsv->pal_node);
 
 327         init_timer(&rsv->timer);
 
 328         rsv->timer.function = uwb_rsv_timer;
 
 329         rsv->timer.data     = (unsigned long)rsv;
 
 336 static void uwb_rsv_free(struct uwb_rsv *rsv)
 
 338         uwb_dev_put(rsv->owner);
 
 339         if (rsv->target.type == UWB_RSV_TARGET_DEV)
 
 340                 uwb_dev_put(rsv->target.dev);
 
 345  * uwb_rsv_create - allocate and initialize a UWB reservation structure
 
 346  * @rc: the radio controller
 
 347  * @cb: callback to use when the reservation completes or terminates
 
 348  * @pal_priv: data private to the PAL to be passed in the callback
 
 350  * The callback is called when the state of the reservation changes from:
 
 352  *   - pending to accepted
 
 353  *   - pending to denined
 
 354  *   - accepted to terminated
 
 355  *   - pending to terminated
 
 357 struct uwb_rsv *uwb_rsv_create(struct uwb_rc *rc, uwb_rsv_cb_f cb, void *pal_priv)
 
 361         rsv = uwb_rsv_alloc(rc);
 
 366         rsv->pal_priv = pal_priv;
 
 370 EXPORT_SYMBOL_GPL(uwb_rsv_create);
 
 372 void uwb_rsv_remove(struct uwb_rsv *rsv)
 
 374         if (rsv->state != UWB_RSV_STATE_NONE)
 
 375                 uwb_rsv_set_state(rsv, UWB_RSV_STATE_NONE);
 
 376         del_timer_sync(&rsv->timer);
 
 377         list_del(&rsv->rc_node);
 
 382  * uwb_rsv_destroy - free a UWB reservation structure
 
 383  * @rsv: the reservation to free
 
 385  * The reservation will be terminated if it is pending or established.
 
 387 void uwb_rsv_destroy(struct uwb_rsv *rsv)
 
 389         struct uwb_rc *rc = rsv->rc;
 
 391         mutex_lock(&rc->rsvs_mutex);
 
 393         mutex_unlock(&rc->rsvs_mutex);
 
 395 EXPORT_SYMBOL_GPL(uwb_rsv_destroy);
 
 398  * usb_rsv_establish - start a reservation establishment
 
 399  * @rsv: the reservation
 
 401  * The PAL should fill in @rsv's owner, target, type, max_mas,
 
 402  * min_mas, sparsity and is_multicast fields.  If the target is a
 
 403  * uwb_dev it must be referenced.
 
 405  * The reservation's callback will be called when the reservation is
 
 406  * accepted, denied or times out.
 
 408 int uwb_rsv_establish(struct uwb_rsv *rsv)
 
 410         struct uwb_rc *rc = rsv->rc;
 
 413         mutex_lock(&rc->rsvs_mutex);
 
 415         ret = uwb_rsv_get_stream(rsv);
 
 419         ret = uwb_rsv_alloc_mas(rsv);
 
 421                 uwb_rsv_put_stream(rsv);
 
 425         list_add_tail(&rsv->rc_node, &rc->reservations);
 
 426         rsv->owner = &rc->uwb_dev;
 
 427         uwb_dev_get(rsv->owner);
 
 428         uwb_rsv_set_state(rsv, UWB_RSV_STATE_O_INITIATED);
 
 430         mutex_unlock(&rc->rsvs_mutex);
 
 433 EXPORT_SYMBOL_GPL(uwb_rsv_establish);
 
 436  * uwb_rsv_modify - modify an already established reservation
 
 437  * @rsv: the reservation to modify
 
 438  * @max_mas: new maximum MAS to reserve
 
 439  * @min_mas: new minimum MAS to reserve
 
 440  * @sparsity: new sparsity to use
 
 442  * FIXME: implement this once there are PALs that use it.
 
 444 int uwb_rsv_modify(struct uwb_rsv *rsv, int max_mas, int min_mas, int sparsity)
 
 448 EXPORT_SYMBOL_GPL(uwb_rsv_modify);
 
 451  * uwb_rsv_terminate - terminate an established reservation
 
 452  * @rsv: the reservation to terminate
 
 454  * A reservation is terminated by removing the DRP IE from the beacon,
 
 455  * the other end will consider the reservation to be terminated when
 
 456  * it does not see the DRP IE for at least mMaxLostBeacons.
 
 458  * If applicable, the reference to the target uwb_dev will be released.
 
 460 void uwb_rsv_terminate(struct uwb_rsv *rsv)
 
 462         struct uwb_rc *rc = rsv->rc;
 
 464         mutex_lock(&rc->rsvs_mutex);
 
 466         uwb_rsv_set_state(rsv, UWB_RSV_STATE_NONE);
 
 468         mutex_unlock(&rc->rsvs_mutex);
 
 470 EXPORT_SYMBOL_GPL(uwb_rsv_terminate);
 
 473  * uwb_rsv_accept - accept a new reservation from a peer
 
 474  * @rsv:      the reservation
 
 475  * @cb:       call back for reservation changes
 
 476  * @pal_priv: data to be passed in the above call back
 
 478  * Reservation requests from peers are denied unless a PAL accepts it
 
 479  * by calling this function.
 
 481 void uwb_rsv_accept(struct uwb_rsv *rsv, uwb_rsv_cb_f cb, void *pal_priv)
 
 484         rsv->pal_priv = pal_priv;
 
 485         rsv->state    = UWB_RSV_STATE_T_ACCEPTED;
 
 487 EXPORT_SYMBOL_GPL(uwb_rsv_accept);
 
 490  * Is a received DRP IE for this reservation?
 
 492 static bool uwb_rsv_match(struct uwb_rsv *rsv, struct uwb_dev *src,
 
 493                           struct uwb_ie_drp *drp_ie)
 
 495         struct uwb_dev_addr *rsv_src;
 
 498         stream = uwb_ie_drp_stream_index(drp_ie);
 
 500         if (rsv->stream != stream)
 
 503         switch (rsv->target.type) {
 
 504         case UWB_RSV_TARGET_DEVADDR:
 
 505                 return rsv->stream == stream;
 
 506         case UWB_RSV_TARGET_DEV:
 
 507                 if (uwb_ie_drp_owner(drp_ie))
 
 508                         rsv_src = &rsv->owner->dev_addr;
 
 510                         rsv_src = &rsv->target.dev->dev_addr;
 
 511                 return uwb_dev_addr_cmp(&src->dev_addr, rsv_src) == 0;
 
 516 static struct uwb_rsv *uwb_rsv_new_target(struct uwb_rc *rc,
 
 518                                           struct uwb_ie_drp *drp_ie)
 
 522         enum uwb_rsv_state state;
 
 524         rsv = uwb_rsv_alloc(rc);
 
 530         uwb_dev_get(rsv->owner);
 
 531         rsv->target.type = UWB_RSV_TARGET_DEV;
 
 532         rsv->target.dev  = &rc->uwb_dev;
 
 533         rsv->type        = uwb_ie_drp_type(drp_ie);
 
 534         rsv->stream      = uwb_ie_drp_stream_index(drp_ie);
 
 535         set_bit(rsv->stream, rsv->owner->streams);
 
 536         uwb_drp_ie_to_bm(&rsv->mas, drp_ie);
 
 539          * See if any PALs are interested in this reservation. If not,
 
 542         rsv->state = UWB_RSV_STATE_T_DENIED;
 
 543         spin_lock(&rc->pal_lock);
 
 544         list_for_each_entry(pal, &rc->pals, node) {
 
 547                 if (rsv->state == UWB_RSV_STATE_T_ACCEPTED)
 
 550         spin_unlock(&rc->pal_lock);
 
 552         list_add_tail(&rsv->rc_node, &rc->reservations);
 
 554         rsv->state = UWB_RSV_STATE_NONE;
 
 555         uwb_rsv_set_state(rsv, state);
 
 561  * uwb_rsv_find - find a reservation for a received DRP IE.
 
 562  * @rc: the radio controller
 
 563  * @src: source of the DRP IE
 
 564  * @drp_ie: the DRP IE
 
 566  * If the reservation cannot be found and the DRP IE is from a peer
 
 567  * attempting to establish a new reservation, create a new reservation
 
 568  * and add it to the list.
 
 570 struct uwb_rsv *uwb_rsv_find(struct uwb_rc *rc, struct uwb_dev *src,
 
 571                              struct uwb_ie_drp *drp_ie)
 
 575         list_for_each_entry(rsv, &rc->reservations, rc_node) {
 
 576                 if (uwb_rsv_match(rsv, src, drp_ie))
 
 580         if (uwb_ie_drp_owner(drp_ie))
 
 581                 return uwb_rsv_new_target(rc, src, drp_ie);
 
 587  * Go through all the reservations and check for timeouts and (if
 
 588  * necessary) update their DRP IEs.
 
 590  * FIXME: look at building the SET_DRP_IE command here rather than
 
 591  * having to rescan the list in uwb_rc_send_all_drp_ie().
 
 593 static bool uwb_rsv_update_all(struct uwb_rc *rc)
 
 595         struct uwb_rsv *rsv, *t;
 
 596         bool ie_updated = false;
 
 598         list_for_each_entry_safe(rsv, t, &rc->reservations, rc_node) {
 
 600                         uwb_drp_handle_timeout(rsv);
 
 601                 if (!rsv->ie_valid) {
 
 602                         uwb_drp_ie_update(rsv);
 
 610 void uwb_rsv_sched_update(struct uwb_rc *rc)
 
 612         queue_work(rc->rsv_workq, &rc->rsv_update_work);
 
 616  * Update DRP IEs and, if necessary, the DRP Availability IE and send
 
 617  * the updated IEs to the radio controller.
 
 619 static void uwb_rsv_update_work(struct work_struct *work)
 
 621         struct uwb_rc *rc = container_of(work, struct uwb_rc, rsv_update_work);
 
 624         mutex_lock(&rc->rsvs_mutex);
 
 626         ie_updated = uwb_rsv_update_all(rc);
 
 628         if (!rc->drp_avail.ie_valid) {
 
 629                 uwb_drp_avail_ie_update(rc);
 
 634                 uwb_rc_send_all_drp_ie(rc);
 
 636         mutex_unlock(&rc->rsvs_mutex);
 
 639 static void uwb_rsv_timer(unsigned long arg)
 
 641         struct uwb_rsv *rsv = (struct uwb_rsv *)arg;
 
 644         uwb_rsv_sched_update(rsv->rc);
 
 647 void uwb_rsv_init(struct uwb_rc *rc)
 
 649         INIT_LIST_HEAD(&rc->reservations);
 
 650         mutex_init(&rc->rsvs_mutex);
 
 651         INIT_WORK(&rc->rsv_update_work, uwb_rsv_update_work);
 
 653         bitmap_complement(rc->uwb_dev.streams, rc->uwb_dev.streams, UWB_NUM_STREAMS);
 
 656 int uwb_rsv_setup(struct uwb_rc *rc)
 
 660         snprintf(name, sizeof(name), "%s_rsvd", dev_name(&rc->uwb_dev.dev));
 
 661         rc->rsv_workq = create_singlethread_workqueue(name);
 
 662         if (rc->rsv_workq == NULL)
 
 668 void uwb_rsv_cleanup(struct uwb_rc *rc)
 
 670         struct uwb_rsv *rsv, *t;
 
 672         mutex_lock(&rc->rsvs_mutex);
 
 673         list_for_each_entry_safe(rsv, t, &rc->reservations, rc_node) {
 
 676         mutex_unlock(&rc->rsvs_mutex);
 
 678         cancel_work_sync(&rc->rsv_update_work);
 
 679         destroy_workqueue(rc->rsv_workq);