2 #include <linux/sort.h>
7 * Author: Beceem Communications Pvt. Ltd
9 * Abstract: This file contains the routines sorting the classification rules.
11 * Copyright (c) 2007 Beceem Communications Pvt. Ltd
14 static int compare_packet_info(void const *a, void const *b)
16 PacketInfo const *pa = a;
17 PacketInfo const *pb = b;
19 if (!pa->bValid || !pb->bValid)
22 return pa->u8TrafficPriority - pb->u8TrafficPriority;
25 VOID SortPackInfo(PMINI_ADAPTER Adapter)
27 BCM_DEBUG_PRINT(Adapter, DBG_TYPE_OTHERS, CONN_MSG,
28 DBG_LVL_ALL, "<=======");
30 sort(Adapter->PackInfo, NO_OF_QUEUES, sizeof(PacketInfo),
31 compare_packet_info, NULL);
34 static int compare_classifiers(void const *a, void const *b)
36 S_CLASSIFIER_RULE const *pa = a;
37 S_CLASSIFIER_RULE const *pb = b;
39 if (!pa->bUsed || !pb->bUsed)
42 return pa->u8ClassifierRulePriority - pb->u8ClassifierRulePriority;
45 VOID SortClassifiers(PMINI_ADAPTER Adapter)
47 BCM_DEBUG_PRINT(Adapter, DBG_TYPE_OTHERS, CONN_MSG,
48 DBG_LVL_ALL, "<=======");
50 sort(Adapter->astClassifierTable, MAX_CLASSIFIERS,
51 sizeof(S_CLASSIFIER_RULE), compare_classifiers, NULL);