Skip to content

Commit b8e1f90

Browse files
Geliang Tangintel-lab-lkp
authored andcommitted
mptcp: change is_backup interfaces as get_flags
is_backup() interface of the path managers is not very common. A more common approach is to add a get_flags() interface to obtain the flags value of a given address. Then is_backup() can be implemented through get_flags() by test whether backup flag is set in the flags value. Signed-off-by: Geliang Tang <[email protected]>
1 parent 1bdad5d commit b8e1f90

File tree

4 files changed

+19
-13
lines changed

4 files changed

+19
-13
lines changed

net/mptcp/pm.c

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -425,13 +425,16 @@ int mptcp_pm_get_local_id(struct mptcp_sock *msk, struct sock_common *skc)
425425
bool mptcp_pm_is_backup(struct mptcp_sock *msk, struct sock_common *skc)
426426
{
427427
struct mptcp_addr_info skc_local;
428+
u8 flags;
428429

429430
mptcp_local_address((struct sock_common *)skc, &skc_local);
430431

431432
if (mptcp_pm_is_userspace(msk))
432-
return mptcp_userspace_pm_is_backup(msk, &skc_local);
433+
flags = mptcp_userspace_pm_get_flags(msk, &skc_local);
434+
else
435+
flags = mptcp_pm_nl_get_flags(msk, &skc_local);
433436

434-
return mptcp_pm_nl_is_backup(msk, &skc_local);
437+
return !!(flags & MPTCP_PM_ADDR_FLAG_BACKUP);
435438
}
436439

437440
static int mptcp_pm_get_addr(u8 id, struct mptcp_pm_addr_entry *addr,

net/mptcp/pm_netlink.c

Lines changed: 5 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1172,18 +1172,19 @@ int mptcp_pm_nl_get_local_id(struct mptcp_sock *msk, struct mptcp_addr_info *skc
11721172
return ret;
11731173
}
11741174

1175-
bool mptcp_pm_nl_is_backup(struct mptcp_sock *msk, struct mptcp_addr_info *skc)
1175+
u8 mptcp_pm_nl_get_flags(struct mptcp_sock *msk,
1176+
struct mptcp_addr_info *skc)
11761177
{
11771178
struct pm_nl_pernet *pernet = pm_nl_get_pernet_from_msk(msk);
11781179
struct mptcp_pm_addr_entry *entry;
1179-
bool backup;
1180+
u8 flags;
11801181

11811182
rcu_read_lock();
11821183
entry = __lookup_addr(pernet, skc);
1183-
backup = entry && !!(entry->flags & MPTCP_PM_ADDR_FLAG_BACKUP);
1184+
flags = entry ? entry->flags : 0;
11841185
rcu_read_unlock();
11851186

1186-
return backup;
1187+
return flags;
11871188
}
11881189

11891190
#define MPTCP_PM_CMD_GRP_OFFSET 0

net/mptcp/pm_userspace.c

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -154,18 +154,18 @@ int mptcp_userspace_pm_get_local_id(struct mptcp_sock *msk,
154154
return mptcp_userspace_pm_append_new_local_addr(msk, &new_entry, true);
155155
}
156156

157-
bool mptcp_userspace_pm_is_backup(struct mptcp_sock *msk,
158-
struct mptcp_addr_info *skc)
157+
u8 mptcp_userspace_pm_get_flags(struct mptcp_sock *msk,
158+
struct mptcp_addr_info *skc)
159159
{
160160
struct mptcp_pm_addr_entry *entry;
161-
bool backup;
161+
u8 flags;
162162

163163
spin_lock_bh(&msk->pm.lock);
164164
entry = mptcp_userspace_pm_lookup_addr(msk, skc);
165-
backup = entry && !!(entry->flags & MPTCP_PM_ADDR_FLAG_BACKUP);
165+
flags = entry ? entry->flags : 0;
166166
spin_unlock_bh(&msk->pm.lock);
167167

168-
return backup;
168+
return flags;
169169
}
170170

171171
static struct mptcp_sock *mptcp_userspace_pm_get_sock(const struct genl_info *info)

net/mptcp/protocol.h

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1132,8 +1132,10 @@ int mptcp_pm_get_local_id(struct mptcp_sock *msk, struct sock_common *skc);
11321132
int mptcp_pm_nl_get_local_id(struct mptcp_sock *msk, struct mptcp_addr_info *skc);
11331133
int mptcp_userspace_pm_get_local_id(struct mptcp_sock *msk, struct mptcp_addr_info *skc);
11341134
bool mptcp_pm_is_backup(struct mptcp_sock *msk, struct sock_common *skc);
1135-
bool mptcp_pm_nl_is_backup(struct mptcp_sock *msk, struct mptcp_addr_info *skc);
1136-
bool mptcp_userspace_pm_is_backup(struct mptcp_sock *msk, struct mptcp_addr_info *skc);
1135+
u8 mptcp_pm_nl_get_flags(struct mptcp_sock *msk,
1136+
struct mptcp_addr_info *skc);
1137+
u8 mptcp_userspace_pm_get_flags(struct mptcp_sock *msk,
1138+
struct mptcp_addr_info *skc);
11371139
int mptcp_pm_nl_dump_addr(struct sk_buff *msg,
11381140
struct netlink_callback *cb);
11391141
int mptcp_userspace_pm_dump_addr(struct sk_buff *msg,

0 commit comments

Comments
 (0)