LAN_DEVICE = 1 WAN_DEVICE = 0 BURST = 3750000000 RATE = 375000000 EXP_TIME = 10 * 1000 * 1000 * 1000 h2 = pop_header(ipv4, on_mismatch=([], [])) # Malformed IPv4 if (h2.vihl & 15) < 5 or packet_size - 14 < (((h2.len & 0xFF) << 8) | ((h2.len & 0xFF00) >> 8)): return ([], []) h1 = pop_header(ether, on_mismatch=([], [])) flow_emap.expire_all(now - EXP_TIME) if received_on_port == WAN_DEVICE and flow_emap.has(ip_addrc(h2.daddr)): flow_idx = flow_emap.get(ip_addrc(h2.daddr)) flow_emap.refresh_idx(flow_idx, now) flow = dyn_vals.get(flow_idx) bucket_size = flow.bucket_size + (now - flow.bucket_time) * RATE if BURST < bucket_size: bucket_size = BURST if packet_size < bucket_size: bucket_size = bucket_size - packet_size dyn_vals.set(flow_idx, DynamicValuec(bucket_size, now)) return ([LAN_DEVICE], [ether(h1), ipv4(h2)]) else: pass else: pass
EXP_TIME = 10 * 1000 BACKEND_EXP_TIME = 3600000000 * 1000 EXT_PORT = 2 if a_packet_received: flow_emap.expire_all(now - EXP_TIME) backend_ip_emap.expire_all(now - BACKEND_EXP_TIME) h3 = pop_header(tcpudp, on_mismatch=([], [])) h2 = pop_header(ipv4, on_mismatch=([], [])) h1 = pop_header(ether, on_mismatch=([], [])) packet_flow = LoadBalancedFlowc(h2.saddr, h2.daddr, h3.src_port, h3.dst_port, h2.npid) if received_on_port == EXT_PORT and flow_emap.has(packet_flow): backend_id = flow_id_to_backend_id.get(flow_emap.get(packet_flow)) if not backend_ip_emap.has_idx(backend_id): flow_emap.erase(packet_flow) if backend_ip_emap.exists_with_cht( cht, _LoadBalancedFlow_hash(packet_flow)): bknd = backend_ip_emap.choose_with_cht( cht, _LoadBalancedFlow_hash(packet_flow)) idx = the_index_allocated flow_emap.add(packet_flow, idx, now) flow_id_to_backend_id.set(idx, bknd) else: pass else: pass else: pass
from state import flow_emap, int_devices EXP_TIME = 10 * 1000 EXT_DEVICE = 1 if a_packet_received: flow_emap.expire_all(now - EXP_TIME) h3 = pop_header(tcpudp, on_mismatch=([],[])) h2 = pop_header(ipv4, on_mismatch=([],[])) h1 = pop_header(ether, on_mismatch=([],[])) if received_on_port == EXT_DEVICE: internal_flow = FlowIdc(h3.dst_port, h3.src_port, h2.daddr, h2.saddr, h2.npid) if flow_emap.has(internal_flow): flow_emap.refresh_idx(flow_emap.get(internal_flow), now) else: pass else: internal_flow = FlowIdc(h3.src_port, h3.dst_port, h2.saddr, h2.daddr, h2.npid) if flow_emap.has(internal_flow): flow_emap.refresh_idx(flow_emap.get(internal_flow), now) else: pass
from state import flow_emap, int_devices EXP_TIME = 10 * 1000 EXT_DEVICE = 1 if a_packet_received: flow_emap.expire_all(now - EXP_TIME) h3 = pop_header(tcpudp, on_mismatch=([], [])) h2 = pop_header(ipv4, on_mismatch=([], [])) h1 = pop_header(ether, on_mismatch=([], [])) internal_flow = FlowIdc(h3.dst_port, h3.src_port, h2.daddr, h2.saddr, h2.npid) if received_on_port == EXT_DEVICE and flow_emap.has(internal_flow): fl_id = flow_emap.get(internal_flow) flow_emap.refresh_idx(fl_id, now) out_port = vector_get(int_devices, fl_id) return ([out_port], [ether(h1, saddr=..., daddr=...), ipv4(h2, cksum=...), tcpudp(h3)]) else: pass
from state import flow_emap EXP_TIME = 10 * 1000 EXT_IP_ADDR = ext_ip EXT_PORT = 1 if a_packet_received: flow_emap.expire_all(now - EXP_TIME) h3 = pop_header(tcpudp, on_mismatch=([], [])) h2 = pop_header(ipv4, on_mismatch=([], [])) h1 = pop_header(ether, on_mismatch=([], [])) internal_flow_id = FlowIdc(h3.src_port, h3.dst_port, h2.saddr, h2.daddr, received_on_port, h2.npid) if received_on_port != EXT_PORT and flow_emap.has(internal_flow_id): idx = flow_emap.get(internal_flow_id) flow_emap.refresh_idx(idx, now) return ([EXT_PORT], [ ether(h1, saddr=..., daddr=...), ipv4(h2, cksum=..., saddr=EXT_IP_ADDR), tcpudp(h3, src_port=idx + start_port) ]) else: pass
from state import flow_emap, flow_id_to_backend_id, backends, backend_ip_emap EXP_TIME = 10 * 1000 BACKEND_EXP_TIME = 3600000000 * 1000 EXT_PORT = 2 if a_packet_received: flow_emap.expire_all(now - EXP_TIME) backend_ip_emap.expire_all(now - BACKEND_EXP_TIME) h3 = pop_header(tcpudp, on_mismatch=([], [])) h2 = pop_header(ipv4, on_mismatch=([], [])) h1 = pop_header(ether, on_mismatch=([], [])) packet_flow = LoadBalancedFlowc(h2.saddr, h2.daddr, h3.src_port, h3.dst_port, h2.npid) if received_on_port == EXT_PORT and flow_emap.has(packet_flow): flow_id = flow_emap.get(packet_flow) backend_id = flow_id_to_backend_id.get(flow_id) if backend_ip_emap.has_idx(backend_id): flow_emap.refresh_idx(flow_emap.get(packet_flow), now) backend = backends.get(backend_id) return ([backend.nic], [ ether(h1, saddr=..., daddr=backend.mac), ipv4(h2, cksum=..., daddr=backend.ip), tcpudp(h3) ]) else: pass else: pass