irqueue.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912
  1. /*********************************************************************
  2. *
  3. * Filename: irqueue.c
  4. * Version: 0.3
  5. * Description: General queue implementation
  6. * Status: Experimental.
  7. * Author: Dag Brattli <dagb@cs.uit.no>
  8. * Created at: Tue Jun 9 13:29:31 1998
  9. * Modified at: Sun Dec 12 13:48:22 1999
  10. * Modified by: Dag Brattli <dagb@cs.uit.no>
  11. * Modified at: Thu Jan 4 14:29:10 CET 2001
  12. * Modified by: Marc Zyngier <mzyngier@freesurf.fr>
  13. *
  14. * Copyright (C) 1998-1999, Aage Kvalnes <aage@cs.uit.no>
  15. * Copyright (C) 1998, Dag Brattli,
  16. * All Rights Reserved.
  17. *
  18. * This code is taken from the Vortex Operating System written by Aage
  19. * Kvalnes. Aage has agreed that this code can use the GPL licence,
  20. * although he does not use that licence in his own code.
  21. *
  22. * This copyright does however _not_ include the ELF hash() function
  23. * which I currently don't know which licence or copyright it
  24. * has. Please inform me if you know.
  25. *
  26. * This program is free software; you can redistribute it and/or
  27. * modify it under the terms of the GNU General Public License as
  28. * published by the Free Software Foundation; either version 2 of
  29. * the License, or (at your option) any later version.
  30. *
  31. * Neither Dag Brattli nor University of Tromsø admit liability nor
  32. * provide warranty for any of this software. This material is
  33. * provided "AS-IS" and at no charge.
  34. *
  35. ********************************************************************/
  36. /*
  37. * NOTE :
  38. * There are various problems with this package :
  39. * o the hash function for ints is pathetic (but could be changed)
  40. * o locking is sometime suspicious (especially during enumeration)
  41. * o most users have only a few elements (== overhead)
  42. * o most users never use search, so don't benefit from hashing
  43. * Problem already fixed :
  44. * o not 64 bit compliant (most users do hashv = (int) self)
  45. * o hashbin_remove() is broken => use hashbin_remove_this()
  46. * I think most users would be better served by a simple linked list
  47. * (like include/linux/list.h) with a global spinlock per list.
  48. * Jean II
  49. */
  50. /*
  51. * Notes on the concurrent access to hashbin and other SMP issues
  52. * -------------------------------------------------------------
  53. * Hashbins are very often in the IrDA stack a global repository of
  54. * information, and therefore used in a very asynchronous manner following
  55. * various events (driver calls, timers, user calls...).
  56. * Therefore, very often it is highly important to consider the
  57. * management of concurrent access to the hashbin and how to guarantee the
  58. * consistency of the operations on it.
  59. *
  60. * First, we need to define the objective of locking :
  61. * 1) Protect user data (content pointed by the hashbin)
  62. * 2) Protect hashbin structure itself (linked list in each bin)
  63. *
  64. * OLD LOCKING
  65. * -----------
  66. *
  67. * The previous locking strategy, either HB_LOCAL or HB_GLOBAL were
  68. * both inadequate in *both* aspect.
  69. * o HB_GLOBAL was using a spinlock for each bin (local locking).
  70. * o HB_LOCAL was disabling irq on *all* CPUs, so use a single
  71. * global semaphore.
  72. * The problems were :
  73. * A) Global irq disabling is no longer supported by the kernel
  74. * B) No protection for the hashbin struct global data
  75. * o hashbin_delete()
  76. * o hb_current
  77. * C) No protection for user data in some cases
  78. *
  79. * A) HB_LOCAL use global irq disabling, so doesn't work on kernel
  80. * 2.5.X. Even when it is supported (kernel 2.4.X and earlier), its
  81. * performance is not satisfactory on SMP setups. Most hashbins were
  82. * HB_LOCAL, so (A) definitely need fixing.
  83. * B) HB_LOCAL could be modified to fix (B). However, because HB_GLOBAL
  84. * lock only the individual bins, it will never be able to lock the
  85. * global data, so can't do (B).
  86. * C) Some functions return pointer to data that is still in the
  87. * hashbin :
  88. * o hashbin_find()
  89. * o hashbin_get_first()
  90. * o hashbin_get_next()
  91. * As the data is still in the hashbin, it may be changed or free'd
  92. * while the caller is examinimg the data. In those case, locking can't
  93. * be done within the hashbin, but must include use of the data within
  94. * the caller.
  95. * The caller can easily do this with HB_LOCAL (just disable irqs).
  96. * However, this is impossible with HB_GLOBAL because the caller has no
  97. * way to know the proper bin, so don't know which spinlock to use.
  98. *
  99. * Quick summary : can no longer use HB_LOCAL, and HB_GLOBAL is
  100. * fundamentally broken and will never work.
  101. *
  102. * NEW LOCKING
  103. * -----------
  104. *
  105. * To fix those problems, I've introduce a few changes in the
  106. * hashbin locking :
  107. * 1) New HB_LOCK scheme
  108. * 2) hashbin->hb_spinlock
  109. * 3) New hashbin usage policy
  110. *
  111. * HB_LOCK :
  112. * -------
  113. * HB_LOCK is a locking scheme intermediate between the old HB_LOCAL
  114. * and HB_GLOBAL. It uses a single spinlock to protect the whole content
  115. * of the hashbin. As it is a single spinlock, it can protect the global
  116. * data of the hashbin and not only the bins themselves.
  117. * HB_LOCK can only protect some of the hashbin calls, so it only lock
  118. * call that can be made 100% safe and leave other call unprotected.
  119. * HB_LOCK in theory is slower than HB_GLOBAL, but as the hashbin
  120. * content is always small contention is not high, so it doesn't matter
  121. * much. HB_LOCK is probably faster than HB_LOCAL.
  122. *
  123. * hashbin->hb_spinlock :
  124. * --------------------
  125. * The spinlock that HB_LOCK uses is available for caller, so that
  126. * the caller can protect unprotected calls (see below).
  127. * If the caller want to do entirely its own locking (HB_NOLOCK), he
  128. * can do so and may use safely this spinlock.
  129. * Locking is done like this :
  130. * spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  131. * Releasing the lock :
  132. * spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  133. *
  134. * Safe & Protected calls :
  135. * ----------------------
  136. * The following calls are safe or protected via HB_LOCK :
  137. * o hashbin_new() -> safe
  138. * o hashbin_delete()
  139. * o hashbin_insert()
  140. * o hashbin_remove_first()
  141. * o hashbin_remove()
  142. * o hashbin_remove_this()
  143. * o HASHBIN_GET_SIZE() -> atomic
  144. *
  145. * The following calls only protect the hashbin itself :
  146. * o hashbin_lock_find()
  147. * o hashbin_find_next()
  148. *
  149. * Unprotected calls :
  150. * -----------------
  151. * The following calls need to be protected by the caller :
  152. * o hashbin_find()
  153. * o hashbin_get_first()
  154. * o hashbin_get_next()
  155. *
  156. * Locking Policy :
  157. * --------------
  158. * If the hashbin is used only in a single thread of execution
  159. * (explicitly or implicitely), you can use HB_NOLOCK
  160. * If the calling module already provide concurrent access protection,
  161. * you may use HB_NOLOCK.
  162. *
  163. * In all other cases, you need to use HB_LOCK and lock the hashbin
  164. * every time before calling one of the unprotected calls. You also must
  165. * use the pointer returned by the unprotected call within the locked
  166. * region.
  167. *
  168. * Extra care for enumeration :
  169. * --------------------------
  170. * hashbin_get_first() and hashbin_get_next() use the hashbin to
  171. * store the current position, in hb_current.
  172. * As long as the hashbin remains locked, this is safe. If you unlock
  173. * the hashbin, the current position may change if anybody else modify
  174. * or enumerate the hashbin.
  175. * Summary : do the full enumeration while locked.
  176. *
  177. * Alternatively, you may use hashbin_find_next(). But, this will
  178. * be slower, is more complex to use and doesn't protect the hashbin
  179. * content. So, care is needed here as well.
  180. *
  181. * Other issues :
  182. * ------------
  183. * I believe that we are overdoing it by using spin_lock_irqsave()
  184. * and we should use only spin_lock_bh() or similar. But, I don't have
  185. * the balls to try it out.
  186. * Don't believe that because hashbin are now (somewhat) SMP safe
  187. * that the rest of the code is. Higher layers tend to be safest,
  188. * but LAP and LMP would need some serious dedicated love.
  189. *
  190. * Jean II
  191. */
  192. #include <linux/module.h>
  193. #include <linux/slab.h>
  194. #include <net/irda/irda.h>
  195. #include <net/irda/irqueue.h>
  196. /************************ QUEUE SUBROUTINES ************************/
  197. /*
  198. * Hashbin
  199. */
  200. #define GET_HASHBIN(x) ( x & HASHBIN_MASK )
  201. /*
  202. * Function hash (name)
  203. *
  204. * This function hash the input string 'name' using the ELF hash
  205. * function for strings.
  206. */
  207. static __u32 hash( const char* name)
  208. {
  209. __u32 h = 0;
  210. __u32 g;
  211. while(*name) {
  212. h = (h<<4) + *name++;
  213. if ((g = (h & 0xf0000000)))
  214. h ^=g>>24;
  215. h &=~g;
  216. }
  217. return h;
  218. }
  219. /*
  220. * Function enqueue_first (queue, proc)
  221. *
  222. * Insert item first in queue.
  223. *
  224. */
  225. static void enqueue_first(irda_queue_t **queue, irda_queue_t* element)
  226. {
  227. /*
  228. * Check if queue is empty.
  229. */
  230. if ( *queue == NULL ) {
  231. /*
  232. * Queue is empty. Insert one element into the queue.
  233. */
  234. element->q_next = element->q_prev = *queue = element;
  235. } else {
  236. /*
  237. * Queue is not empty. Insert element into front of queue.
  238. */
  239. element->q_next = (*queue);
  240. (*queue)->q_prev->q_next = element;
  241. element->q_prev = (*queue)->q_prev;
  242. (*queue)->q_prev = element;
  243. (*queue) = element;
  244. }
  245. }
  246. /*
  247. * Function dequeue (queue)
  248. *
  249. * Remove first entry in queue
  250. *
  251. */
  252. static irda_queue_t *dequeue_first(irda_queue_t **queue)
  253. {
  254. irda_queue_t *ret;
  255. pr_debug("dequeue_first()\n");
  256. /*
  257. * Set return value
  258. */
  259. ret = *queue;
  260. if ( *queue == NULL ) {
  261. /*
  262. * Queue was empty.
  263. */
  264. } else if ( (*queue)->q_next == *queue ) {
  265. /*
  266. * Queue only contained a single element. It will now be
  267. * empty.
  268. */
  269. *queue = NULL;
  270. } else {
  271. /*
  272. * Queue contained several element. Remove the first one.
  273. */
  274. (*queue)->q_prev->q_next = (*queue)->q_next;
  275. (*queue)->q_next->q_prev = (*queue)->q_prev;
  276. *queue = (*queue)->q_next;
  277. }
  278. /*
  279. * Return the removed entry (or NULL of queue was empty).
  280. */
  281. return ret;
  282. }
  283. /*
  284. * Function dequeue_general (queue, element)
  285. *
  286. *
  287. */
  288. static irda_queue_t *dequeue_general(irda_queue_t **queue, irda_queue_t* element)
  289. {
  290. irda_queue_t *ret;
  291. pr_debug("dequeue_general()\n");
  292. /*
  293. * Set return value
  294. */
  295. ret = *queue;
  296. if ( *queue == NULL ) {
  297. /*
  298. * Queue was empty.
  299. */
  300. } else if ( (*queue)->q_next == *queue ) {
  301. /*
  302. * Queue only contained a single element. It will now be
  303. * empty.
  304. */
  305. *queue = NULL;
  306. } else {
  307. /*
  308. * Remove specific element.
  309. */
  310. element->q_prev->q_next = element->q_next;
  311. element->q_next->q_prev = element->q_prev;
  312. if ( (*queue) == element)
  313. (*queue) = element->q_next;
  314. }
  315. /*
  316. * Return the removed entry (or NULL of queue was empty).
  317. */
  318. return ret;
  319. }
  320. /************************ HASHBIN MANAGEMENT ************************/
  321. /*
  322. * Function hashbin_create ( type, name )
  323. *
  324. * Create hashbin!
  325. *
  326. */
  327. hashbin_t *hashbin_new(int type)
  328. {
  329. hashbin_t* hashbin;
  330. /*
  331. * Allocate new hashbin
  332. */
  333. hashbin = kzalloc(sizeof(*hashbin), GFP_ATOMIC);
  334. if (!hashbin)
  335. return NULL;
  336. /*
  337. * Initialize structure
  338. */
  339. hashbin->hb_type = type;
  340. hashbin->magic = HB_MAGIC;
  341. //hashbin->hb_current = NULL;
  342. /* Make sure all spinlock's are unlocked */
  343. if ( hashbin->hb_type & HB_LOCK ) {
  344. spin_lock_init(&hashbin->hb_spinlock);
  345. }
  346. return hashbin;
  347. }
  348. EXPORT_SYMBOL(hashbin_new);
  349. /*
  350. * Function hashbin_delete (hashbin, free_func)
  351. *
  352. * Destroy hashbin, the free_func can be a user supplied special routine
  353. * for deallocating this structure if it's complex. If not the user can
  354. * just supply kfree, which should take care of the job.
  355. */
  356. int hashbin_delete( hashbin_t* hashbin, FREE_FUNC free_func)
  357. {
  358. irda_queue_t* queue;
  359. unsigned long flags = 0;
  360. int i;
  361. IRDA_ASSERT(hashbin != NULL, return -1;);
  362. IRDA_ASSERT(hashbin->magic == HB_MAGIC, return -1;);
  363. /* Synchronize */
  364. if (hashbin->hb_type & HB_LOCK)
  365. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  366. /*
  367. * Free the entries in the hashbin, TODO: use hashbin_clear when
  368. * it has been shown to work
  369. */
  370. for (i = 0; i < HASHBIN_SIZE; i ++ ) {
  371. while (1) {
  372. queue = dequeue_first((irda_queue_t**) &hashbin->hb_queue[i]);
  373. if (!queue)
  374. break;
  375. if (free_func) {
  376. if (hashbin->hb_type & HB_LOCK)
  377. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  378. free_func(queue);
  379. if (hashbin->hb_type & HB_LOCK)
  380. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  381. }
  382. }
  383. }
  384. /* Cleanup local data */
  385. hashbin->hb_current = NULL;
  386. hashbin->magic = ~HB_MAGIC;
  387. /* Release lock */
  388. if (hashbin->hb_type & HB_LOCK)
  389. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  390. /*
  391. * Free the hashbin structure
  392. */
  393. kfree(hashbin);
  394. return 0;
  395. }
  396. EXPORT_SYMBOL(hashbin_delete);
  397. /********************* HASHBIN LIST OPERATIONS *********************/
  398. /*
  399. * Function hashbin_insert (hashbin, entry, name)
  400. *
  401. * Insert an entry into the hashbin
  402. *
  403. */
  404. void hashbin_insert(hashbin_t* hashbin, irda_queue_t* entry, long hashv,
  405. const char* name)
  406. {
  407. unsigned long flags = 0;
  408. int bin;
  409. IRDA_ASSERT( hashbin != NULL, return;);
  410. IRDA_ASSERT( hashbin->magic == HB_MAGIC, return;);
  411. /*
  412. * Locate hashbin
  413. */
  414. if ( name )
  415. hashv = hash( name );
  416. bin = GET_HASHBIN( hashv );
  417. /* Synchronize */
  418. if ( hashbin->hb_type & HB_LOCK ) {
  419. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  420. } /* Default is no-lock */
  421. /*
  422. * Store name and key
  423. */
  424. entry->q_hash = hashv;
  425. if ( name )
  426. strlcpy( entry->q_name, name, sizeof(entry->q_name));
  427. /*
  428. * Insert new entry first
  429. */
  430. enqueue_first( (irda_queue_t**) &hashbin->hb_queue[ bin ],
  431. entry);
  432. hashbin->hb_size++;
  433. /* Release lock */
  434. if ( hashbin->hb_type & HB_LOCK ) {
  435. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  436. } /* Default is no-lock */
  437. }
  438. EXPORT_SYMBOL(hashbin_insert);
  439. /*
  440. * Function hashbin_remove_first (hashbin)
  441. *
  442. * Remove first entry of the hashbin
  443. *
  444. * Note : this function no longer use hashbin_remove(), but does things
  445. * similar to hashbin_remove_this(), so can be considered safe.
  446. * Jean II
  447. */
  448. void *hashbin_remove_first( hashbin_t *hashbin)
  449. {
  450. unsigned long flags = 0;
  451. irda_queue_t *entry = NULL;
  452. /* Synchronize */
  453. if ( hashbin->hb_type & HB_LOCK ) {
  454. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  455. } /* Default is no-lock */
  456. entry = hashbin_get_first( hashbin);
  457. if ( entry != NULL) {
  458. int bin;
  459. long hashv;
  460. /*
  461. * Locate hashbin
  462. */
  463. hashv = entry->q_hash;
  464. bin = GET_HASHBIN( hashv );
  465. /*
  466. * Dequeue the entry...
  467. */
  468. dequeue_general( (irda_queue_t**) &hashbin->hb_queue[ bin ],
  469. entry);
  470. hashbin->hb_size--;
  471. entry->q_next = NULL;
  472. entry->q_prev = NULL;
  473. /*
  474. * Check if this item is the currently selected item, and in
  475. * that case we must reset hb_current
  476. */
  477. if ( entry == hashbin->hb_current)
  478. hashbin->hb_current = NULL;
  479. }
  480. /* Release lock */
  481. if ( hashbin->hb_type & HB_LOCK ) {
  482. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  483. } /* Default is no-lock */
  484. return entry;
  485. }
  486. /*
  487. * Function hashbin_remove (hashbin, hashv, name)
  488. *
  489. * Remove entry with the given name
  490. *
  491. * The use of this function is highly discouraged, because the whole
  492. * concept behind hashbin_remove() is broken. In many cases, it's not
  493. * possible to guarantee the unicity of the index (either hashv or name),
  494. * leading to removing the WRONG entry.
  495. * The only simple safe use is :
  496. * hashbin_remove(hasbin, (int) self, NULL);
  497. * In other case, you must think hard to guarantee unicity of the index.
  498. * Jean II
  499. */
  500. void* hashbin_remove( hashbin_t* hashbin, long hashv, const char* name)
  501. {
  502. int bin, found = FALSE;
  503. unsigned long flags = 0;
  504. irda_queue_t* entry;
  505. IRDA_ASSERT( hashbin != NULL, return NULL;);
  506. IRDA_ASSERT( hashbin->magic == HB_MAGIC, return NULL;);
  507. /*
  508. * Locate hashbin
  509. */
  510. if ( name )
  511. hashv = hash( name );
  512. bin = GET_HASHBIN( hashv );
  513. /* Synchronize */
  514. if ( hashbin->hb_type & HB_LOCK ) {
  515. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  516. } /* Default is no-lock */
  517. /*
  518. * Search for entry
  519. */
  520. entry = hashbin->hb_queue[ bin ];
  521. if ( entry ) {
  522. do {
  523. /*
  524. * Check for key
  525. */
  526. if ( entry->q_hash == hashv ) {
  527. /*
  528. * Name compare too?
  529. */
  530. if ( name ) {
  531. if ( strcmp( entry->q_name, name) == 0)
  532. {
  533. found = TRUE;
  534. break;
  535. }
  536. } else {
  537. found = TRUE;
  538. break;
  539. }
  540. }
  541. entry = entry->q_next;
  542. } while ( entry != hashbin->hb_queue[ bin ] );
  543. }
  544. /*
  545. * If entry was found, dequeue it
  546. */
  547. if ( found ) {
  548. dequeue_general( (irda_queue_t**) &hashbin->hb_queue[ bin ],
  549. entry);
  550. hashbin->hb_size--;
  551. /*
  552. * Check if this item is the currently selected item, and in
  553. * that case we must reset hb_current
  554. */
  555. if ( entry == hashbin->hb_current)
  556. hashbin->hb_current = NULL;
  557. }
  558. /* Release lock */
  559. if ( hashbin->hb_type & HB_LOCK ) {
  560. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  561. } /* Default is no-lock */
  562. /* Return */
  563. if ( found )
  564. return entry;
  565. else
  566. return NULL;
  567. }
  568. EXPORT_SYMBOL(hashbin_remove);
  569. /*
  570. * Function hashbin_remove_this (hashbin, entry)
  571. *
  572. * Remove entry with the given name
  573. *
  574. * In some cases, the user of hashbin can't guarantee the unicity
  575. * of either the hashv or name.
  576. * In those cases, using the above function is guaranteed to cause troubles,
  577. * so we use this one instead...
  578. * And by the way, it's also faster, because we skip the search phase ;-)
  579. */
  580. void* hashbin_remove_this( hashbin_t* hashbin, irda_queue_t* entry)
  581. {
  582. unsigned long flags = 0;
  583. int bin;
  584. long hashv;
  585. IRDA_ASSERT( hashbin != NULL, return NULL;);
  586. IRDA_ASSERT( hashbin->magic == HB_MAGIC, return NULL;);
  587. IRDA_ASSERT( entry != NULL, return NULL;);
  588. /* Synchronize */
  589. if ( hashbin->hb_type & HB_LOCK ) {
  590. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  591. } /* Default is no-lock */
  592. /* Check if valid and not already removed... */
  593. if((entry->q_next == NULL) || (entry->q_prev == NULL)) {
  594. entry = NULL;
  595. goto out;
  596. }
  597. /*
  598. * Locate hashbin
  599. */
  600. hashv = entry->q_hash;
  601. bin = GET_HASHBIN( hashv );
  602. /*
  603. * Dequeue the entry...
  604. */
  605. dequeue_general( (irda_queue_t**) &hashbin->hb_queue[ bin ],
  606. entry);
  607. hashbin->hb_size--;
  608. entry->q_next = NULL;
  609. entry->q_prev = NULL;
  610. /*
  611. * Check if this item is the currently selected item, and in
  612. * that case we must reset hb_current
  613. */
  614. if ( entry == hashbin->hb_current)
  615. hashbin->hb_current = NULL;
  616. out:
  617. /* Release lock */
  618. if ( hashbin->hb_type & HB_LOCK ) {
  619. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  620. } /* Default is no-lock */
  621. return entry;
  622. }
  623. EXPORT_SYMBOL(hashbin_remove_this);
  624. /*********************** HASHBIN ENUMERATION ***********************/
  625. /*
  626. * Function hashbin_common_find (hashbin, hashv, name)
  627. *
  628. * Find item with the given hashv or name
  629. *
  630. */
  631. void* hashbin_find( hashbin_t* hashbin, long hashv, const char* name )
  632. {
  633. int bin;
  634. irda_queue_t* entry;
  635. pr_debug("hashbin_find()\n");
  636. IRDA_ASSERT( hashbin != NULL, return NULL;);
  637. IRDA_ASSERT( hashbin->magic == HB_MAGIC, return NULL;);
  638. /*
  639. * Locate hashbin
  640. */
  641. if ( name )
  642. hashv = hash( name );
  643. bin = GET_HASHBIN( hashv );
  644. /*
  645. * Search for entry
  646. */
  647. entry = hashbin->hb_queue[ bin];
  648. if ( entry ) {
  649. do {
  650. /*
  651. * Check for key
  652. */
  653. if ( entry->q_hash == hashv ) {
  654. /*
  655. * Name compare too?
  656. */
  657. if ( name ) {
  658. if ( strcmp( entry->q_name, name ) == 0 ) {
  659. return entry;
  660. }
  661. } else {
  662. return entry;
  663. }
  664. }
  665. entry = entry->q_next;
  666. } while ( entry != hashbin->hb_queue[ bin ] );
  667. }
  668. return NULL;
  669. }
  670. EXPORT_SYMBOL(hashbin_find);
  671. /*
  672. * Function hashbin_lock_find (hashbin, hashv, name)
  673. *
  674. * Find item with the given hashv or name
  675. *
  676. * Same, but with spinlock protection...
  677. * I call it safe, but it's only safe with respect to the hashbin, not its
  678. * content. - Jean II
  679. */
  680. void* hashbin_lock_find( hashbin_t* hashbin, long hashv, const char* name )
  681. {
  682. unsigned long flags = 0;
  683. irda_queue_t* entry;
  684. /* Synchronize */
  685. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  686. /*
  687. * Search for entry
  688. */
  689. entry = hashbin_find(hashbin, hashv, name);
  690. /* Release lock */
  691. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  692. return entry;
  693. }
  694. EXPORT_SYMBOL(hashbin_lock_find);
  695. /*
  696. * Function hashbin_find (hashbin, hashv, name, pnext)
  697. *
  698. * Find an item with the given hashv or name, and its successor
  699. *
  700. * This function allow to do concurrent enumerations without the
  701. * need to lock over the whole session, because the caller keep the
  702. * context of the search. On the other hand, it might fail and return
  703. * NULL if the entry is removed. - Jean II
  704. */
  705. void* hashbin_find_next( hashbin_t* hashbin, long hashv, const char* name,
  706. void ** pnext)
  707. {
  708. unsigned long flags = 0;
  709. irda_queue_t* entry;
  710. /* Synchronize */
  711. spin_lock_irqsave(&hashbin->hb_spinlock, flags);
  712. /*
  713. * Search for current entry
  714. * This allow to check if the current item is still in the
  715. * hashbin or has been removed.
  716. */
  717. entry = hashbin_find(hashbin, hashv, name);
  718. /*
  719. * Trick hashbin_get_next() to return what we want
  720. */
  721. if(entry) {
  722. hashbin->hb_current = entry;
  723. *pnext = hashbin_get_next( hashbin );
  724. } else
  725. *pnext = NULL;
  726. /* Release lock */
  727. spin_unlock_irqrestore(&hashbin->hb_spinlock, flags);
  728. return entry;
  729. }
  730. /*
  731. * Function hashbin_get_first (hashbin)
  732. *
  733. * Get a pointer to first element in hashbin, this function must be
  734. * called before any calls to hashbin_get_next()!
  735. *
  736. */
  737. irda_queue_t *hashbin_get_first( hashbin_t* hashbin)
  738. {
  739. irda_queue_t *entry;
  740. int i;
  741. IRDA_ASSERT( hashbin != NULL, return NULL;);
  742. IRDA_ASSERT( hashbin->magic == HB_MAGIC, return NULL;);
  743. if ( hashbin == NULL)
  744. return NULL;
  745. for ( i = 0; i < HASHBIN_SIZE; i ++ ) {
  746. entry = hashbin->hb_queue[ i];
  747. if ( entry) {
  748. hashbin->hb_current = entry;
  749. return entry;
  750. }
  751. }
  752. /*
  753. * Did not find any item in hashbin
  754. */
  755. return NULL;
  756. }
  757. EXPORT_SYMBOL(hashbin_get_first);
  758. /*
  759. * Function hashbin_get_next (hashbin)
  760. *
  761. * Get next item in hashbin. A series of hashbin_get_next() calls must
  762. * be started by a call to hashbin_get_first(). The function returns
  763. * NULL when all items have been traversed
  764. *
  765. * The context of the search is stored within the hashbin, so you must
  766. * protect yourself from concurrent enumerations. - Jean II
  767. */
  768. irda_queue_t *hashbin_get_next( hashbin_t *hashbin)
  769. {
  770. irda_queue_t* entry;
  771. int bin;
  772. int i;
  773. IRDA_ASSERT( hashbin != NULL, return NULL;);
  774. IRDA_ASSERT( hashbin->magic == HB_MAGIC, return NULL;);
  775. if ( hashbin->hb_current == NULL) {
  776. IRDA_ASSERT( hashbin->hb_current != NULL, return NULL;);
  777. return NULL;
  778. }
  779. entry = hashbin->hb_current->q_next;
  780. bin = GET_HASHBIN( entry->q_hash);
  781. /*
  782. * Make sure that we are not back at the beginning of the queue
  783. * again
  784. */
  785. if ( entry != hashbin->hb_queue[ bin ]) {
  786. hashbin->hb_current = entry;
  787. return entry;
  788. }
  789. /*
  790. * Check that this is not the last queue in hashbin
  791. */
  792. if ( bin >= HASHBIN_SIZE)
  793. return NULL;
  794. /*
  795. * Move to next queue in hashbin
  796. */
  797. bin++;
  798. for ( i = bin; i < HASHBIN_SIZE; i++ ) {
  799. entry = hashbin->hb_queue[ i];
  800. if ( entry) {
  801. hashbin->hb_current = entry;
  802. return entry;
  803. }
  804. }
  805. return NULL;
  806. }
  807. EXPORT_SYMBOL(hashbin_get_next);