read grid units

This commit is contained in:
Christophe Alexandre 2008-06-10 18:36:28 +00:00
parent 279ff2a2aa
commit b7bd1e19a4
5 changed files with 39 additions and 27 deletions

View File

@ -55,6 +55,7 @@ const Name Transistor::DrainName("DRAIN");
const Name Transistor::SourceName("SOURCE"); const Name Transistor::SourceName("SOURCE");
const Name Transistor::GridName("GRID"); const Name Transistor::GridName("GRID");
const Name Transistor::BulkName("BULK"); const Name Transistor::BulkName("BULK");
const Name Transistor::AnonymousName("ANONYMOUS");
Transistor::Transistor(Library* library, const Name& name, const Polarity& polarity): Transistor::Transistor(Library* library, const Name& name, const Polarity& polarity):
Cell(library, name), Cell(library, name),
@ -62,13 +63,15 @@ Transistor::Transistor(Library* library, const Name& name, const Polarity& polar
_source(NULL), _source(NULL),
_grid(NULL), _grid(NULL),
_bulk(NULL), _bulk(NULL),
_anonymous(NULL),
_polarity(polarity), _polarity(polarity),
_abutmentType(), _abutmentType(),
_l(DbU::Min), _l(DbU::Min),
_w(DbU::Min), _w(DbU::Min),
_source20(NULL), _source22(NULL), _source20(NULL), _source22(NULL),
_drain40(NULL), _drain42(NULL), _drain40(NULL), _drain42(NULL),
_grid00(NULL), _grid01(NULL), _grid30(NULL), _grid31(NULL) _grid00(NULL), _grid01(NULL), _grid30(NULL), _grid31(NULL),
_anonymous10(NULL), _anonymous11(NULL), _anonymous12(NULL)
{} {}
@ -92,6 +95,7 @@ void Transistor::_postCreate() {
_grid->setExternal(true); _grid->setExternal(true);
_bulk = Net::create(this, BulkName); _bulk = Net::create(this, BulkName);
_bulk->setExternal(true); _bulk->setExternal(true);
_anonymous = Net::create(this, AnonymousName);
_source20 = createPad(technology, _source, "cut0"); _source20 = createPad(technology, _source, "cut0");
_source22 = createPad(technology, _source, "cut1"); _source22 = createPad(technology, _source, "cut1");
_drain40 = createPad(technology, _drain, "cut0"); _drain40 = createPad(technology, _drain, "cut0");
@ -100,18 +104,20 @@ void Transistor::_postCreate() {
_grid01 = createPad(technology, _grid, "poly"); _grid01 = createPad(technology, _grid, "poly");
_grid30 = createPad(technology, _grid, "cut0"); _grid30 = createPad(technology, _grid, "cut0");
_grid31 = createPad(technology, _grid, "metal1"); _grid31 = createPad(technology, _grid, "metal1");
_anonymous10 = createPad(technology, _anonymous, "active");
_anonymous11 = createPad(technology, _anonymous, "nimp");
_anonymous12 = createPad(technology, _anonymous, "nimp");
} }
void Transistor::createLayout() { void Transistor::createLayout() {
ATechnology* techno = AEnv::getATechnology(); ATechnology* techno = AEnv::getATechnology();
DbU::Unit rwCont = DbU::real(techno->getPhysicalRule("RW_CONT")->getValue()); DbU::Unit rwCont = techno->getPhysicalRule("RW_CONT")->getValue();
DbU::Unit rdCont = DbU::real(techno->getPhysicalRule("RD_CONT")->getValue()); DbU::Unit rdCont = techno->getPhysicalRule("RD_CONT")->getValue();
DbU::Unit reGateActiv = DbU::real(techno->getPhysicalRule("RE", getLayer("poly"), getLayer("active"))->getValue()); DbU::Unit reGateActiv = techno->getPhysicalRule("RE", getLayer("poly"), getLayer("active"))->getValue();
DbU::Unit rePolyCont = DbU::real(techno->getPhysicalRule("RE", getLayer("poly"), getLayer("cut"))->getValue()); DbU::Unit rePolyCont = techno->getPhysicalRule("RE", getLayer("poly"), getLayer("cut"))->getValue();
DbU::Unit rdActiveCont = DbU::real(techno->getPhysicalRule("RD", getLayer("active"), getLayer("cut"))->getValue()); DbU::Unit rdActiveCont = techno->getPhysicalRule("RD", getLayer("active"), getLayer("cut"))->getValue();
DbU::Unit rdActivePoly = DbU::real(techno->getPhysicalRule("RD", getLayer("active"), getLayer("poly"))->getValue()); DbU::Unit rdActivePoly = techno->getPhysicalRule("RD", getLayer("active"), getLayer("poly"))->getValue();
UpdateSession::open(); UpdateSession::open();
@ -158,5 +164,7 @@ void Transistor::createLayout() {
dy01 = y31 - (y00 + dy00); dy01 = y31 - (y00 + dy00);
} }
//12
UpdateSession::close(); UpdateSession::close();
} }

