Fix data race in gw::deactivate_eps_bearer.

master
faluco 3 years ago committed by Andre Puschmann
parent a1b2f3915d
commit 3ecc8bb4c6

@ -210,6 +210,8 @@ int gw::setup_if_addr(uint32_t eps_bearer_id, uint8_t pdn_type, uint32_t ip_addr
int gw::deactivate_eps_bearer(const uint32_t eps_bearer_id) int gw::deactivate_eps_bearer(const uint32_t eps_bearer_id)
{ {
std::lock_guard<std::mutex> lock(gw_mutex);
// only deactivation of default bearer // only deactivation of default bearer
if (eps_bearer_id == static_cast<uint32_t>(default_eps_bearer_id)) { if (eps_bearer_id == static_cast<uint32_t>(default_eps_bearer_id)) {
logger.debug("Deactivating EPS bearer %d", eps_bearer_id); logger.debug("Deactivating EPS bearer %d", eps_bearer_id);
@ -468,7 +470,9 @@ int gw::setup_if_addr4(uint32_t ip_addr, char* err_str)
return SRSRAN_ERROR_CANT_START; return SRSRAN_ERROR_CANT_START;
} }
ifr.ifr_netmask.sa_family = AF_INET; ifr.ifr_netmask.sa_family = AF_INET;
if (inet_pton(ifr.ifr_netmask.sa_family, args.tun_dev_netmask.c_str(), &((struct sockaddr_in*)&ifr.ifr_netmask)->sin_addr.s_addr) != 1) { if (inet_pton(ifr.ifr_netmask.sa_family,
args.tun_dev_netmask.c_str(),
&((struct sockaddr_in*)&ifr.ifr_netmask)->sin_addr.s_addr) != 1) {
logger.error("Invalid tun_dev_netmask: %s", args.tun_dev_netmask.c_str()); logger.error("Invalid tun_dev_netmask: %s", args.tun_dev_netmask.c_str());
srsran::console("Invalid tun_dev_netmask: %s\n", args.tun_dev_netmask.c_str()); srsran::console("Invalid tun_dev_netmask: %s\n", args.tun_dev_netmask.c_str());
perror("inet_pton"); perror("inet_pton");

Loading…
Cancel
Save