progressing with Transistor Layout
This commit is contained in:
parent
53af9ae3b1
commit
de62ff741d
|
@ -2,7 +2,8 @@ PROJECT(CHAMSIN)
|
||||||
|
|
||||||
CMAKE_MINIMUM_REQUIRED(VERSION 2.4.0)
|
CMAKE_MINIMUM_REQUIRED(VERSION 2.4.0)
|
||||||
|
|
||||||
SET(CMAKE_MODULE_PATH "$ENV{HURRICANE_TOP}/share/cmake_modules/")
|
SET(CMAKE_MODULE_PATH "$ENV{HURRICANE_TOP}/share/cmake_modules/"
|
||||||
|
"$ENV{HURRICANE_TOP}/share/cmake_modules/")
|
||||||
|
|
||||||
FIND_PACKAGE(BISON REQUIRED)
|
FIND_PACKAGE(BISON REQUIRED)
|
||||||
FIND_PACKAGE(FLEX REQUIRED)
|
FIND_PACKAGE(FLEX REQUIRED)
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
INCLUDE_DIRECTORIES(${CHAMSIN_SOURCE_DIR}/src/dtr ${HURRICANE_INCLUDE_DIR} ${source_dir})
|
INCLUDE_DIRECTORIES(${CHAMSIN_SOURCE_DIR}/src/technology ${HURRICANE_INCLUDE_DIR})
|
||||||
|
|
||||||
ADD_LIBRARY(analogic SHARED
|
ADD_LIBRARY(analogic SHARED Transistor.cpp)
|
||||||
Transistor.cpp)
|
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(analogic dtr ${HURRICANE_LIBRARIES})
|
TARGET_LINK_LIBRARIES(analogic atechnology ${HURRICANE_LIBRARIES})
|
||||||
|
|
||||||
INSTALL(TARGETS analogic DESTINATION /lib)
|
INSTALL(TARGETS analogic DESTINATION /lib)
|
||||||
|
|
|
@ -1,14 +1,57 @@
|
||||||
#include "UpdateSession.h"
|
#include "UpdateSession.h"
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
|
||||||
|
#include "AEnv.h"
|
||||||
|
#include "ATechnology.h"
|
||||||
#include "Transistor.h"
|
#include "Transistor.h"
|
||||||
|
|
||||||
|
const Name Transistor::DrainName("DRAIN");
|
||||||
|
const Name Transistor::SourceName("SOURCE");
|
||||||
|
const Name Transistor::GridName("GRID");
|
||||||
|
const Name Transistor::BulkName("BULK");
|
||||||
|
|
||||||
|
Transistor::Transistor(Library* library, const Name& name, const Polarity& polarity):
|
||||||
|
Cell(library, name),
|
||||||
|
_drain(NULL),
|
||||||
|
_source(NULL),
|
||||||
|
_grid(NULL),
|
||||||
|
_bulk(NULL),
|
||||||
|
_polarity(polarity),
|
||||||
|
_abutmentType(),
|
||||||
|
_l(0.0),
|
||||||
|
_w(0.0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
Transistor* Transistor::create(Library* library, const Name& name, const Polarity& polarity) {
|
||||||
|
Transistor* transistor = new Transistor(library, name, polarity);
|
||||||
|
|
||||||
|
transistor->_postCreate();
|
||||||
|
|
||||||
|
return transistor;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Transistor::_postCreate() {
|
||||||
|
Inherit::_postCreate();
|
||||||
|
_drain = Net::create(this, DrainName);
|
||||||
|
_drain->setExternal(true);
|
||||||
|
_source = Net::create(this, SourceName);
|
||||||
|
_source->setExternal(true);
|
||||||
|
_grid = Net::create(this, GridName);
|
||||||
|
_grid->setExternal(true);
|
||||||
|
_bulk = Net::create(this, BulkName);
|
||||||
|
_bulk->setExternal(true);
|
||||||
|
}
|
||||||
|
|
||||||
void Transistor::createLayout() {
|
void Transistor::createLayout() {
|
||||||
|
ATechnology* techno = AEnv::getATechnology();
|
||||||
|
|
||||||
|
Unit rwCont = getUnit(techno->getPhysicalRule("RW_CONT")->getValue());
|
||||||
|
Unit rdCont = getUnit(techno->getPhysicalRule("RD_CONT")->getValue());
|
||||||
|
|
||||||
UpdateSession::open();
|
UpdateSession::open();
|
||||||
|
|
||||||
//Net* source = transistor->getSource();
|
|
||||||
//Net* drain = transistor->getDrain();
|
|
||||||
//Net* grid = transistor->getGrid();
|
|
||||||
|
|
||||||
UpdateSession::close();
|
UpdateSession::close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#ifndef TRANSISTOR_H
|
#ifndef TRANSISTOR_H
|
||||||
#define TRANSISTOR_H
|
#define TRANSISTOR_H
|
||||||
|
|
||||||
|
#include "Name.h"
|
||||||
#include "Cell.h"
|
#include "Cell.h"
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
|
||||||
|
@ -8,24 +9,36 @@ namespace Hurricane {
|
||||||
|
|
||||||
class Transistor : public Cell {
|
class Transistor : public Cell {
|
||||||
public:
|
public:
|
||||||
|
static const Name DrainName;
|
||||||
|
static const Name SourceName;
|
||||||
|
static const Name GridName;
|
||||||
|
static const Name BulkName;
|
||||||
enum Polarity {N=0, P=1};
|
enum Polarity {N=0, P=1};
|
||||||
enum AbutmentType { INTERNAL=0, LEFT=1, RIGHT=2, SINGLE=3};
|
enum AbutmentType { INTERNAL=0, LEFT=1, RIGHT=2, SINGLE=3};
|
||||||
|
|
||||||
static Transistor* create(Library* library, const Name& name, const Polarity& polarity);
|
static Transistor* create(Library* library, const Name& name, const Polarity& polarity);
|
||||||
void createLayout();
|
void createLayout();
|
||||||
|
|
||||||
bool isNmos() const { return polarity == N; };
|
bool isNmos() const { return _polarity == N; };
|
||||||
bool isPmos() const { return polarity == P; };
|
bool isPmos() const { return _polarity == P; };
|
||||||
bool isInternal() const { return abutmentType == INTERNAL; };
|
bool isInternal() const { return _abutmentType == INTERNAL; };
|
||||||
bool isLeft() const { return abutmentType == LEFT; };
|
bool isLeft() const { return _abutmentType == LEFT; };
|
||||||
bool isRight() const { return abutmentType == RIGHT; };
|
bool isRight() const { return _abutmentType == RIGHT; };
|
||||||
bool isSingle() const { return abutmentType == SINGLE; };
|
bool isSingle() const { return _abutmentType == SINGLE; };
|
||||||
|
protected:
|
||||||
|
void _postCreate();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Polarity polarity;
|
Net* _drain;
|
||||||
AbutmentType abutmentType;
|
Net* _source;
|
||||||
double l;
|
Net* _grid;
|
||||||
double w;
|
Net* _bulk;
|
||||||
|
Polarity _polarity;
|
||||||
|
AbutmentType _abutmentType;
|
||||||
|
double _l;
|
||||||
|
double _w;
|
||||||
|
|
||||||
|
Transistor(Library* library, const Name& name, const Polarity& polarity);
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
#include "DataBase.h"
|
#include "DataBase.h"
|
||||||
|
#include "Library.h"
|
||||||
#include "Technology.h"
|
#include "Technology.h"
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
|
||||||
|
@ -13,6 +14,7 @@ void AEnv::create(const char* technoFilePath) {
|
||||||
throw Error("");
|
throw Error("");
|
||||||
}
|
}
|
||||||
db = DataBase::create();
|
db = DataBase::create();
|
||||||
|
Library* rootLibrary = Library::create(db, Name("RootLibrary"));
|
||||||
Technology* techno = Technology::create(db, Name("AnalogicTechnology"));
|
Technology* techno = Technology::create(db, Name("AnalogicTechnology"));
|
||||||
ATechnologyXmlParser::parse(technoFilePath, techno);
|
ATechnologyXmlParser::parse(technoFilePath, techno);
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,12 +17,12 @@ string ATechnology::_getTypeName() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
void ATechnology::addPhysicalRule(const string& name, double value, const string& reference) {
|
void ATechnology::addPhysicalRule(const string& name, double value, const string& reference) {
|
||||||
PhysicalRules::iterator prit = physicalRules_.find(name);
|
PhysicalRules::iterator prit = _physicalRules.find(name);
|
||||||
if (prit != physicalRules_.end()) {
|
if (prit != _physicalRules.end()) {
|
||||||
throw Error("");
|
throw Error("");
|
||||||
}
|
}
|
||||||
PhysicalRule* newPhysicalRule = new PhysicalRule(name, value, reference);
|
PhysicalRule* newPhysicalRule = new PhysicalRule(name, value, reference);
|
||||||
physicalRules_[newPhysicalRule->name_] = newPhysicalRule;
|
_physicalRules[newPhysicalRule->_name] = newPhysicalRule;
|
||||||
}
|
}
|
||||||
|
|
||||||
ATechnology* ATechnology::create(Technology* technology) {
|
ATechnology* ATechnology::create(Technology* technology) {
|
||||||
|
@ -47,12 +47,20 @@ ATechnology* ATechnology::getATechnology(Technology* technology) {
|
||||||
void ATechnology::print() {
|
void ATechnology::print() {
|
||||||
cout << "Printing ATechnology" << endl;
|
cout << "Printing ATechnology" << endl;
|
||||||
cout << " o Physical Rules" << endl;
|
cout << " o Physical Rules" << endl;
|
||||||
for (PhysicalRules::iterator prit = physicalRules_.begin();
|
for (PhysicalRules::iterator prit = _physicalRules.begin();
|
||||||
prit != physicalRules_.end();
|
prit != _physicalRules.end();
|
||||||
prit++) {
|
prit++) {
|
||||||
PhysicalRule* physicalRule = prit->second;
|
PhysicalRule* physicalRule = prit->second;
|
||||||
cout << " - name = " << physicalRule->name_ <<
|
cout << " - name = " << physicalRule->_name <<
|
||||||
", value = " << physicalRule->value_ <<
|
", value = " << physicalRule->_value <<
|
||||||
", ref = " << physicalRule->reference_ << endl;
|
", ref = " << physicalRule->_reference << endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const ATechnology::PhysicalRule* ATechnology::getPhysicalRule(const string& name) {
|
||||||
|
PhysicalRules::iterator prit = _physicalRules.find(name);
|
||||||
|
if (prit == _physicalRules.end()) {
|
||||||
|
throw Error("Cannot find Physical Rule " + name);
|
||||||
|
}
|
||||||
|
return prit->second;
|
||||||
|
}
|
||||||
|
|
|
@ -17,32 +17,35 @@ class ATechnology : public PrivateProperty {
|
||||||
PhysicalRule(const string& name,
|
PhysicalRule(const string& name,
|
||||||
double value,
|
double value,
|
||||||
const string& reference):
|
const string& reference):
|
||||||
name_(name),
|
_name(name),
|
||||||
value_(value),
|
_value(value),
|
||||||
reference_(reference) {}
|
_reference(reference) {}
|
||||||
PhysicalRule(const PhysicalRule& physicalRule):
|
PhysicalRule(const PhysicalRule& physicalRule):
|
||||||
name_(physicalRule.name_),
|
_name(physicalRule._name),
|
||||||
value_(physicalRule.value_),
|
_value(physicalRule._value),
|
||||||
reference_(physicalRule.reference_) {}
|
_reference(physicalRule._reference) {}
|
||||||
const string name_;
|
const string _name;
|
||||||
const double value_;
|
const double _value;
|
||||||
const string reference_;
|
const string _reference;
|
||||||
|
double getValue() const { return _value; }
|
||||||
};
|
};
|
||||||
typedef map<string, ATechnology::PhysicalRule*> PhysicalRules;
|
typedef map<string, ATechnology::PhysicalRule*> PhysicalRules;
|
||||||
static ATechnology* create(Hurricane::Technology* technology);
|
static ATechnology* create(Hurricane::Technology* technology);
|
||||||
static ATechnology* getATechnology(Hurricane::Technology* technology);
|
static ATechnology* getATechnology(Hurricane::Technology* technology);
|
||||||
const PhysicalRule* getPhysicalRule(string name);
|
const PhysicalRule* getPhysicalRule(const string& name);
|
||||||
void addPhysicalRule(const string& name, double value, const string& reference);
|
void addPhysicalRule(const string& name, double value, const string& reference);
|
||||||
void print();
|
void print();
|
||||||
|
|
||||||
virtual Name getName() const;
|
virtual Name getName() const;
|
||||||
|
|
||||||
virtual string _getTypeName() const;
|
virtual string _getTypeName() const;
|
||||||
|
|
||||||
ATechnology():
|
ATechnology():
|
||||||
Inherit(),
|
Inherit(),
|
||||||
physicalRules_() {}
|
_physicalRules() {}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
PhysicalRules physicalRules_;
|
PhysicalRules _physicalRules;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* ATECHNOLOGY_H_*/
|
#endif /* ATECHNOLOGY_H_*/
|
||||||
|
|
|
@ -1,12 +1,14 @@
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
#include "DBo.h"
|
|
||||||
#include "Warning.h"
|
#include "Warning.h"
|
||||||
#include "Error.h"
|
#include "Error.h"
|
||||||
|
#include "DataBase.h"
|
||||||
|
#include "Library.h"
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
|
||||||
#include "AEnv.h"
|
#include "AEnv.h"
|
||||||
#include "ATechnology.h"
|
#include "ATechnology.h"
|
||||||
|
#include "Transistor.h"
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
int main(int argc, char* argv[]) {
|
||||||
|
@ -17,11 +19,17 @@ int main(int argc, char* argv[]) {
|
||||||
exit(56);
|
exit(56);
|
||||||
}
|
}
|
||||||
AEnv::create(argv[1]);
|
AEnv::create(argv[1]);
|
||||||
|
DataBase* db = getDataBase();
|
||||||
|
Library* rootLibrary = db->getRootLibrary();
|
||||||
|
Library* userLibrary = Library::create(rootLibrary, Name("USER"));
|
||||||
|
|
||||||
ATechnology* aTechnology = AEnv::getATechnology();
|
ATechnology* aTechnology = AEnv::getATechnology();
|
||||||
if (!aTechnology) {
|
if (!aTechnology) {
|
||||||
exit(56);
|
exit(56);
|
||||||
}
|
}
|
||||||
aTechnology->print();
|
aTechnology->print();
|
||||||
|
Transistor* trans = Transistor::create(userLibrary, Name("TEST"), Transistor::P);
|
||||||
|
cerr << trans << endl;
|
||||||
exit(0);
|
exit(0);
|
||||||
} catch (Hurricane::Warning& w) {
|
} catch (Hurricane::Warning& w) {
|
||||||
cerr << w.what() << endl;
|
cerr << w.what() << endl;
|
||||||
|
|
|
@ -4,6 +4,6 @@ ${CHAMSIN_SOURCE_DIR}/src/analogic ${CHAMSIN_SOURCE_DIR}/src/device)
|
||||||
|
|
||||||
ADD_EXECUTABLE(atest AnalogicTest.cpp)
|
ADD_EXECUTABLE(atest AnalogicTest.cpp)
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(atest atechnology ${HURRICANE_LIBRARIES})
|
TARGET_LINK_LIBRARIES(atest atechnology analogic ${HURRICANE_LIBRARIES})
|
||||||
|
|
||||||
INSTALL(TARGETS atest DESTINATION /bin)
|
INSTALL(TARGETS atest DESTINATION /bin)
|
||||||
|
|
Loading…
Reference in New Issue