View File

@ -13,6 +13,7 @@ class Transistor : public Cell {
static const Name SourceName; static const Name SourceName;
static const Name GridName; static const Name GridName;
static const Name BulkName; static const Name BulkName;
static const Name AnonymousName;
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};
@ -34,6 +35,7 @@ class Transistor : public Cell {
Net* _source; Net* _source;
Net* _grid; Net* _grid;
Net* _bulk; Net* _bulk;
Net* _anonymous;
Polarity _polarity; Polarity _polarity;
AbutmentType _abutmentType; AbutmentType _abutmentType;
DbU::Unit _l; DbU::Unit _l;
@ -41,6 +43,7 @@ class Transistor : public Cell {
Pad *_source20, *_source22; Pad *_source20, *_source22;
Pad *_drain40, *_drain42; Pad *_drain40, *_drain42;
Pad *_grid00, *_grid01, *_grid30, *_grid31; Pad *_grid00, *_grid01, *_grid30, *_grid31;
Pad *_anonymous10, *_anonymous11, *_anonymous12, *_anonymous50;
Transistor(Library* library, const Name& name, const Polarity& polarity); Transistor(Library* library, const Name& name, const Polarity& polarity);
}; };

View File

@ -27,7 +27,7 @@ string ATechnology::_getTypeName() const {
return _TName("ATechnologyProperty"); return _TName("ATechnologyProperty");
} }
void ATechnology::addPhysicalRule(const Name& name, double value, const string& reference) { void ATechnology::addPhysicalRule(const Name& name, DbU::Unit value, const string& reference) {
PhysicalRule searchPR(name, 0, ""); PhysicalRule searchPR(name, 0, "");
PhysicalRules::iterator prit = _noLayerPhysicalRules.find(&searchPR); PhysicalRules::iterator prit = _noLayerPhysicalRules.find(&searchPR);
if (prit != _noLayerPhysicalRules.end()) { if (prit != _noLayerPhysicalRules.end()) {
@ -37,7 +37,7 @@ void ATechnology::addPhysicalRule(const Name& name, double value, const string&
_noLayerPhysicalRules.insert(newPhysicalRule); _noLayerPhysicalRules.insert(newPhysicalRule);
} }
void ATechnology::addPhysicalRule(const Name& name, const Name& layerName, double value, const string& reference) { void ATechnology::addPhysicalRule(const Name& name, const Name& layerName, DbU::Unit value, const string& reference) {
Layer* layer = getLayer(layerName); Layer* layer = getLayer(layerName);
OneLayerPhysicalRules::iterator olprit = _oneLayerPhysicalRules.find(layer); OneLayerPhysicalRules::iterator olprit = _oneLayerPhysicalRules.find(layer);
if (olprit == _oneLayerPhysicalRules.end()) { if (olprit == _oneLayerPhysicalRules.end()) {
@ -59,7 +59,7 @@ void ATechnology::addPhysicalRule(const Name& name, const Name& layerName, doubl
} }
void ATechnology::addPhysicalRule(const Name& name, const Name& layer1Name, void ATechnology::addPhysicalRule(const Name& name, const Name& layer1Name,
const Name& layer2Name, double value, const string& reference) { const Name& layer2Name, DbU::Unit value, const string& reference) {
} }
ATechnology* ATechnology::create(Technology* technology) { ATechnology* ATechnology::create(Technology* technology) {

View File

@ -16,7 +16,7 @@ class ATechnology : public PrivateProperty {
class PhysicalRule { class PhysicalRule {
public: public:
PhysicalRule(const Name& name, PhysicalRule(const Name& name,
double value, DbU::Unit value,
const string& reference): const string& reference):
_name(name), _name(name),
_value(value), _value(value),
@ -26,7 +26,7 @@ class ATechnology : public PrivateProperty {
_value(physicalRule._value), _value(physicalRule._value),
_reference(physicalRule._reference) {} _reference(physicalRule._reference) {}
const Name _name; const Name _name;
const double _value; const DbU::Unit _value;
const string _reference; const string _reference;
double getValue() const { return _value; } double getValue() const { return _value; }
}; };
@ -68,10 +68,10 @@ class ATechnology : public PrivateProperty {
const PhysicalRule* getPhysicalRule(const Name& name) const; const PhysicalRule* getPhysicalRule(const Name& name) const;
const PhysicalRule* getPhysicalRule(const Name& name, const Layer* layer) const; const PhysicalRule* getPhysicalRule(const Name& name, const Layer* layer) const;
const PhysicalRule* getPhysicalRule(const Name& name, const Layer* layer1, const Layer* layer2) const; const PhysicalRule* getPhysicalRule(const Name& name, const Layer* layer1, const Layer* layer2) const;
void addPhysicalRule(const Name& name, double value, const string& reference); void addPhysicalRule(const Name& name, DbU::Unit value, const string& reference);
void addPhysicalRule(const Name& name, const Name& layerName, double value, const string& reference); void addPhysicalRule(const Name& name, const Name& layerName, DbU::Unit value, const string& reference);
void addPhysicalRule(const Name& name, const Name& layer1Name, void addPhysicalRule(const Name& name, const Name& layer1Name,
const Name& layer2Name, double value, const string& reference); const Name& layer2Name, DbU::Unit value, const string& reference);
Layer* getLayer(const Name& layerName); Layer* getLayer(const Name& layerName);
void print(); void print();

View File

@ -33,16 +33,17 @@ void readPhysicalRules(xmlNode* node, ATechnology* aTechnology) {
if (ruleNameC && valueC && refC) { if (ruleNameC && valueC && refC) {
string ruleName((const char*)ruleNameC); string ruleName((const char*)ruleNameC);
double value = atof((const char*)valueC); double value = atof((const char*)valueC);
DbU::Unit unitValue= DbU::real(value);
string reference((const char*)refC); string reference((const char*)refC);
if (layerC) { if (layerC) {
Name layerName((const char*)layerC); Name layerName((const char*)layerC);
aTechnology->addPhysicalRule(ruleName, layerName, value, reference); aTechnology->addPhysicalRule(ruleName, layerName, unitValue, reference);
} else if (layer1C && layer2C) { } else if (layer1C && layer2C) {
Name layer1Name((const char*)layer1C); Name layer1Name((const char*)layer1C);
Name layer2Name((const char*)layer2C); Name layer2Name((const char*)layer2C);
aTechnology->addPhysicalRule(ruleName, layer1Name, layer2Name, value, reference); aTechnology->addPhysicalRule(ruleName, layer1Name, layer2Name, unitValue, reference);
} else { } else {
aTechnology->addPhysicalRule(ruleName, value, reference); aTechnology->addPhysicalRule(ruleName, unitValue, reference);
} }
} else { } else {
syntaxError(""); syntaxError("");