/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */ /* *************************************************************************** * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. * * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * As a special exception, you may use this file as part of a free software * library without restriction. Specifically, if other files instantiate * templates or use macros or inline functions from this file, or you compile * this file and link it with other files to produce an executable, this * file does not by itself cause the resulting executable to be covered by * the GNU General Public License. This exception does not however * invalidate any other reasons why the executable file might be covered by * the GNU General Public License. * **************************************************************************** */ /* * The program is a simple map used: * 1. as a software accelerator (mapSA) * 2. to compute just one single task (mapOneShot). * */ #include #include #include #include using namespace ff; // this is the map function void* mapF(basePartitioner*const P, int tid) { LinearPartitioner* const partitioner=(LinearPartitioner* const)P; LinearPartitioner::partition_t Partition; partitioner->getPartition(tid, Partition); int* p = (int*)Partition.getData(); // gets the pointer to the first element of the partion size_t l = Partition.getLength(); // gets the length of the partion for(size_t i=0;i P(arraySize,nworkers); // defining the map passing as parameter the function called // within each worker and the partitioner that has to be used // to create the worker partitions ff_map mapSA(mapF,&P, NULL, true); // the 4rd parameter enable the accelerator mode mapSA.run(); printf("\nmapSA:\n"); for(int i=0;i<10;++i) { // create a task int* A=new int[arraySize]; for(int j=0;j