22 #include <ovsdb_types.h>
24 using namespace OVSDB;
38 const std::string &name) :
39 OvsdbDBEntry(table), name_(name), device_name_(), vxlan_id_(0),
40 mcast_local_row_list_(), mcast_remote_row_(NULL), delete_ovs_(false),
41 res_vxlan_id_(table->client_idl()->vxlan_table(), this), del_task_(NULL) {
46 name_(
UuidToString(entry->vn()->GetUuid())), mcast_local_row_list_(),
47 mcast_remote_row_(NULL), delete_ovs_(false),
48 res_vxlan_id_(table->client_idl()->vxlan_table(), this), del_task_(NULL) {
55 mcast_local_row_list_(), mcast_remote_row_(NULL), delete_ovs_(false),
56 res_vxlan_id_(table->client_idl()->vxlan_table(), this), del_task_(NULL) {
63 struct ovsdb_idl_row *entry) :
OvsdbDBEntry(table, entry),
66 mcast_remote_row_(NULL), delete_ovs_(false),
67 res_vxlan_id_(table->client_idl()->vxlan_table(), this), del_task_(NULL) {
90 struct ovsdb_idl_row *row =
110 struct ovsdb_idl_row *pl_row = NULL;
114 pl_row, dest_ip.c_str());
137 OvsdbIdlRowList::iterator it;
225 if (!p_switch->IsResolved()) {
265 uint32_t active_vxlan_id =
287 uint32_t active_vxlan_id =
311 if (!add_change_in_progress) {
326 Task((entry->table()->client_idl()->agent()->task_scheduler()\
327 ->GetTaskId(
"Agent::KSync")), 0), entry_(entry) {
341 std::set<IntrusiveReferrer>::const_iterator it =
345 for (
int i = 0; i < kEntriesPerIteration; i++) {
389 SandeshLogicalSwitchInfo info;
392 info.set_op(
"Add Requested");
395 info.set_op(
"Delete Requested");
398 info.set_op(
"Add Received");
401 info.set_op(
"Delete Received");
404 info.set_op(
"Add Request with Duplicate tunnel key");
407 info.set_op(
"unknown");
409 info.set_name(
name_);
416 OvsdbIdlRowList::iterator it;
435 OvsdbIdlRowList::iterator it;
475 struct ovsdb_idl_row *row) {
489 struct ovsdb_idl_row *row) {
497 struct ovsdb_idl_row *l_set =
505 OvsdbIdlRowMap::iterator idl_it =
idl_row_map_.find(row);
507 entry = idl_it->second;
512 ", logical switch " + (entry != NULL ? entry->
name() :
""));
518 ", logical switch " + (ls ? std::string(ls) :
""));
542 struct ovsdb_idl_row *row) {
552 OvsdbIdlRowMap::iterator idl_it =
idl_row_map_.find(row);
554 entry = idl_it->second;
559 ", logical switch " + (entry != NULL ? entry->
name() :
""));
573 ", logical switch " + (ls ? std::string(ls) :
""));
594 if (dest_ip.compare(tsn_ip) != 0) {
613 struct ovsdb_idl_row *row) {
623 OvsdbIdlRowMap::iterator idl_it =
idl_row_map_.find(row);
625 entry = idl_it->second;
630 ", logical switch " + (entry != NULL ? entry->
name() :
""));
636 ", logical switch " + (ls ? std::string(ls) :
""));
699 Task((table->client_idl()->agent()->task_scheduler()\
700 ->GetTaskId(
"Agent::KSync")), 0), table_(table), entry_(NULL) {
708 if (kentry == NULL) {
709 kentry =
table_->Next(kentry);
713 while (kentry != NULL) {
716 kentry =
table_->Next(kentry);
722 if (count == kEntriesPerIteration && kentry != NULL) {
740 if (
false == args.
Get(
"name", &
name_)) {
744 if (
false == args.
Get(
"vxlan_id", &vxlan_id)) {
751 const std::string &ip,
753 const std::string &name,
762 if (!
name_.empty()) {
772 if (!
name_.empty()) {
774 if (entry->
name().find(
name_) == std::string::npos) {
792 OvsdbLogicalSwitchEntry lentry;
794 lentry.set_name(entry->
name());
796 lentry.set_vxlan_id(entry->
vxlan_id());
799 lentry.set_vxlan_id_available(res.
VxLanId() != 0);
812 lentry.set_message(
"Waiting for Local Macs Cleanup");
814 OvsdbLogicalSwitchResp *ls_resp =
815 static_cast<OvsdbLogicalSwitchResp *
>(resp);
816 std::vector<OvsdbLogicalSwitchEntry> &lswitch =
817 const_cast<std::vector<OvsdbLogicalSwitchEntry>&
>(
818 ls_resp->get_lswitch());
819 lswitch.push_back(lentry);
831 void OvsdbLogicalSwitchReq::HandleRequest()
const {
834 get_session_remote_port(),
835 get_name(), get_vxlan_id());
KSyncEntryPtr pl_create_ref_
struct ovsdb_idl_row * ovsdb_wrapper_add_logical_switch(struct ovsdb_idl_txn *, struct ovsdb_idl_row *, const char *, int64_t)
SandeshResponse * Alloc()
ProcessDeleteOvsReqTask * del_task_
const std::string & device_display_name() const
#define OVSDB_TRACE(obj,...)
bool is_local_mac_ref_set() const
void Change(KSyncEntry *entry)
char * ovsdb_wrapper_mcast_mac_local_logical_switch(struct ovsdb_idl_row *row)
OvsdbClientIdl * client_idl()
The TaskScheduler keeps track of what tasks are currently schedulable. When a task is enqueued it is ...
OvsdbIdlRowList old_mcast_remote_row_list_
virtual void StaleTimerExpired()
void DeleteOldMcastRemoteMac()
uint32_t ucast_local_row_list_size() const
KSyncEntry * Alloc(const KSyncEntry *key, uint32_t index)
virtual void NotifyDelete(struct ovsdb_idl_row *)
LogicalSwitchTable(OvsdbClientIdl *idl)
std::string StateString() const
bool IsLocalMacsRef() const
KSyncEntry * DBToKSyncEntry(const DBEntry *)
struct ovsdb_idl_row * ovsdb_wrapper_mcast_mac_local_physical_locator_set(struct ovsdb_idl_row *row)
virtual ~LogicalSwitchEntry()
char * ovsdb_wrapper_logical_switch_name(struct ovsdb_idl_row *row)
char * ovsdb_wrapper_mcast_mac_remote_logical_switch(struct ovsdb_idl_row *row)
bool AcquireCreateRequest(KSyncEntry *creator)
void UpdateResp(KSyncEntry *kentry, SandeshResponse *resp)
virtual ~ProcessDeleteOvsReqTask()
std::pair< void *, void * > IntrusiveReferrer
static std::string UuidToString(const boost::uuids::uuid &id)
OvsdbIdlRowList mcast_local_row_list_
PhysicalLocatorTable * physical_locator_table()
bool IsLess(const KSyncEntry &) const
void Register(EntryType type, NotifyCB cb)
MulticastMacLocalOvsdb * multicast_mac_local_ovsdb()
DBFilterResp OvsdbDBEntryFilter(const DBEntry *entry, const OvsdbDBEntry *ovsdb_entry)
uint32_t old_mcast_remote_row_list_size() const
bool Run()
Code to execute. Returns true if task is completed. Return false to reschedule the task...
void ChangeMsg(struct ovsdb_idl_txn *)
CancelReturnCode Cancel(Task *task)
Cancels a Task that can be in RUN/WAIT state. The caller needs to ensure that the task exists when Ca...
struct ovsdb_idl_row * ovs_entry()
bool IsDeleteOvsInProgress() const
void ovsdb_wrapper_delete_mcast_mac_remote(struct ovsdb_idl_row *row)
bool AcquireVxLanId(uint32_t vxlan_id)
TaskScheduler * task_scheduler() const
bool Get(const std::string &key, std::string *val) const
char * ovsdb_wrapper_mcast_mac_remote_mac(struct ovsdb_idl_row *row)
OvsdbDBEntry * AllocOvsEntry(struct ovsdb_idl_row *row)
KSyncEntryPtr local_mac_ref_
void SafeNotifyEvent(KSyncEntry *entry, KSyncEntry::KSyncEvent event)
static TaskScheduler * GetInstance()
void Enqueue(Task *task)
Enqueues a task for running. Starts task if all policy rules are met else puts task in waitq...
std::string tor_service_node() const
void OvsdbMcastRemoteMacNotify(OvsdbClientIdl::Op, struct ovsdb_idl_row *)
int64_t ovsdb_wrapper_logical_switch_tunnel_key(struct ovsdb_idl_row *row)
void set_active_vxlan_id(uint32_t vxlan_id)
void NotifyDeleteOvsdb(OvsdbDBEntry *key, struct ovsdb_idl_row *row)
KSyncEntryPtr physical_switch_
const std::string & name() const
void AddMsg(struct ovsdb_idl_txn *)
void ovsdb_wrapper_delete_mcast_mac_local(struct ovsdb_idl_row *row)
struct ovsdb_idl_row * ovs_entry_
KSyncEntry * UnresolvedReference()
OvsdbClientIdl * client_idl()
std::set< IntrusiveReferrer > back_ref_set_
void OvsdbNotify(OvsdbClientIdl::Op, struct ovsdb_idl_row *)
KSyncEntry * Find(const KSyncEntry *key)
struct ovsdb_idl_row * ovs_entry()
bool Add(const std::string &key, const std::string &val)
virtual ~ProcessDeleteTableReqTask()
KSyncEntry * GetReference(const KSyncEntry *key)
OvsdbIdlRowMap idl_row_map_
void OvsdbMcastLocalMacNotify(OvsdbClientIdl::Op, struct ovsdb_idl_row *)
OvsdbIdlRowList ucast_local_row_list_
boost::asio::ip::address_v4 Ip4Address
Ip4Address & physical_switch_tunnel_ip()
virtual void NotifyDelete(struct ovsdb_idl_row *)
LogicalSwitchTable * logical_switch_table()
LogicalSwitchSandeshTask(std::string resp_ctx, AgentSandeshArguments &args)
uint32_t mcast_local_row_list_size() const
KSyncEntry * CreateStale(const KSyncEntry *key)
void ProcessDeleteTableReq()
void ovsdb_wrapper_add_mcast_mac_remote(struct ovsdb_idl_txn *txn, struct ovsdb_idl_row *row, const char *mac, struct ovsdb_idl_row *ls, struct ovsdb_idl_row *pl, const char *dst_ip)
void ovsdb_wrapper_delete_logical_switch(struct ovsdb_idl_row *)
void SendTrace(Trace event) const
virtual ~LogicalSwitchTable()
void EncodeArgs(AgentSandeshArguments &args)
ProcessDeleteOvsReqTask(LogicalSwitchEntry *entry)
OvsdbResourceVxLanId & res_vxlan_id()
virtual void Ack(bool success)
void DeleteMsg(struct ovsdb_idl_txn *)
UnicastMacLocalOvsdb * unicast_mac_local_ovsdb()
static KSyncEntry * default_defer_entry()
FilterResp Filter(KSyncEntry *entry)
KSyncObject * GetObject(OvsdbClientSession *session)
void DeleteOvs(bool add_change_in_progress)
const std::string & device_name() const
void intrusive_ptr_add_back_ref(IntrusiveReferrer ref, LogicalSwitchEntry *p)
bool is_mcast_remote_set() const
char * ovsdb_wrapper_ucast_mac_local_logical_switch(struct ovsdb_idl_row *row)
virtual ~LogicalSwitchSandeshTask()
char * ovsdb_wrapper_ucast_mac_local_mac(struct ovsdb_idl_row *row)
bool Run()
Code to execute. Returns true if task is completed. Return false to reschedule the task...
struct ovsdb_idl_row * mcast_remote_row_
void ReleaseCreateRequest(KSyncEntry *creator)
void ReleaseLocatorCreateReference()
char * ovsdb_wrapper_mcast_mac_remote_dst_ip(struct ovsdb_idl_row *row)
OvsdbResourceVxLanId res_vxlan_id_
char * ovsdb_wrapper_mcast_mac_local_mac(struct ovsdb_idl_row *row)
Task is a wrapper over tbb::task to support policies.
LogicalSwitchEntry(OvsdbDBObject *table, const std::string &name)
void NotifyAddOvsdb(OvsdbDBEntry *key, struct ovsdb_idl_row *row)
void OvsdbUcastLocalMacNotify(OvsdbClientIdl::Op, struct ovsdb_idl_row *)
void intrusive_ptr_del_back_ref(IntrusiveReferrer ref, LogicalSwitchEntry *p)
void ovsdb_wrapper_delete_ucast_mac_local(struct ovsdb_idl_row *row)
ProcessDeleteTableReqTask(LogicalSwitchTable *table)
uint32_t active_vxlan_id() const
PhysicalSwitchTable * physical_switch_table()