forked from OSchip/llvm-project
parent
6ad2444d5b
commit
aeed39774d
|
@ -56,12 +56,9 @@ void ScopLib::initializeParameters() {
|
||||||
void ScopLib::initializeArrays() {
|
void ScopLib::initializeArrays() {
|
||||||
int nb_arrays = 0;
|
int nb_arrays = 0;
|
||||||
|
|
||||||
for (Scop::iterator SI = PollyScop->begin(), SE = PollyScop->end(); SI != SE;
|
for (ScopStmt *Stmt : *PollyScop)
|
||||||
++SI)
|
for (MemoryAccess *MA : *Stmt) {
|
||||||
for (ScopStmt::memacc_iterator MI = (*SI)->memacc_begin(),
|
const Value *BaseAddr = MA->getBaseAddr();
|
||||||
ME = (*SI)->memacc_end();
|
|
||||||
MI != ME; ++MI) {
|
|
||||||
const Value *BaseAddr = (*MI)->getBaseAddr();
|
|
||||||
if (ArrayMap.find(BaseAddr) == ArrayMap.end()) {
|
if (ArrayMap.find(BaseAddr) == ArrayMap.end()) {
|
||||||
ArrayMap.insert(std::make_pair(BaseAddr, nb_arrays));
|
ArrayMap.insert(std::make_pair(BaseAddr, nb_arrays));
|
||||||
++nb_arrays;
|
++nb_arrays;
|
||||||
|
@ -447,17 +444,16 @@ scoplib_matrix_p ScopLib::createAccessMatrix(ScopStmt *S, bool isRead) {
|
||||||
unsigned NbColumns = S->getNumIterators() + S->getNumParams() + 2;
|
unsigned NbColumns = S->getNumIterators() + S->getNumParams() + 2;
|
||||||
scoplib_matrix_p m = scoplib_matrix_malloc(0, NbColumns);
|
scoplib_matrix_p m = scoplib_matrix_malloc(0, NbColumns);
|
||||||
|
|
||||||
for (ScopStmt::memacc_iterator MI = S->memacc_begin(), ME = S->memacc_end();
|
for (MemoryAccess *MA : *S)
|
||||||
MI != ME; ++MI)
|
if (MA->isRead() == isRead) {
|
||||||
if ((*MI)->isRead() == isRead) {
|
|
||||||
// Extract the access function.
|
// Extract the access function.
|
||||||
isl_map *AccessRelation = (*MI)->getAccessRelation();
|
isl_map *AccessRelation = MA->getAccessRelation();
|
||||||
isl_map_foreach_basic_map(AccessRelation, &accessToMatrix_basic_map, m);
|
isl_map_foreach_basic_map(AccessRelation, &accessToMatrix_basic_map, m);
|
||||||
isl_map_free(AccessRelation);
|
isl_map_free(AccessRelation);
|
||||||
|
|
||||||
// Set the index of the memory access base element.
|
// Set the index of the memory access base element.
|
||||||
std::map<const Value *, int>::iterator BA =
|
std::map<const Value *, int>::iterator BA =
|
||||||
ArrayMap.find((*MI)->getBaseAddr());
|
ArrayMap.find(MA->getBaseAddr());
|
||||||
SCOPVAL_set_si(m->p[m->NbRows - 1][0], (*BA).second + 1);
|
SCOPVAL_set_si(m->p[m->NbRows - 1][0], (*BA).second + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,6 @@
|
||||||
#include "llvm/Support/Path.h"
|
#include "llvm/Support/Path.h"
|
||||||
#include "llvm/Support/Program.h"
|
#include "llvm/Support/Program.h"
|
||||||
#include "llvm/Support/MemoryBuffer.h"
|
#include "llvm/Support/MemoryBuffer.h"
|
||||||
#include "llvm/Support/system_error.h"
|
|
||||||
#include "llvm/ADT/SmallString.h"
|
#include "llvm/ADT/SmallString.h"
|
||||||
|
|
||||||
#include "isl/space.h"
|
#include "isl/space.h"
|
||||||
|
@ -37,6 +36,7 @@
|
||||||
#include "isl/constraint.h"
|
#include "isl/constraint.h"
|
||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
#include <system_error>
|
||||||
|
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
using namespace polly;
|
using namespace polly;
|
||||||
|
@ -253,14 +253,16 @@ void Pocc::printScop(raw_ostream &OS) const {
|
||||||
|
|
||||||
OS << "\n";
|
OS << "\n";
|
||||||
|
|
||||||
if (error_code ec = MemoryBuffer::getFile(PlutoStdout.str(), stdoutBuffer))
|
if (std::error_code ec =
|
||||||
|
MemoryBuffer::getFile(PlutoStdout.str(), stdoutBuffer))
|
||||||
OS << "Could not open pocc stdout file: " + ec.message() << "\n";
|
OS << "Could not open pocc stdout file: " + ec.message() << "\n";
|
||||||
else {
|
else {
|
||||||
OS << "pocc stdout: " << stdoutBuffer->getBufferIdentifier() << "\n";
|
OS << "pocc stdout: " << stdoutBuffer->getBufferIdentifier() << "\n";
|
||||||
OS << stdoutBuffer->getBuffer() << "\n";
|
OS << stdoutBuffer->getBuffer() << "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (error_code ec = MemoryBuffer::getFile(PlutoStderr.str(), stderrBuffer))
|
if (std::error_code ec =
|
||||||
|
MemoryBuffer::getFile(PlutoStderr.str(), stderrBuffer))
|
||||||
OS << "Could not open pocc stderr file: " + ec.message() << "\n";
|
OS << "Could not open pocc stderr file: " + ec.message() << "\n";
|
||||||
else {
|
else {
|
||||||
OS << "pocc stderr: " << PlutoStderr << "\n";
|
OS << "pocc stderr: " << PlutoStderr << "\n";
|
||||||
|
|
Loading…
Reference in New Issue