X-Git-Url: http://git.cinelerra-gg.org/git/?a=blobdiff_plain;ds=inline;f=cinelerra-5.1%2Fguicast%2Fxfer.C;h=13f49f82975938d9ef8be647a1300a5e4c1c645b;hb=7a70932d3e04454177c456d0b42ee2f5318d6ad1;hp=87ad6bdd5b619971865f53a14f8a7b2b552722fc;hpb=1f78d86b5532943b2a3ea51f409a1fe5bd961e02;p=goodguy%2Fhistory.git diff --git a/cinelerra-5.1/guicast/xfer.C b/cinelerra-5.1/guicast/xfer.C index 87ad6bdd..13f49f82 100644 --- a/cinelerra-5.1/guicast/xfer.C +++ b/cinelerra-5.1/guicast/xfer.C @@ -265,14 +265,12 @@ BC_Xfer::SlicerList BC_Xfer::slicers; BC_Xfer::SlicerList::SlicerList() { - waiting = new Condition(0, "BC_Xfer::SlicerList", 1); count = 0; } BC_Xfer::SlicerList::~SlicerList() { reset(); - delete waiting; } void BC_Xfer::SlicerList::reset() @@ -285,24 +283,24 @@ void BC_Xfer::SlicerList::reset() BC_Xfer::Slicer *BC_Xfer::SlicerList::get_slicer(BC_Xfer *xp) { - while( !first ) { + Slicer *slicer = first; + if( !slicer ) { if( count < BC_Resources::machine_cpus ) { - append(new Slicer(xp)); + slicer = new Slicer(xp); ++count; } - else - waiting->lock("BC_Xfer::SlicerList::get_slicer"); } - Slicer *slicer = first; - remove_pointer(slicer); + else + remove_pointer(slicer); return slicer; } void BC_Xfer::xfer_slices(int slices) { if( !xfn ) return; - int max_slices = BC_Resources::machine_cpus/2+1; + int max_slices = BC_Resources::machine_cpus/2; if( slices > max_slices ) slices = max_slices; + if( slices < 1 ) slices = 1; Slicer *active[slices]; unsigned y0 = 0, y1 = out_h; int slices1 = slices-1; @@ -310,6 +308,7 @@ void BC_Xfer::xfer_slices(int slices) slicers.lock("BC_Xfer::xfer_slices"); for( int i=0; islice(this, y0, y1); @@ -324,7 +323,6 @@ void BC_Xfer::xfer_slices(int slices) for( int i=0; iunlock(); } }