112 lines
4.3 KiB
Python
112 lines
4.3 KiB
Python
# -*- mode:Python -*-
|
|
#
|
|
# This file is part of the Coriolis Software.
|
|
# Copyright (c) Sorbonne Université 2020-2021, All Rights Reserved
|
|
#
|
|
# +-----------------------------------------------------------------+
|
|
# | C O R I O L I S |
|
|
# | Alliance / Hurricane Interface |
|
|
# | |
|
|
# | Author : Jean-Paul Chaput |
|
|
# | E-mail : Jean-Paul.Chaput@lip6.fr |
|
|
# | =============================================================== |
|
|
# | Python : "./crlcore/helpers/technology.py" |
|
|
# +-----------------------------------------------------------------+
|
|
|
|
"""
|
|
Some helpers to create or load a technology and it's libraries.
|
|
"""
|
|
|
|
from Hurricane3 import DataBase, Layer, BasicLayer, ViaLayer
|
|
|
|
|
|
__all__ = [ 'safeGetLibrary', 'createBL', 'setEnclosures' ]
|
|
|
|
|
|
def safeGetLibrary ( frameworkName, libName ):
|
|
"""
|
|
Return the library named ``libName`` if it already exists,
|
|
or create it if needed. To avoid potential collision, design
|
|
kits libraries should not be created directly under the DataBase
|
|
root library but be grouped under a common technology library,
|
|
in this case ``CM018``.
|
|
"""
|
|
db = DataBase.getDB()
|
|
tech = db.getTechnology()
|
|
frameLib = db.getRootLibrary().getLibrary( frameworkName )
|
|
if frameLib is None:
|
|
frameLib = Library.create( db.getRootLibrary(), frameworkName )
|
|
lib = frameLib.getLibrary( libName )
|
|
if lib is None:
|
|
lib = Library.create( frameLib, libName )
|
|
return lib
|
|
|
|
|
|
def createBL ( tech, layerName, material, size=None, spacing=None, gds2Layer=None, gds2DataType=0, area=None ):
|
|
"""
|
|
Create a new BasicLayer. Parameters ``tech``, ``layerName`` and ``material``
|
|
are mandatory.
|
|
|
|
:param tech: The technology the basic layer will be part of.
|
|
:param layerName: The name of the layer.
|
|
:param material: The kind of layer, see BasicLayer.Material.
|
|
:param size: The minimal size (i.e. width).
|
|
:param spacing: The minimal distance, edge to edge between two wires.
|
|
:param gds2layer: The GDSII layer number (for the GDSII driver).
|
|
:param gds2DataType: The GDSII DataType (i.e purpose).
|
|
:param area: The minimum area (in um2)
|
|
"""
|
|
print( tech )
|
|
layer = BasicLayer.create( tech, layerName, BasicLayer.Material(material) )
|
|
if size is not None:
|
|
layer.setMinimalSize( size )
|
|
if spacing is not None:
|
|
layer.setMinimalSpacing( spacing )
|
|
if gds2Layer is not None:
|
|
layer.setGds2Layer ( gds2Layer )
|
|
layer.setGds2Datatype( gds2DataType )
|
|
if area is not None:
|
|
layer.setMinimalArea( area )
|
|
return layer
|
|
|
|
|
|
def createVia ( tech, viaName, botName, cutName, topName, size=None ):
|
|
"""
|
|
Create a new ViaLayer. Parameters ``tech``, ``viaName``, ``botName``,
|
|
``cutName`` and ``topName`` are mandatory.
|
|
|
|
:param tech: The technology the basic layer will be part of.
|
|
:param viaName: The name of the newly defined VIA layer.
|
|
:param botName: The name of the *bottom* metal layer.
|
|
:param cutName: The name of the *cut* (aka, via hole) layer.
|
|
:param topName: The name of the *top* metal layer.
|
|
:param size: The minimal side size of the square *cut* layer.
|
|
"""
|
|
layer = ViaLayer.create( tech
|
|
, viaName
|
|
, tech.getLayer(botName)
|
|
, tech.getLayer(cutName)
|
|
, tech.getLayer(topName) )
|
|
if size is not None:
|
|
layer.setMinimalSize( size )
|
|
return layer
|
|
|
|
|
|
def setEnclosures ( layer, subLayer, enclosures ):
|
|
"""
|
|
Set horizontal & vertical enclosure for a given ``subLayer`` in a
|
|
composite ``layer`` (typically a ViaLayer). If ``enclosures`` is a
|
|
number, both H/V will be set to that same value. If it is a tuple
|
|
(a pair), then the first value is horizontal and the seconf is
|
|
vertical.
|
|
"""
|
|
if isinstance(enclosures,tuple):
|
|
henclosure = enclosures[0]
|
|
venclosure = enclosures[1]
|
|
else:
|
|
henclosure = enclosures
|
|
venclosure = enclosures
|
|
layer.setEnclosure( subLayer, henclosure, Layer.EnclosureH )
|
|
layer.setEnclosure( subLayer, venclosure, Layer.EnclosureV )
|
|
return
|