aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/rocker
diff options
context:
space:
mode:
authorJiri Pirko <jiri@mellanox.com>2016-02-16 09:14:42 -0500
committerDavid S. Miller <davem@davemloft.net>2016-02-17 23:08:34 -0500
commitde1521923c0f2ee9c6328ad6b3e46e662d88a3cd (patch)
tree3bf69945190b05314a31717ad45c8cf39fd1d683 /drivers/net/ethernet/rocker
parent11ce2ba3d05b3ac330022da1f83b589a4f78569c (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/Makefile2
-rw-r--r--drivers/net/ethernet/rocker/rocker.h27
-rw-r--r--drivers/net/ethernet/rocker/rocker_main.c222
-rw-r--r--drivers/net/ethernet/rocker/rocker_tlv.c53
-rw-r--r--drivers/net/ethernet/rocker/rocker_tlv.h201
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
5obj-$(CONFIG_ROCKER) += rocker.o 5obj-$(CONFIG_ROCKER) += rocker.o
6rocker-y := rocker_main.o 6rocker-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
19struct 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
44static const char rocker_driver_name[] = "rocker"; 46static 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
180struct 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
188struct rocker_dma_ring_info { 182struct 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
681static 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
690static 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
706static int rocker_tlv_attr_size(int payload)
707{
708 return ROCKER_TLV_HDRLEN + payload;
709}
710
711static int rocker_tlv_total_size(int payload)
712{
713 return ROCKER_TLV_ALIGN(rocker_tlv_attr_size(payload));
714}
715
716static int rocker_tlv_padlen(int payload)
717{
718 return rocker_tlv_total_size(payload) - rocker_tlv_attr_size(payload);
719}
720
721static int rocker_tlv_type(const struct rocker_tlv *tlv)
722{
723 return tlv->type;
724}
725
726static void *rocker_tlv_data(const struct rocker_tlv *tlv)
727{
728 return (char *) tlv + ROCKER_TLV_HDRLEN;
729}
730
731static int rocker_tlv_len(const struct rocker_tlv *tlv)
732{
733 return tlv->len - ROCKER_TLV_HDRLEN;
734}
735
736static u8 rocker_tlv_get_u8(const struct rocker_tlv *tlv)
737{
738 return *(u8 *) rocker_tlv_data(tlv);
739}
740
741static u16 rocker_tlv_get_u16(const struct rocker_tlv *tlv)
742{
743 return *(u16 *) rocker_tlv_data(tlv);
744}
745
746static __be16 rocker_tlv_get_be16(const struct rocker_tlv *tlv)
747{
748 return *(__be16 *) rocker_tlv_data(tlv);
749}
750
751static u32 rocker_tlv_get_u32(const struct rocker_tlv *tlv)
752{
753 return *(u32 *) rocker_tlv_data(tlv);
754}
755
756static u64 rocker_tlv_get_u64(const struct rocker_tlv *tlv)
757{
758 return *(u64 *) rocker_tlv_data(tlv);
759}
760
761static 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
778static 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
785static 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
792static 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
798static 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
817static 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
823static 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
829static 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
835static 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
841static 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
847static 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
853static struct rocker_tlv *
854rocker_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
864static 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
870static 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
19void 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
36int 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
33static 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
42static 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
58static inline int rocker_tlv_attr_size(int payload)
59{
60 return ROCKER_TLV_HDRLEN + payload;
61}
62
63static inline int rocker_tlv_total_size(int payload)
64{
65 return ROCKER_TLV_ALIGN(rocker_tlv_attr_size(payload));
66}
67
68static inline int rocker_tlv_padlen(int payload)
69{
70 return rocker_tlv_total_size(payload) - rocker_tlv_attr_size(payload);
71}
72
73static inline int rocker_tlv_type(const struct rocker_tlv *tlv)
74{
75 return tlv->type;
76}
77
78static inline void *rocker_tlv_data(const struct rocker_tlv *tlv)
79{
80 return (char *) tlv + ROCKER_TLV_HDRLEN;
81}
82
83static inline int rocker_tlv_len(const struct rocker_tlv *tlv)
84{
85 return tlv->len - ROCKER_TLV_HDRLEN;
86}
87
88static inline u8 rocker_tlv_get_u8(const struct rocker_tlv *tlv)
89{
90 return *(u8 *) rocker_tlv_data(tlv);
91}
92
93static inline u16 rocker_tlv_get_u16(const struct rocker_tlv *tlv)
94{
95 return *(u16 *) rocker_tlv_data(tlv);
96}
97
98static inline __be16 rocker_tlv_get_be16(const struct rocker_tlv *tlv)
99{
100 return *(__be16 *) rocker_tlv_data(tlv);
101}
102
103static inline u32 rocker_tlv_get_u32(const struct rocker_tlv *tlv)
104{
105 return *(u32 *) rocker_tlv_data(tlv);
106}
107
108static inline u64 rocker_tlv_get_u64(const struct rocker_tlv *tlv)
109{
110 return *(u64 *) rocker_tlv_data(tlv);
111}
112
113void rocker_tlv_parse(const struct rocker_tlv **tb, int maxtype,
114 const char *buf, int buf_len);
115
116static 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
124static inline void
125rocker_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
132static inline struct rocker_tlv *
133rocker_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
139int rocker_tlv_put(struct rocker_desc_info *desc_info,
140 int attrtype, int attrlen, const void *data);
141
142static 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
148static 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
154static 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
160static 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
166static 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
172static 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
178static inline struct rocker_tlv *
179rocker_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
189static 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
195static 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