提交 ac6c44de 编写于 作者: M Mika Westerberg 提交者: Greg Kroah-Hartman

thunderbolt: Expose get_route() to other files

We are going to use it when we change the connection manager to handle
events itself. Also rename it to follow naming convention used in
functions exposed in ctl.h.
Signed-off-by: NMika Westerberg <mika.westerberg@linux.intel.com>
Reviewed-by: NYehezkel Bernat <yehezkel.bernat@intel.com>
Reviewed-by: NMichael Jamet <michael.jamet@intel.com>
Reviewed-by: NAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: NAndreas Noever <andreas.noever@gmail.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 32af9434
...@@ -54,11 +54,6 @@ struct tb_ctl { ...@@ -54,11 +54,6 @@ struct tb_ctl {
/* utility functions */ /* utility functions */
static u64 get_route(struct tb_cfg_header header)
{
return (u64) header.route_hi << 32 | header.route_lo;
}
static struct tb_cfg_header make_header(u64 route) static struct tb_cfg_header make_header(u64 route)
{ {
struct tb_cfg_header header = { struct tb_cfg_header header = {
...@@ -66,7 +61,7 @@ static struct tb_cfg_header make_header(u64 route) ...@@ -66,7 +61,7 @@ static struct tb_cfg_header make_header(u64 route)
.route_lo = route, .route_lo = route,
}; };
/* check for overflow, route_hi is not 32 bits! */ /* check for overflow, route_hi is not 32 bits! */
WARN_ON(get_route(header) != route); WARN_ON(tb_cfg_get_route(&header) != route);
return header; return header;
} }
...@@ -91,9 +86,9 @@ static int check_header(struct ctl_pkg *pkg, u32 len, enum tb_cfg_pkg_type type, ...@@ -91,9 +86,9 @@ static int check_header(struct ctl_pkg *pkg, u32 len, enum tb_cfg_pkg_type type,
if (WARN(header->unknown != 1 << 9, if (WARN(header->unknown != 1 << 9,
"header->unknown is %#x\n", header->unknown)) "header->unknown is %#x\n", header->unknown))
return -EIO; return -EIO;
if (WARN(route != get_route(*header), if (WARN(route != tb_cfg_get_route(header),
"wrong route (expected %llx, got %llx)", "wrong route (expected %llx, got %llx)",
route, get_route(*header))) route, tb_cfg_get_route(header)))
return -EIO; return -EIO;
return 0; return 0;
} }
...@@ -126,10 +121,10 @@ static struct tb_cfg_result decode_error(struct ctl_pkg *response) ...@@ -126,10 +121,10 @@ static struct tb_cfg_result decode_error(struct ctl_pkg *response)
{ {
struct cfg_error_pkg *pkg = response->buffer; struct cfg_error_pkg *pkg = response->buffer;
struct tb_cfg_result res = { 0 }; struct tb_cfg_result res = { 0 };
res.response_route = get_route(pkg->header); res.response_route = tb_cfg_get_route(&pkg->header);
res.response_port = 0; res.response_port = 0;
res.err = check_header(response, sizeof(*pkg), TB_CFG_PKG_ERROR, res.err = check_header(response, sizeof(*pkg), TB_CFG_PKG_ERROR,
get_route(pkg->header)); tb_cfg_get_route(&pkg->header));
if (res.err) if (res.err)
return res; return res;
...@@ -153,7 +148,7 @@ static struct tb_cfg_result parse_header(struct ctl_pkg *pkg, u32 len, ...@@ -153,7 +148,7 @@ static struct tb_cfg_result parse_header(struct ctl_pkg *pkg, u32 len,
return decode_error(pkg); return decode_error(pkg);
res.response_port = 0; /* will be updated later for cfg_read/write */ res.response_port = 0; /* will be updated later for cfg_read/write */
res.response_route = get_route(*header); res.response_route = tb_cfg_get_route(header);
res.err = check_header(pkg, len, type, route); res.err = check_header(pkg, len, type, route);
return res; return res;
} }
...@@ -294,7 +289,7 @@ static void tb_ctl_handle_plug_event(struct tb_ctl *ctl, ...@@ -294,7 +289,7 @@ static void tb_ctl_handle_plug_event(struct tb_ctl *ctl,
struct ctl_pkg *response) struct ctl_pkg *response)
{ {
struct cfg_event_pkg *pkg = response->buffer; struct cfg_event_pkg *pkg = response->buffer;
u64 route = get_route(pkg->header); u64 route = tb_cfg_get_route(&pkg->header);
if (check_header(response, sizeof(*pkg), TB_CFG_PKG_EVENT, route)) { if (check_header(response, sizeof(*pkg), TB_CFG_PKG_EVENT, route)) {
tb_ctl_warn(ctl, "malformed TB_CFG_PKG_EVENT\n"); tb_ctl_warn(ctl, "malformed TB_CFG_PKG_EVENT\n");
......
...@@ -38,6 +38,10 @@ struct tb_cfg_result { ...@@ -38,6 +38,10 @@ struct tb_cfg_result {
enum tb_cfg_error tb_error; /* valid if err == 1 */ enum tb_cfg_error tb_error; /* valid if err == 1 */
}; };
static inline u64 tb_cfg_get_route(const struct tb_cfg_header *header)
{
return (u64) header->route_hi << 32 | header->route_lo;
}
int tb_cfg_error(struct tb_ctl *ctl, u64 route, u32 port, int tb_cfg_error(struct tb_ctl *ctl, u64 route, u32 port,
enum tb_cfg_error error); enum tb_cfg_error error);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册