Как скопировать список ячеек между библиотеками и переименовать справочную библиотеку с помощью Cadence SKILL

Мне нужен был скрипт SKILL для копирования макета нескольких ячеек из одной библиотеки в другую, а затем переименования справочной библиотеки. Так я написал один:)

1 ответ

;Copy list of cells
procedure(copycells(source_lib destination_lib)
let( ( cell_list old_cell new_cell call_name oldSpec newSpec specList destination_lib objId)
    cell_list=list(
        "HV_driver_dc2dc_fb" "dc2dc" "dc2dc_comparator" "dc2dc_core" "dc2dc_fb_cap_divider" "dc2dc_hv_curr_src" "dc2dc_low_side_switch_logic"
        "dc2dc_ls_iso" "dc2dc_ocp_comparator" "dc2dc_ref_voltage_selector" "dc2dc_switch_and_diode" "dc2dc_top" "dc2dc_tst_tg"
        "dc2dc_vref_amp" "dc2dc_vref_preamp" "doubler" "doubler_aux_bottom_driver" "doubler_core" "doubler_main_bottom_driver"
        "doubler_main_cap" "dcdc_tst_mux" "dcdc_t6_tst_mux_tg_esd" "dcdc_t6_tst_mux_tg"
    )

    specList = gdmCreateSpecList();Speclist for rename reference library function

    foreach(call_name cell_list
        ;This part needed only for version control managed labraries
        objId = ddGetObj( destination_lib call_name "layout" "*" );;Get objId for layout view

        unless( objId
            error( "** Unable to get objId of %s %s layout\n" destination_lib call_name )
        );unless
        when( ddNeedCheckout(objId)  ;If ccheckout needed old commend ufIsObjectCheckedIn(objId)
            printf("Checking out %s cellView of %s %s\n " "layout" destination_lib  call_name)

            unless(ddCheckout(objId);Check out
                error( "** Unable to get check out %s %s %s\n" destination_lib  call_name "layout")
            );unless
        );when
        ;check out end

        old_cell = dbOpenCellViewByType( source_lib call_name "layout" );Source cell
        unless(old_cell error("Unable to open old cell"))
        printf("Copy %s %s to %s %s\n" source_lib call_name destination_lib call_name)
        new_cell= dbCopyCellView( old_cell destination_lib call_name "layout" nil nil t );Copy cell
        unless(new_cell error("Unable to copy %s" call_name))
        dbClose(old_cell);Close old ce;;
        dbClose(new_cell);Close new cell
        gdmAddSpecToSpecList(gdmCreateSpecFromDDID(ddGetObj(destination_lib call_name "layout")) specList);Add cell to SPEC list
    );foreach
    oldSpec = gdmCreateSpec( source_lib "" "" "" "CDBA" );Spec of source lib
    newSpec = gdmCreateSpec( destination_lib "" "" "" "CDBA" );Spec of destination lib
    ccpRenameReferenceLib(oldSpec newSpec specList 'CCP_VALID_BOTH_REFS);Rename reference library for target cells
);let );copycells
Другие вопросы по тегам