/* $Id: delta.cpp,v 1.4 2006-11-05 04:42:43 ganzhorn Exp $ * This file is part of lfhex. * Copyright (C) 2006 Salem Ganzhorn * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation version 2. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "delta.hpp" // // DeltaMap class implimentation: // DeltaMap::DeltaMap() {} // noop DeltaMap::~DeltaMap() { // just free all of the Delta's clear(); } // Free all the Delta's // Note: this invalidates all pointers to Delta's returned through search() // do NOT keep returned pointers arround for long. // void DeltaMap::clear() { _map.erase(_map.begin(),_map.end()); // note: the union of _undo and _redo should contain ALL of the Delta's // in the map. The intersection of _undo and _redo should be the empty set. while ( !_undo.empty() ) { delete _undo.top(); _undo.pop(); } while ( !_redo.empty() ) { delete _redo.top(); _redo.pop(); } } // returns const ptr to the most recent delta on offset off_t const Delta * DeltaMap::search( off_t offset ) const { delta_map_t::const_iterator itr = _map.find(offset); if ( itr != _map.end() && (itr->second).size() ) return itr->second.back(); else return 0; } size_t DeltaMap::insert( off_t offset, const vector& oldData, const vector& newData ) { // // only modify the newData of the top undo iff the offsets match // and the redo stack is empty. // if( _undo.size() && _undo.top()->offset() == offset && _redo.empty() ) { //just modify the newData of the top delta _undo.top()->setNewData( newData ); // _map[offset] _should_ exist return _map[offset].size(); } else { // create a new delta Delta * tmp = new Delta(offset, oldData, newData); _map[offset].push_back( tmp ); _undo.push( tmp ); return _map[offset].size(); } } bool DeltaMap::undo() { if( _undo.empty() ) return false; Delta* d = _undo.top(); _undo.pop(); // find the delta in the delta list indexed by d->offset and remove it. map >::iterator itr = _map.find(d->offset()); itr->second.remove(d); // remove the entry iff the list is empty if( itr->second.empty() ) { _map.erase(itr); } // push the delta back onto the redo stack. _redo.push( d ); return true; } bool DeltaMap::redo() { if( _redo.empty() ) return false; // insert the delta back into the modification list Delta *d = _redo.top(); _redo.pop(); _map[d->offset()].push_back( d ); _undo.push( d ); return true; } // methods for iterating over all the modifications in the tree off_t DeltaMap::lower_bound(off_t lb) const { delta_map_t::const_iterator itr = _map.lower_bound(lb); if( itr == _map.end() ) { return -1; } else { return itr->first; } } s-private-remove&id=433e19cf33d34bb6751c874a9c00980552fe508c'>xfrm_hash.h
diff options
context:
space:
mode:
authorDexuan Cui <decui@microsoft.com>2017-01-28 11:46:02 -0700
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-01-31 10:59:48 +0100
commit433e19cf33d34bb6751c874a9c00980552fe508c (patch)
treece6547ef2987fbb289fa28f03536328a42781651 /net/xfrm/xfrm_hash.h
parent191e885a2e130e639bb0c8ee350d7047294f2ce6 (diff)
Drivers: hv: vmbus: finally fix hv_need_to_signal_on_read()
Commit a389fcfd2cb5 ("Drivers: hv: vmbus: Fix signaling logic in hv_need_to_signal_on_read()") added the proper mb(), but removed the test "prev_write_sz < pending_sz" when making the signal decision. As a result, the guest can signal the host unnecessarily, and then the host can throttle the guest because the host thinks the guest is buggy or malicious; finally the user running stress test can perceive intermittent freeze of the guest. This patch brings back the test, and properly handles the in-place consumption APIs used by NetVSC (see get_next_pkt_raw(), put_pkt_raw() and commit_rd_index()). Fixes: a389fcfd2cb5 ("Drivers: hv: vmbus: Fix signaling logic in hv_need_to_signal_on_read()") Signed-off-by: Dexuan Cui <decui@microsoft.com> Reported-by: Rolf Neugebauer <rolf.neugebauer@docker.com> Tested-by: Rolf Neugebauer <rolf.neugebauer@docker.com> Cc: "K. Y. Srinivasan" <kys@microsoft.com> Cc: Haiyang Zhang <haiyangz@microsoft.com> Cc: Stephen Hemminger <sthemmin@microsoft.com> Cc: <stable@vger.kernel.org> Signed-off-by: K. Y. Srinivasan <kys@microsoft.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'net/xfrm/xfrm_hash.h')