diff options
author | Jiri Pirko <jiri@mellanox.com> | 2016-02-16 09:14:42 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-02-17 23:08:34 -0500 |
commit | de1521923c0f2ee9c6328ad6b3e46e662d88a3cd (patch) | |
tree | 3bf69945190b05314a31717ad45c8cf39fd1d683 /drivers/net/ethernet/rocker | |
parent | 11ce2ba3d05b3ac330022da1f83b589a4f78569c (diff) |
rocker: push tlv processing into separate files
Carve out TLV processing helpers into separate files.
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Acked-by: Scott Feldman <sfeldma@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/rocker')
-rw-r--r-- | drivers/net/ethernet/rocker/Makefile | 2 | ||||
-rw-r--r-- | drivers/net/ethernet/rocker/rocker.h | 27 | ||||
-rw-r--r-- | drivers/net/ethernet/rocker/rocker_main.c | 222 | ||||
-rw-r--r-- | drivers/net/ethernet/rocker/rocker_tlv.c | 53 | ||||
-rw-r--r-- | drivers/net/ethernet/rocker/rocker_tlv.h | 201 |
5 files changed, 284 insertions, 221 deletions
diff --git a/drivers/net/ethernet/rocker/Makefile b/drivers/net/ethernet/rocker/Makefile index 2bed42385076..47f34928f809 100644 --- a/drivers/net/ethernet/rocker/Makefile +++ b/drivers/net/ethernet/rocker/Makefile | |||
@@ -3,4 +3,4 @@ | |||
3 | # | 3 | # |
4 | 4 | ||
5 | obj-$(CONFIG_ROCKER) += rocker.o | 5 | obj-$(CONFIG_ROCKER) += rocker.o |
6 | rocker-y := rocker_main.o | 6 | rocker-y := rocker_main.o rocker_tlv.o |
diff --git a/drivers/net/ethernet/rocker/rocker.h b/drivers/net/ethernet/rocker/rocker.h new file mode 100644 index 000000000000..23b5e3dfea45 --- /dev/null +++ b/drivers/net/ethernet/rocker/rocker.h | |||
@@ -0,0 +1,27 @@ | |||
1 | /* | ||
2 | * drivers/net/ethernet/rocker/rocker.h - Rocker switch device driver | ||
3 | * Copyright (c) 2014-2016 Jiri Pirko <jiri@mellanox.com> | ||
4 | * Copyright (c) 2014 Scott Feldman <sfeldma@gmail.com> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | */ | ||
11 | |||
12 | #ifndef _ROCKER_H | ||
13 | #define _ROCKER_H | ||
14 | |||
15 | #include <linux/types.h> | ||
16 | |||
17 | #include "rocker_hw.h" | ||
18 | |||
19 | struct rocker_desc_info { | ||
20 | char *data; /* mapped */ | ||
21 | size_t data_size; | ||
22 | size_t tlv_size; | ||
23 | struct rocker_desc *desc; | ||
24 | dma_addr_t mapaddr; | ||
25 | }; | ||
26 | |||
27 | #endif | ||
diff --git a/drivers/net/ethernet/rocker/rocker_main.c b/drivers/net/ethernet/rocker/rocker_main.c index 44fa9ac36d85..eecbbd59acc1 100644 --- a/drivers/net/ethernet/rocker/rocker_main.c +++ b/drivers/net/ethernet/rocker/rocker_main.c | |||
@@ -40,6 +40,8 @@ | |||
40 | #include <generated/utsrelease.h> | 40 | #include <generated/utsrelease.h> |
41 | 41 | ||
42 | #include "rocker_hw.h" | 42 | #include "rocker_hw.h" |
43 | #include "rocker.h" | ||
44 | #include "rocker_tlv.h" | ||
43 | 45 | ||
44 | static const char rocker_driver_name[] = "rocker"; | 46 | static const char rocker_driver_name[] = "rocker"; |
45 | 47 | ||
@@ -177,14 +179,6 @@ struct rocker_neigh_tbl_entry { | |||
177 | bool ttl_check; | 179 | bool ttl_check; |
178 | }; | 180 | }; |
179 | 181 | ||
180 | struct rocker_desc_info { | ||
181 | char *data; /* mapped */ | ||
182 | size_t data_size; | ||
183 | size_t tlv_size; | ||
184 | struct rocker_desc *desc; | ||
185 | dma_addr_t mapaddr; | ||
186 | }; | ||
187 | |||
188 | struct rocker_dma_ring_info { | 182 | struct rocker_dma_ring_info { |
189 | size_t size; | 183 | size_t size; |
190 | u32 head; | 184 | u32 head; |
@@ -661,218 +655,6 @@ free_irq: | |||
661 | return err; | 655 | return err; |
662 | } | 656 | } |
663 | 657 | ||
664 | /****** | ||
665 | * TLV | ||
666 | ******/ | ||
667 | |||
668 | #define ROCKER_TLV_ALIGNTO 8U | ||
669 | #define ROCKER_TLV_ALIGN(len) \ | ||
670 | (((len) + ROCKER_TLV_ALIGNTO - 1) & ~(ROCKER_TLV_ALIGNTO - 1)) | ||
671 | #define ROCKER_TLV_HDRLEN ROCKER_TLV_ALIGN(sizeof(struct rocker_tlv)) | ||
672 | |||
673 | /* <------- ROCKER_TLV_HDRLEN -------> <--- ROCKER_TLV_ALIGN(payload) ---> | ||
674 | * +-----------------------------+- - -+- - - - - - - - - - - - - - -+- - -+ | ||
675 | * | Header | Pad | Payload | Pad | | ||
676 | * | (struct rocker_tlv) | ing | | ing | | ||
677 | * +-----------------------------+- - -+- - - - - - - - - - - - - - -+- - -+ | ||
678 | * <--------------------------- tlv->len --------------------------> | ||
679 | */ | ||
680 | |||
681 | static struct rocker_tlv *rocker_tlv_next(const struct rocker_tlv *tlv, | ||
682 | int *remaining) | ||
683 | { | ||
684 | int totlen = ROCKER_TLV_ALIGN(tlv->len); | ||
685 | |||
686 | *remaining -= totlen; | ||
687 | return (struct rocker_tlv *) ((char *) tlv + totlen); | ||
688 | } | ||
689 | |||
690 | static int rocker_tlv_ok(const struct rocker_tlv *tlv, int remaining) | ||
691 | { | ||
692 | return remaining >= (int) ROCKER_TLV_HDRLEN && | ||
693 | tlv->len >= ROCKER_TLV_HDRLEN && | ||
694 | tlv->len <= remaining; | ||
695 | } | ||
696 | |||
697 | #define rocker_tlv_for_each(pos, head, len, rem) \ | ||
698 | for (pos = head, rem = len; \ | ||
699 | rocker_tlv_ok(pos, rem); \ | ||
700 | pos = rocker_tlv_next(pos, &(rem))) | ||
701 | |||
702 | #define rocker_tlv_for_each_nested(pos, tlv, rem) \ | ||
703 | rocker_tlv_for_each(pos, rocker_tlv_data(tlv), \ | ||
704 | rocker_tlv_len(tlv), rem) | ||
705 | |||
706 | static int rocker_tlv_attr_size(int payload) | ||
707 | { | ||
708 | return ROCKER_TLV_HDRLEN + payload; | ||
709 | } | ||
710 | |||
711 | static int rocker_tlv_total_size(int payload) | ||
712 | { | ||
713 | return ROCKER_TLV_ALIGN(rocker_tlv_attr_size(payload)); | ||
714 | } | ||
715 | |||
716 | static int rocker_tlv_padlen(int payload) | ||
717 | { | ||
718 | return rocker_tlv_total_size(payload) - rocker_tlv_attr_size(payload); | ||
719 | } | ||
720 | |||
721 | static int rocker_tlv_type(const struct rocker_tlv *tlv) | ||
722 | { | ||
723 | return tlv->type; | ||
724 | } | ||
725 | |||
726 | static void *rocker_tlv_data(const struct rocker_tlv *tlv) | ||
727 | { | ||
728 | return (char *) tlv + ROCKER_TLV_HDRLEN; | ||
729 | } | ||
730 | |||
731 | static int rocker_tlv_len(const struct rocker_tlv *tlv) | ||
732 | { | ||
733 | return tlv->len - ROCKER_TLV_HDRLEN; | ||
734 | } | ||
735 | |||
736 | static u8 rocker_tlv_get_u8(const struct rocker_tlv *tlv) | ||
737 | { | ||
738 | return *(u8 *) rocker_tlv_data(tlv); | ||
739 | } | ||
740 | |||
741 | static u16 rocker_tlv_get_u16(const struct rocker_tlv *tlv) | ||
742 | { | ||
743 | return *(u16 *) rocker_tlv_data(tlv); | ||
744 | } | ||
745 | |||
746 | static __be16 rocker_tlv_get_be16(const struct rocker_tlv *tlv) | ||
747 | { | ||
748 | return *(__be16 *) rocker_tlv_data(tlv); | ||
749 | } | ||
750 | |||
751 | static u32 rocker_tlv_get_u32(const struct rocker_tlv *tlv) | ||
752 | { | ||
753 | return *(u32 *) rocker_tlv_data(tlv); | ||
754 | } | ||
755 | |||
756 | static u64 rocker_tlv_get_u64(const struct rocker_tlv *tlv) | ||
757 | { | ||
758 | return *(u64 *) rocker_tlv_data(tlv); | ||
759 | } | ||
760 | |||
761 | static void rocker_tlv_parse(const struct rocker_tlv **tb, int maxtype, | ||
762 | const char *buf, int buf_len) | ||
763 | { | ||
764 | const struct rocker_tlv *tlv; | ||
765 | const struct rocker_tlv *head = (const struct rocker_tlv *) buf; | ||
766 | int rem; | ||
767 | |||
768 | memset(tb, 0, sizeof(struct rocker_tlv *) * (maxtype + 1)); | ||
769 | |||
770 | rocker_tlv_for_each(tlv, head, buf_len, rem) { | ||
771 | u32 type = rocker_tlv_type(tlv); | ||
772 | |||
773 | if (type > 0 && type <= maxtype) | ||
774 | tb[type] = tlv; | ||
775 | } | ||
776 | } | ||
777 | |||
778 | static void rocker_tlv_parse_nested(const struct rocker_tlv **tb, int maxtype, | ||
779 | const struct rocker_tlv *tlv) | ||
780 | { | ||
781 | rocker_tlv_parse(tb, maxtype, rocker_tlv_data(tlv), | ||
782 | rocker_tlv_len(tlv)); | ||
783 | } | ||
784 | |||
785 | static void rocker_tlv_parse_desc(const struct rocker_tlv **tb, int maxtype, | ||
786 | const struct rocker_desc_info *desc_info) | ||
787 | { | ||
788 | rocker_tlv_parse(tb, maxtype, desc_info->data, | ||
789 | desc_info->desc->tlv_size); | ||
790 | } | ||
791 | |||
792 | static struct rocker_tlv *rocker_tlv_start(struct rocker_desc_info *desc_info) | ||
793 | { | ||
794 | return (struct rocker_tlv *) ((char *) desc_info->data + | ||
795 | desc_info->tlv_size); | ||
796 | } | ||
797 | |||
798 | static int rocker_tlv_put(struct rocker_desc_info *desc_info, | ||
799 | int attrtype, int attrlen, const void *data) | ||
800 | { | ||
801 | int tail_room = desc_info->data_size - desc_info->tlv_size; | ||
802 | int total_size = rocker_tlv_total_size(attrlen); | ||
803 | struct rocker_tlv *tlv; | ||
804 | |||
805 | if (unlikely(tail_room < total_size)) | ||
806 | return -EMSGSIZE; | ||
807 | |||
808 | tlv = rocker_tlv_start(desc_info); | ||
809 | desc_info->tlv_size += total_size; | ||
810 | tlv->type = attrtype; | ||
811 | tlv->len = rocker_tlv_attr_size(attrlen); | ||
812 | memcpy(rocker_tlv_data(tlv), data, attrlen); | ||
813 | memset((char *) tlv + tlv->len, 0, rocker_tlv_padlen(attrlen)); | ||
814 | return 0; | ||
815 | } | ||
816 | |||
817 | static int rocker_tlv_put_u8(struct rocker_desc_info *desc_info, | ||
818 | int attrtype, u8 value) | ||
819 | { | ||
820 | return rocker_tlv_put(desc_info, attrtype, sizeof(u8), &value); | ||
821 | } | ||
822 | |||
823 | static int rocker_tlv_put_u16(struct rocker_desc_info *desc_info, | ||
824 | int attrtype, u16 value) | ||
825 | { | ||
826 | return rocker_tlv_put(desc_info, attrtype, sizeof(u16), &value); | ||
827 | } | ||
828 | |||
829 | static int rocker_tlv_put_be16(struct rocker_desc_info *desc_info, | ||
830 | int attrtype, __be16 value) | ||
831 | { | ||
832 | return rocker_tlv_put(desc_info, attrtype, sizeof(__be16), &value); | ||
833 | } | ||
834 | |||
835 | static int rocker_tlv_put_u32(struct rocker_desc_info *desc_info, | ||
836 | int attrtype, u32 value) | ||
837 | { | ||
838 | return rocker_tlv_put(desc_info, attrtype, sizeof(u32), &value); | ||
839 | } | ||
840 | |||
841 | static int rocker_tlv_put_be32(struct rocker_desc_info *desc_info, | ||
842 | int attrtype, __be32 value) | ||
843 | { | ||
844 | return rocker_tlv_put(desc_info, attrtype, sizeof(__be32), &value); | ||
845 | } | ||
846 | |||
847 | static int rocker_tlv_put_u64(struct rocker_desc_info *desc_info, | ||
848 | int attrtype, u64 value) | ||
849 | { | ||
850 | return rocker_tlv_put(desc_info, attrtype, sizeof(u64), &value); | ||
851 | } | ||
852 | |||
853 | static struct rocker_tlv * | ||
854 | rocker_tlv_nest_start(struct rocker_desc_info *desc_info, int attrtype) | ||
855 | { | ||
856 | struct rocker_tlv *start = rocker_tlv_start(desc_info); | ||
857 | |||
858 | if (rocker_tlv_put(desc_info, attrtype, 0, NULL) < 0) | ||
859 | return NULL; | ||
860 | |||
861 | return start; | ||
862 | } | ||
863 | |||
864 | static void rocker_tlv_nest_end(struct rocker_desc_info *desc_info, | ||
865 | struct rocker_tlv *start) | ||
866 | { | ||
867 | start->len = (char *) rocker_tlv_start(desc_info) - (char *) start; | ||
868 | } | ||
869 | |||
870 | static void rocker_tlv_nest_cancel(struct rocker_desc_info *desc_info, | ||
871 | const struct rocker_tlv *start) | ||
872 | { | ||
873 | desc_info->tlv_size = (const char *) start - desc_info->data; | ||
874 | } | ||
875 | |||
876 | /****************************************** | 658 | /****************************************** |
877 | * DMA rings and descriptors manipulations | 659 | * DMA rings and descriptors manipulations |
878 | ******************************************/ | 660 | ******************************************/ |
diff --git a/drivers/net/ethernet/rocker/rocker_tlv.c b/drivers/net/ethernet/rocker/rocker_tlv.c new file mode 100644 index 000000000000..8185118f3492 --- /dev/null +++ b/drivers/net/ethernet/rocker/rocker_tlv.c | |||
@@ -0,0 +1,53 @@ | |||
1 | /* | ||
2 | * drivers/net/ethernet/rocker/rocker_tlv.c - Rocker switch device driver | ||
3 | * Copyright (c) 2014-2016 Jiri Pirko <jiri@mellanox.com> | ||
4 | * Copyright (c) 2014 Scott Feldman <sfeldma@gmail.com> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | */ | ||
11 | |||
12 | #include <linux/types.h> | ||
13 | #include <linux/string.h> | ||
14 | #include <linux/errno.h> | ||
15 | |||
16 | #include "rocker_hw.h" | ||
17 | #include "rocker_tlv.h" | ||
18 | |||
19 | void rocker_tlv_parse(const struct rocker_tlv **tb, int maxtype, | ||
20 | const char *buf, int buf_len) | ||
21 | { | ||
22 | const struct rocker_tlv *tlv; | ||
23 | const struct rocker_tlv *head = (const struct rocker_tlv *) buf; | ||
24 | int rem; | ||
25 | |||
26 | memset(tb, 0, sizeof(struct rocker_tlv *) * (maxtype + 1)); | ||
27 | |||
28 | rocker_tlv_for_each(tlv, head, buf_len, rem) { | ||
29 | u32 type = rocker_tlv_type(tlv); | ||
30 | |||
31 | if (type > 0 && type <= maxtype) | ||
32 | tb[type] = tlv; | ||
33 | } | ||
34 | } | ||
35 | |||
36 | int rocker_tlv_put(struct rocker_desc_info *desc_info, | ||
37 | int attrtype, int attrlen, const void *data) | ||
38 | { | ||
39 | int tail_room = desc_info->data_size - desc_info->tlv_size; | ||
40 | int total_size = rocker_tlv_total_size(attrlen); | ||
41 | struct rocker_tlv *tlv; | ||
42 | |||
43 | if (unlikely(tail_room < total_size)) | ||
44 | return -EMSGSIZE; | ||
45 | |||
46 | tlv = rocker_tlv_start(desc_info); | ||
47 | desc_info->tlv_size += total_size; | ||
48 | tlv->type = attrtype; | ||
49 | tlv->len = rocker_tlv_attr_size(attrlen); | ||
50 | memcpy(rocker_tlv_data(tlv), data, attrlen); | ||
51 | memset((char *) tlv + tlv->len, 0, rocker_tlv_padlen(attrlen)); | ||
52 | return 0; | ||
53 | } | ||
diff --git a/drivers/net/ethernet/rocker/rocker_tlv.h b/drivers/net/ethernet/rocker/rocker_tlv.h new file mode 100644 index 000000000000..a63ef82e7c72 --- /dev/null +++ b/drivers/net/ethernet/rocker/rocker_tlv.h | |||
@@ -0,0 +1,201 @@ | |||
1 | /* | ||
2 | * drivers/net/ethernet/rocker/rocker_tlv.h - Rocker switch device driver | ||
3 | * Copyright (c) 2014-2016 Jiri Pirko <jiri@mellanox.com> | ||
4 | * Copyright (c) 2014 Scott Feldman <sfeldma@gmail.com> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | */ | ||
11 | |||
12 | #ifndef _ROCKER_TLV_H | ||
13 | #define _ROCKER_TLV_H | ||
14 | |||
15 | #include <linux/types.h> | ||
16 | |||
17 | #include "rocker_hw.h" | ||
18 | #include "rocker.h" | ||
19 | |||
20 | #define ROCKER_TLV_ALIGNTO 8U | ||
21 | #define ROCKER_TLV_ALIGN(len) \ | ||
22 | (((len) + ROCKER_TLV_ALIGNTO - 1) & ~(ROCKER_TLV_ALIGNTO - 1)) | ||
23 | #define ROCKER_TLV_HDRLEN ROCKER_TLV_ALIGN(sizeof(struct rocker_tlv)) | ||
24 | |||
25 | /* <------- ROCKER_TLV_HDRLEN -------> <--- ROCKER_TLV_ALIGN(payload) ---> | ||
26 | * +-----------------------------+- - -+- - - - - - - - - - - - - - -+- - -+ | ||
27 | * | Header | Pad | Payload | Pad | | ||
28 | * | (struct rocker_tlv) | ing | | ing | | ||
29 | * +-----------------------------+- - -+- - - - - - - - - - - - - - -+- - -+ | ||
30 | * <--------------------------- tlv->len --------------------------> | ||
31 | */ | ||
32 | |||
33 | static inline struct rocker_tlv *rocker_tlv_next(const struct rocker_tlv *tlv, | ||
34 | int *remaining) | ||
35 | { | ||
36 | int totlen = ROCKER_TLV_ALIGN(tlv->len); | ||
37 | |||
38 | *remaining -= totlen; | ||
39 | return (struct rocker_tlv *) ((char *) tlv + totlen); | ||
40 | } | ||
41 | |||
42 | static inline int rocker_tlv_ok(const struct rocker_tlv *tlv, int remaining) | ||
43 | { | ||
44 | return remaining >= (int) ROCKER_TLV_HDRLEN && | ||
45 | tlv->len >= ROCKER_TLV_HDRLEN && | ||
46 | tlv->len <= remaining; | ||
47 | } | ||
48 | |||
49 | #define rocker_tlv_for_each(pos, head, len, rem) \ | ||
50 | for (pos = head, rem = len; \ | ||
51 | rocker_tlv_ok(pos, rem); \ | ||
52 | pos = rocker_tlv_next(pos, &(rem))) | ||
53 | |||
54 | #define rocker_tlv_for_each_nested(pos, tlv, rem) \ | ||
55 | rocker_tlv_for_each(pos, rocker_tlv_data(tlv), \ | ||
56 | rocker_tlv_len(tlv), rem) | ||
57 | |||
58 | static inline int rocker_tlv_attr_size(int payload) | ||
59 | { | ||
60 | return ROCKER_TLV_HDRLEN + payload; | ||
61 | } | ||
62 | |||
63 | static inline int rocker_tlv_total_size(int payload) | ||
64 | { | ||
65 | return ROCKER_TLV_ALIGN(rocker_tlv_attr_size(payload)); | ||
66 | } | ||
67 | |||
68 | static inline int rocker_tlv_padlen(int payload) | ||
69 | { | ||
70 | return rocker_tlv_total_size(payload) - rocker_tlv_attr_size(payload); | ||
71 | } | ||
72 | |||
73 | static inline int rocker_tlv_type(const struct rocker_tlv *tlv) | ||
74 | { | ||
75 | return tlv->type; | ||
76 | } | ||
77 | |||
78 | static inline void *rocker_tlv_data(const struct rocker_tlv *tlv) | ||
79 | { | ||
80 | return (char *) tlv + ROCKER_TLV_HDRLEN; | ||
81 | } | ||
82 | |||
83 | static inline int rocker_tlv_len(const struct rocker_tlv *tlv) | ||
84 | { | ||
85 | return tlv->len - ROCKER_TLV_HDRLEN; | ||
86 | } | ||
87 | |||
88 | static inline u8 rocker_tlv_get_u8(const struct rocker_tlv *tlv) | ||
89 | { | ||
90 | return *(u8 *) rocker_tlv_data(tlv); | ||
91 | } | ||
92 | |||
93 | static inline u16 rocker_tlv_get_u16(const struct rocker_tlv *tlv) | ||
94 | { | ||
95 | return *(u16 *) rocker_tlv_data(tlv); | ||
96 | } | ||
97 | |||
98 | static inline __be16 rocker_tlv_get_be16(const struct rocker_tlv *tlv) | ||
99 | { | ||
100 | return *(__be16 *) rocker_tlv_data(tlv); | ||
101 | } | ||
102 | |||
103 | static inline u32 rocker_tlv_get_u32(const struct rocker_tlv *tlv) | ||
104 | { | ||
105 | return *(u32 *) rocker_tlv_data(tlv); | ||
106 | } | ||
107 | |||
108 | static inline u64 rocker_tlv_get_u64(const struct rocker_tlv *tlv) | ||
109 | { | ||
110 | return *(u64 *) rocker_tlv_data(tlv); | ||
111 | } | ||
112 | |||
113 | void rocker_tlv_parse(const struct rocker_tlv **tb, int maxtype, | ||
114 | const char *buf, int buf_len); | ||
115 | |||
116 | static inline void rocker_tlv_parse_nested(const struct rocker_tlv **tb, | ||
117 | int maxtype, | ||
118 | const struct rocker_tlv *tlv) | ||
119 | { | ||
120 | rocker_tlv_parse(tb, maxtype, rocker_tlv_data(tlv), | ||
121 | rocker_tlv_len(tlv)); | ||
122 | } | ||
123 | |||
124 | static inline void | ||
125 | rocker_tlv_parse_desc(const struct rocker_tlv **tb, int maxtype, | ||
126 | const struct rocker_desc_info *desc_info) | ||
127 | { | ||
128 | rocker_tlv_parse(tb, maxtype, desc_info->data, | ||
129 | desc_info->desc->tlv_size); | ||
130 | } | ||
131 | |||
132 | static inline struct rocker_tlv * | ||
133 | rocker_tlv_start(struct rocker_desc_info *desc_info) | ||
134 | { | ||
135 | return (struct rocker_tlv *) ((char *) desc_info->data + | ||
136 | desc_info->tlv_size); | ||
137 | } | ||
138 | |||
139 | int rocker_tlv_put(struct rocker_desc_info *desc_info, | ||
140 | int attrtype, int attrlen, const void *data); | ||
141 | |||
142 | static inline int rocker_tlv_put_u8(struct rocker_desc_info *desc_info, | ||
143 | int attrtype, u8 value) | ||
144 | { | ||
145 | return rocker_tlv_put(desc_info, attrtype, sizeof(u8), &value); | ||
146 | } | ||
147 | |||
148 | static inline int rocker_tlv_put_u16(struct rocker_desc_info *desc_info, | ||
149 | int attrtype, u16 value) | ||
150 | { | ||
151 | return rocker_tlv_put(desc_info, attrtype, sizeof(u16), &value); | ||
152 | } | ||
153 | |||
154 | static inline int rocker_tlv_put_be16(struct rocker_desc_info *desc_info, | ||
155 | int attrtype, __be16 value) | ||
156 | { | ||
157 | return rocker_tlv_put(desc_info, attrtype, sizeof(__be16), &value); | ||
158 | } | ||
159 | |||
160 | static inline int rocker_tlv_put_u32(struct rocker_desc_info *desc_info, | ||
161 | int attrtype, u32 value) | ||
162 | { | ||
163 | return rocker_tlv_put(desc_info, attrtype, sizeof(u32), &value); | ||
164 | } | ||
165 | |||
166 | static inline int rocker_tlv_put_be32(struct rocker_desc_info *desc_info, | ||
167 | int attrtype, __be32 value) | ||
168 | { | ||
169 | return rocker_tlv_put(desc_info, attrtype, sizeof(__be32), &value); | ||
170 | } | ||
171 | |||
172 | static inline int rocker_tlv_put_u64(struct rocker_desc_info *desc_info, | ||
173 | int attrtype, u64 value) | ||
174 | { | ||
175 | return rocker_tlv_put(desc_info, attrtype, sizeof(u64), &value); | ||
176 | } | ||
177 | |||
178 | static inline struct rocker_tlv * | ||
179 | rocker_tlv_nest_start(struct rocker_desc_info *desc_info, int attrtype) | ||
180 | { | ||
181 | struct rocker_tlv *start = rocker_tlv_start(desc_info); | ||
182 | |||
183 | if (rocker_tlv_put(desc_info, attrtype, 0, NULL) < 0) | ||
184 | return NULL; | ||
185 | |||
186 | return start; | ||
187 | } | ||
188 | |||
189 | static inline void rocker_tlv_nest_end(struct rocker_desc_info *desc_info, | ||
190 | struct rocker_tlv *start) | ||
191 | { | ||
192 | start->len = (char *) rocker_tlv_start(desc_info) - (char *) start; | ||
193 | } | ||
194 | |||
195 | static inline void rocker_tlv_nest_cancel(struct rocker_desc_info *desc_info, | ||
196 | const struct rocker_tlv *start) | ||
197 | { | ||
198 | desc_info->tlv_size = (const char *) start - desc_info->data; | ||
199 | } | ||
200 | |||
201 | #endif | ||