Product Version 20.10 March 2020

© 2013-2020 Cadence Design Systems, Inc. All rights reserved. Printed in the United States of America.

Cadence Design Systems, Inc. (Cadence), 2655 Seely Ave., San Jose, CA 95134, USA.

Open SystemC, Open SystemC Initiative, OSCI, SystemC, and SystemC Initiative are trademarks or registered trademarks of Open SystemC Initiative, Inc. in the United States and other countries and are used with permission.

**Trademarks:** Trademarks and service marks of Cadence Design Systems, Inc. (Cadence) contained in this document are attributed to Cadence with the appropriate symbol. For queries regarding Cadence's trademarks, contact the corporate legal department at the address shown above or call 800.862.4522.

All other trademarks are the property of their respective holders.

**Restricted Permission:** This publication is protected by copyright law and international treaties and contains trade secrets and proprietary information owned by Cadence. Unauthorized reproduction or distribution of this publication, or any portion of it, may result in civil and criminal penalties. Except as specified in this permission statement, this publication may not be copied, reproduced, modified, published, uploaded, posted, transmitted, or distributed in any way, without prior written permission from Cadence. Unless otherwise agreed to by Cadence in writing, this statement grants Cadence customers permission to print one (1) hard copy of this publication subject to the following conditions:

- 1. The publication may be used only in accordance with a written agreement between Cadence and its customer.
- 2. The publication may not be modified in any way.
- 3. Any authorized copy of the publication or portion thereof must include all original copyright, trademark, and other proprietary notices and this permission statement.
- 4. The information contained in this document cannot be used in the development of like products or software, whether for internal or external use, and shall not be used for the benefit of any other party, whether or not for consideration.

**Disclaimer:** Information in this publication is subject to change without notice and does not represent a commitment on the part of Cadence. Except as may be explicitly set forth in such agreement, Cadence does not make, and expressly disclaims, any representations or warranties as to the completeness, accuracy or usefulness of the information contained in this document. Cadence does not warrant that use of such information will not infringe any third party rights, nor does Cadence assume any liability for damages or costs of any kind that may result from use of such information.

**Restricted Rights:** Use, duplication, or disclosure by the Government is subject to restrictions as set forth in FAR52.227-14 and DFAR252.227-7013 et seg. or its successor.

# Innovus Stylus Common UI Error Message Reference Table of Contents

# **Contents**

| 1                          | 54 |
|----------------------------|----|
| Error and Warning Messages | 54 |
| CHKCTS-1                   | 54 |
| CHKCTS-2                   | 54 |
| CHKCTS-3                   | 55 |
| CHKCTS-4                   | 55 |
| CHKCTS-5                   | 56 |
| CHKCTS-6                   | 56 |
| CHKCTS-9                   | 57 |
| CHKCTS-10                  | 57 |
| CHKCTS-12                  | 58 |
| CHKCTS-13                  | 58 |
| CHKCTS-14                  | 59 |
| CHKCTS-15                  | 59 |
| CHKCTS-16                  | 60 |
| CHKCTS-17                  | 60 |
| CHKCTS-18                  | 61 |
| CHKCTS-19                  | 61 |
| CHKCTS-20                  | 62 |
| CHKCTS-21                  | 62 |
| CHKCTS-22                  | 63 |
| CHKCTS-23                  | 63 |
| CHKCTS-24                  | 64 |
| CHKCTS-25                  | 64 |
| CHKCTS-29                  | 65 |
| CHKCTS-30                  | 65 |
| CHKCTS-31                  | 66 |
| CHKCTS-32                  | 66 |
| CHKCTS-37                  | 67 |
| CHKCTS-38                  | 67 |
| CHKCTS-39                  | 68 |
| CHKCTS-40                  | 68 |
| CHKCTS-41                  | 69 |

| CHKCTS-42       | 69 |
|-----------------|----|
| CHKCTS-43       | 70 |
| CHKCTS-44       | 70 |
| CHKCTS-45       | 71 |
| CHKCTS-46       | 71 |
| CHKCTS-48       | 72 |
| CHKCTS-50       | 72 |
| CHKCTS-51       | 73 |
| CHKCTS-53       | 73 |
| CHKCTS-54       | 74 |
| CHKCTS-55       | 74 |
| CHKCTS-56       | 75 |
| CHKCTS-58       | 75 |
| CHKPTNFEED-90   | 76 |
| CHKPTNFEED-100  | 77 |
| CHKPTNFEED-233  | 78 |
| CHKPTNFEED-426  | 79 |
| CHKPTNFEED-427  | 80 |
| CHKPTNFEED-428  | 80 |
| CHKPTNFEED-429  | 81 |
| CHKPTNFEED-555  | 82 |
| CHKPTNFEED-624  | 83 |
| CHKPTNFEED-646  | 84 |
| CHKPTNFEED-647  | 84 |
| CHKPTNFEED-652  | 85 |
| CHKPTNFEED-716  | 85 |
| CHKPTNFEED-780  | 86 |
| CHKPTNFEED-882  | 87 |
| CHKPTNFEED-946  | 88 |
| CHKPTNFEED-1211 | 88 |
| CHKPTNFEED-1250 | 89 |
| CHKPTNFEED-1520 | 89 |
| CHKPTNFEED-1521 | 90 |
| CHKPTNFEED-1550 | 90 |
| CHKPTNFEED-1669 | 91 |
| CHKPTNFEED-1671 | 92 |
| CHKPTNFEED-1699 | 93 |

| CHKPTNFEED-1704 | 93  |
|-----------------|-----|
| CHKPTNFEED-1717 | 94  |
| CHKPTNFEED-1755 | 95  |
| CHKPTNFEED-1802 | 97  |
| CHKPTNFEED-3207 | 97  |
| CHKPTNPIN-90    | 98  |
| CHKPTNPIN-100   | 100 |
| CHKPTNPIN-233   | 100 |
| CHKPTNPIN-426   | 101 |
| CHKPTNPIN-427   | 102 |
| CHKPTNPIN-428   | 103 |
| CHKPTNPIN-429   | 103 |
| CHKPTNPIN-555   | 104 |
| CHKPTNPIN-624   | 105 |
| CHKPTNPIN-646   | 106 |
| CHKPTNPIN-647   | 106 |
| CHKPTNPIN-652   | 107 |
| CHKPTNPIN-716   | 108 |
| CHKPTNPIN-780   | 108 |
| CHKPTNPIN-882   | 109 |
| CHKPTNPIN-946   | 110 |
| CHKPTNPIN-1211  | 110 |
| CHKPTNPIN-1250  | 111 |
| CHKPTNPIN-1520  | 112 |
| CHKPTNPIN-1521  | 112 |
| CHKPTNPIN-1550  | 113 |
| CHKPTNPIN-1669  | 113 |
| CHKPTNPIN-1671  | 115 |
| CHKPTNPIN-1699  | 115 |
| CHKPTNPIN-1704  | 116 |
| CHKPTNPIN-1717  | 116 |
| CHKPTNPIN-1755  | 118 |
| CHKPTNPIN-1802  | 119 |
| CHKPTNPIN-3207  | 120 |
| CHKTB-2         | 120 |
| CHKTB-36        | 122 |
| CHKTB-178       | 122 |

| CHKTB-521     | 123 |
|---------------|-----|
| CHKTB-522     | 123 |
| IMPAFP-1873   | 124 |
| IMPAFP-1909   | 124 |
| IMPAFP-2031   | 125 |
| IMPAFP-3353   | 126 |
| IMPAFP-3928   | 127 |
| IMPAFP-3952   | 128 |
| IMPAFP-5000   | 128 |
| IMPAFP-5002   | 129 |
| IMPAFP-5029   | 130 |
| IMPAFP-9003   | 131 |
| IMPAFP-9021   | 132 |
| IMPAFP-9117   | 132 |
| IMPAFP-9641   | 133 |
| IMPAFP-9642   | 134 |
| IMPAFP-9643   | 134 |
| IMPAFP-9644   | 135 |
| IMPAFP-9645   | 136 |
| IMPAFP-9649   | 137 |
| IMPAFP-9801   | 138 |
| IMPAFP-9805   | 139 |
| IMPAFP-9811   | 139 |
| IMPAFPU-3817  | 140 |
| IMPAFPU-3819  | 140 |
| IMPAFPU-9005  | 141 |
| IMPAFPU-9201  | 141 |
| IMPAFPU-9202  | 142 |
| IMPCCD-3001   | 142 |
| IMPCCOPT-1007 | 143 |
| IMPCCOPT-1013 | 144 |
| IMPCCOPT-1014 | 145 |
| IMPCCOPT-1020 | 145 |
| IMPCCOPT-1021 | 146 |
| IMPCCOPT-1023 | 147 |
| IMPCCOPT-1026 | 147 |
| IMPCCOPT-1033 | 148 |

| IMPCCOPT-1038 | 149 |
|---------------|-----|
| IMPCCOPT-1041 | 149 |
| IMPCCOPT-1051 | 150 |
| IMPCCOPT-1052 | 150 |
| IMPCCOPT-1053 | 151 |
| IMPCCOPT-1062 | 151 |
| IMPCCOPT-1070 | 152 |
| IMPCCOPT-1071 | 152 |
| IMPCCOPT-1072 | 153 |
| IMPCCOPT-1073 | 153 |
| IMPCCOPT-1074 | 154 |
| IMPCCOPT-1075 | 154 |
| IMPCCOPT-1080 | 155 |
| IMPCCOPT-1081 | 155 |
| IMPCCOPT-1088 | 156 |
| IMPCCOPT-1089 | 156 |
| IMPCCOPT-1090 | 157 |
| IMPCCOPT-1092 | 157 |
| IMPCCOPT-1093 | 158 |
| IMPCCOPT-1107 | 158 |
| IMPCCOPT-1154 | 159 |
| IMPCCOPT-1157 | 159 |
| IMPCCOPT-1173 | 160 |
| IMPCCOPT-1174 | 160 |
| IMPCCOPT-1195 | 161 |
| IMPCCOPT-1209 | 161 |
| IMPCCOPT-1239 | 162 |
| IMPCCOPT-1241 | 162 |
| IMPCCOPT-1247 | 163 |
| IMPCCOPT-1260 | 163 |
| IMPCCOPT-1261 | 164 |
| IMPCCOPT-1262 | 164 |
| IMPCCOPT-1263 | 165 |
| IMPCCOPT-1274 | 165 |
| IMPCCOPT-1275 | 166 |
| IMPCCOPT-1278 | 166 |
| IMPCCOPT-1279 | 167 |

| IMPCCOPT-1280 | 167 |
|---------------|-----|
| IMPCCOPT-1281 | 168 |
| IMPCCOPT-1282 | 168 |
| IMPCCOPT-1287 | 169 |
| IMPCCOPT-1288 | 169 |
| IMPCCOPT-1289 | 170 |
| IMPCCOPT-1299 | 170 |
| IMPCCOPT-1314 | 171 |
| IMPCCOPT-1315 | 171 |
| IMPCCOPT-1316 | 172 |
| IMPCCOPT-1317 | 172 |
| IMPCCOPT-1322 | 173 |
| IMPCCOPT-1348 | 173 |
| IMPCCOPT-1368 | 174 |
| IMPCCOPT-1372 | 174 |
| IMPCCOPT-1373 | 175 |
| IMPCCOPT-1405 | 175 |
| IMPCCOPT-1470 | 176 |
| IMPCCOPT-1471 | 176 |
| IMPCCOPT-2001 | 177 |
| IMPCCOPT-2006 | 177 |
| IMPCCOPT-2023 | 178 |
| IMPCCOPT-2024 | 178 |
| IMPCCOPT-2025 | 179 |
| IMPCCOPT-2026 | 179 |
| IMPCCOPT-2027 | 180 |
| IMPCCOPT-2267 | 180 |
| IMPCCOPT-2319 | 181 |
| IMPCCOPT-2327 | 181 |
| IMPCCOPT-2347 | 182 |
| IMPCCOPT-2393 | 182 |
| IMPCCOPT-2396 | 183 |
| IMPCCOPT-2400 | 183 |
| IMPCCOPT-3084 | 184 |
| IMPCCOPT-3085 | 184 |
| IMPCCOPT-4144 | 185 |
| IMPCCOPT-4156 | 185 |

| IMPCCOPT-4196 | 186 |
|---------------|-----|
| IMPCCOPT-4205 | 186 |
| IMPCCOPT-4232 | 187 |
| IMPCCOPT-4245 | 187 |
| IMPCCOPT-4246 | 188 |
| IMPCCOPT-4251 | 188 |
| IMPCCOPT-4318 | 189 |
| IMPCCOPT-4319 | 189 |
| IMPCCOPT-4320 | 190 |
| IMPCCOPT-4321 | 190 |
| IMPCCOPT-4322 | 191 |
| IMPCCOPT-4323 | 191 |
| IMPCCOPT-4324 | 192 |
| IMPCCOPT-4325 | 193 |
| IMPCCOPT-4327 | 193 |
| IMPCCOPT-4338 | 194 |
| IMPCCOPT-4339 | 194 |
| IMPCCOPT-4346 | 195 |
| IMPCCOPT-4347 | 195 |
| IMPCCOPT-4348 | 196 |
| IMPCCOPT-4349 | 196 |
| IMPCCOPT-4350 | 197 |
| IMPCCOPT-4352 | 197 |
| IMPCCOPT-4353 | 198 |
| IMPCCOPT-4355 | 198 |
| IMPCCOPT-4356 | 199 |
| IMPCCOPT-4360 | 199 |
| IMPCCOPT-4362 | 200 |
| IMPCCOPT-4375 | 200 |
| IMPCCOPT-4379 | 201 |
| IMPCCOPT-4383 | 201 |
| IMPCCOPT-4386 | 202 |
| IMPCCOPT-4388 | 202 |
| IMPCCOPT-5026 | 203 |
| IMPCCOPT-5037 | 203 |
| IMPCCOPT-5046 | 204 |
| IMPCCOPT-5047 | 204 |

| IMPCK-29    | 205 |
|-------------|-----|
| IMPCK-157   | 205 |
| IMPCK-209   | 206 |
| IMPCK-361   | 207 |
| IMPCK-657   | 208 |
| IMPCK-661   | 209 |
| IMPCK-766   | 210 |
| IMPCK-767   | 211 |
| IMPCK-6001  | 212 |
| IMPCK-6336  | 212 |
| IMPCPF-190  | 213 |
| IMPCPF-201  | 214 |
| IMPCPF-209  | 214 |
| IMPCPF-235  | 215 |
| IMPCPF-237  | 216 |
| IMPCPF-238  | 217 |
| IMPCPF-239  | 217 |
| IMPCPF-243  | 218 |
| IMPCPF-246  | 219 |
| IMPCPF-247  | 220 |
| IMPCPF-249  | 220 |
| IMPCPF-251  | 221 |
| IMPCPF-253  | 222 |
| IMPCPF-289  | 223 |
| IMPCPF-310  | 223 |
| IMPCPF-311  | 224 |
| IMPCPF-312  | 225 |
| IMPCPF-350  | 226 |
| IMPCPF-390  | 226 |
| IMPCPF-402  | 227 |
| IMPCPF-403  | 227 |
| IMPCPF-701  | 228 |
| IMPCPF-980  | 229 |
| IMPCPF-2011 | 229 |
| IMPCPF-2204 | 230 |
| IMPCPF-2210 | 231 |
| IMPCPF-2303 | 231 |
|             |     |

| IMPCPF-2500  | 232 |
|--------------|-----|
| IMPCPF-2510  | 233 |
| IMPCPF-2602  | 233 |
| IMPCTE-104   | 234 |
| IMPCTE-290   | 235 |
| IMPCTE-291   | 235 |
| IMPCTE-313   | 236 |
| IMPCTE-314   | 236 |
| IMPCTE-317   | 237 |
| IMPCTE-318   | 237 |
| IMPCTE-337   | 238 |
| IMPCTE-432   | 238 |
| IMPDB-1206   | 239 |
| IMPDB-1216   | 239 |
| IMPDB-1220   | 240 |
| IMPDB-1284   | 241 |
| IMPDB-2148   | 241 |
| IMPDB-2504   | 242 |
| IMPDB-2532   | 242 |
| IMPDB-2550   | 243 |
| IMPDB-5029   | 243 |
| IMPDB-7003   | 244 |
| IMPDBTCL-204 | 244 |
| IMPDBTCL-205 | 245 |
| IMPDBTCL-229 | 246 |
| IMPDBTCL-271 | 247 |
| IMPDBTCL-614 | 248 |
| IMPDC-1159   | 248 |
| IMPDC-3242   | 249 |
| IMPDC-3243   | 249 |
| IMPDC-3245   | 250 |
| IMPDC-3246   | 250 |
| IMPDC-3247   | 251 |
| IMPDC-3248   | 251 |
| IMPDC-3249   | 252 |
| IMPDF-2      | 252 |
| IMPDF-30     | 253 |

| IMPDF-84    | 254 |
|-------------|-----|
| IMPDF-1008  | 255 |
| IMPDF-1012  | 256 |
| IMPDF-1018  | 256 |
| IMPECO-1    | 257 |
| IMPECO-37   | 258 |
| IMPECO-146  | 258 |
| IMPECO-154  | 259 |
| IMPECO-238  | 259 |
| IMPECO-521  | 260 |
| IMPECO-560  | 260 |
| IMPECO-570  | 261 |
| IMPECO-620  | 261 |
| IMPESI-3086 | 262 |
| IMPESI-3140 | 262 |
| IMPESI-3188 | 263 |
| IMPESI-3189 | 263 |
| IMPESI-3190 | 264 |
| IMPESI-3191 | 264 |
| IMPESI-3192 | 265 |
| IMPESI-3193 | 265 |
| IMPESI-3194 | 266 |
| IMPESI-3199 | 266 |
| IMPESI-3352 | 267 |
| IMPESO-301  | 267 |
| IMPESO-303  | 268 |
| IMPESO-306  | 268 |
| IMPESO-309  | 269 |
| IMPESO-314  | 269 |
| IMPESO-317  | 270 |
| IMPESO-320  | 270 |
| IMPESO-338  | 271 |
| IMPESO-358  | 271 |
| IMPESO-366  | 272 |
| IMPESO-389  | 273 |
| IMPESO-396  | 273 |
| IMPEXT-1023 | 274 |

| IMPEXT-1024 | 275 |
|-------------|-----|
| IMPEXT-1081 | 275 |
| IMPEXT-1197 | 276 |
| IMPEXT-1221 | 277 |
| IMPEXT-1222 | 277 |
| IMPEXT-1241 | 278 |
| IMPEXT-1245 | 279 |
| IMPEXT-2773 | 279 |
| IMPEXT-2776 | 280 |
| IMPEXT-2827 | 280 |
| IMPEXT-2884 | 282 |
| IMPEXT-2900 | 283 |
| IMPEXT-2989 | 284 |
| IMPEXT-3297 | 286 |
| IMPEXT-3423 | 286 |
| IMPEXT-3493 | 287 |
| IMPEXT-3496 | 288 |
| IMPEXT-3497 | 290 |
| IMPEXT-3530 | 292 |
| IMPEXT-3534 | 293 |
| IMPEXT-3550 | 293 |
| IMPEXT-3551 | 295 |
| IMPEXT-5036 | 296 |
| IMPEXT-5064 | 296 |
| IMPEXT-6013 | 299 |
| IMPEXT-6089 | 301 |
| IMPEXT-6159 | 302 |
| IMPEXT-6166 | 303 |
| IMPEXT-6189 | 304 |
| IMPEXT-6191 | 304 |
| IMPEXT-6195 | 305 |
| IMPEXT-6197 | 305 |
| IMPEXT-6198 | 306 |
| IMPEXT-6202 | 307 |
| IMPEXT-7036 | 307 |
| IMPFM-205   | 308 |
| IMPFM-206   | 308 |

| IMPFM-226  | 309 |
|------------|-----|
| IMPFM-235  | 310 |
| IMPFM-318  | 310 |
| IMPFM-333  | 311 |
| IMPFM-334  | 311 |
| IMPFM-353  | 312 |
| IMPFM-706  | 312 |
| IMPFM-709  | 313 |
| IMPFM-725  | 313 |
| IMPFM-730  | 314 |
| IMPFM-735  | 314 |
| IMPFM-759  | 315 |
| IMPFM-760  | 316 |
| IMPFM-761  | 316 |
| IMPFM-790  | 317 |
| IMPFM-1206 | 317 |
| IMPFM-1304 | 318 |
| IMPFP-40   | 318 |
| IMPFP-104  | 319 |
| IMPFP-172  | 319 |
| IMPFP-175  | 320 |
| IMPFP-247  | 321 |
| IMPFP-298  | 321 |
| IMPFP-316  | 322 |
| IMPFP-320  | 322 |
| IMPFP-701  | 323 |
| IMPFP-704  | 323 |
| IMPFP-788  | 324 |
| IMPFP-793  | 324 |
| IMPFP-903  | 325 |
| IMPFP-905  | 326 |
| IMPFP-1594 | 326 |
| IMPFP-1871 | 327 |
| IMPFP-2101 | 327 |
| IMPFP-3101 | 328 |
| IMPFP-3302 | 329 |
| IMPFP-3356 | 329 |

| IMPFP-3361 | 331 |
|------------|-----|
| IMPFP-3388 | 331 |
| IMPFP-3761 | 332 |
| IMPFP-3780 | 333 |
| IMPFP-3803 | 333 |
| IMPFP-3823 | 334 |
| IMPFP-3824 | 335 |
| IMPFP-3825 | 335 |
| IMPFP-3881 | 336 |
| IMPFP-3929 | 336 |
| IMPFP-3941 | 337 |
| IMPFP-3957 | 337 |
| IMPFP-3960 | 338 |
| IMPFP-3961 | 339 |
| IMPFP-3966 | 340 |
| IMPFP-3967 | 340 |
| IMPFP-3968 | 341 |
| IMPFP-3969 | 341 |
| IMPFP-3970 | 342 |
| IMPFP-3971 | 343 |
| IMPFP-3972 | 343 |
| IMPFP-3973 | 344 |
| IMPFP-3974 | 344 |
| IMPFP-3975 | 345 |
| IMPFP-3976 | 345 |
| IMPFP-3977 | 346 |
| IMPFP-3978 | 346 |
| IMPFP-3980 | 347 |
| IMPFP-3981 | 348 |
| IMPFP-4008 | 348 |
| IMPFP-4009 | 349 |
| IMPFP-4010 | 350 |
| IMPFP-4011 | 351 |
| IMPFP-7006 | 351 |
| IMPFP-7007 | 352 |
| IMPFP-7008 | 352 |
| IMPFP-7009 | 353 |
|            |     |

| IMPFP-7012 | 353 |
|------------|-----|
| IMPFP-7013 | 354 |
| IMPFP-7014 | 354 |
| IMPFP-7015 | 355 |
| IMPFP-7016 | 355 |
| IMPFP-9998 | 356 |
| IMPILM-194 | 356 |
| IMPILM-203 | 357 |
| IMPILM-281 | 358 |
| IMPILM-298 | 358 |
| IMPILM-334 | 359 |
| IMPILM-349 | 359 |
| IMPILM-350 | 360 |
| IMPILM-365 | 360 |
| IMPILM-380 | 361 |
| IMPILM-402 | 362 |
| IMPILM-537 | 363 |
| IMPILM-548 | 363 |
| IMPIMEX-1  | 364 |
| IMPIMEX-3  | 365 |
| IMPIO-1    | 366 |
| IMPIO-2    | 366 |
| IMPIO-3    | 366 |
| IMPIO-4    | 367 |
| IMPLF-3    | 367 |
| IMPLF-27   | 368 |
| IMPLF-40   | 369 |
| IMPLF-53   | 370 |
| IMPLF-58   | 371 |
| IMPLF-61   | 371 |
| IMPLF-63   | 372 |
| IMPLF-80   | 373 |
| IMPLF-119  | 374 |
| IMPLF-200  | 375 |
| IMPLF-201  | 376 |
| IMPLF-223  | 378 |
| IMPLF-345  | 379 |

| IMPMP-1001   | 380 |
|--------------|-----|
| IMPMSMV-1006 | 380 |
| IMPMSMV-1007 | 381 |
| IMPMSMV-1015 | 381 |
| IMPMSMV-1051 | 382 |
| IMPMSMV-1052 | 382 |
| IMPMSMV-1053 | 383 |
| IMPMSMV-1054 | 383 |
| IMPMSMV-1116 | 384 |
| IMPMSMV-1123 | 385 |
| IMPMSMV-1211 | 385 |
| IMPMSMV-1212 | 386 |
| IMPMSMV-1213 | 386 |
| IMPMSMV-1215 | 387 |
| IMPMSMV-1219 | 388 |
| IMPMSMV-1226 | 388 |
| IMPMSMV-1243 | 389 |
| IMPMSMV-1245 | 390 |
| IMPMSMV-1246 | 390 |
| IMPMSMV-1247 | 391 |
| IMPMSMV-1248 | 391 |
| IMPMSMV-1249 | 392 |
| IMPMSMV-1264 | 392 |
| IMPMSMV-1267 | 393 |
| IMPMSMV-1314 | 393 |
| IMPMSMV-1315 | 394 |
| IMPMSMV-1501 | 395 |
| IMPMSMV-1504 | 395 |
| IMPMSMV-1531 | 396 |
| IMPMSMV-1592 | 396 |
| IMPMSMV-1595 | 397 |
| IMPMSMV-1636 | 398 |
| IMPMSMV-1780 | 400 |
| IMPMSMV-1781 | 400 |
| IMPMSMV-1783 | 401 |
| IMPMSMV-1792 | 401 |
| IMPMSMV-1798 | 402 |

| IMPMSMV-1800 | 402 |
|--------------|-----|
| IMPMSMV-1801 | 403 |
| IMPMSMV-1802 | 403 |
| IMPMSMV-1804 | 404 |
| IMPMSMV-1805 | 404 |
| IMPMSMV-1806 | 405 |
| IMPMSMV-1820 | 405 |
| IMPMSMV-3101 | 406 |
| IMPMSMV-3502 | 407 |
| IMPMSMV-3700 | 407 |
| IMPMSMV-3701 | 408 |
| IMPMSMV-3910 | 409 |
| IMPMSMV-3920 | 410 |
| IMPMSMV-4001 | 410 |
| IMPMSMV-4002 | 411 |
| IMPMSMV-4100 | 411 |
| IMPMSMV-4110 | 412 |
| IMPMSMV-4111 | 412 |
| IMPMSMV-4112 | 413 |
| IMPMSMV-4113 | 413 |
| IMPMSMV-4115 | 414 |
| IMPMSMV-4120 | 414 |
| IMPMSMV-4200 | 415 |
| IMPMSMV-4201 | 415 |
| IMPMSMV-6600 | 416 |
| IMPMSMV-7101 | 416 |
| IMPMSMV-7510 | 417 |
| IMPMSMV-7511 | 417 |
| IMPMSMV-7512 | 418 |
| IMPMSMV-7515 | 418 |
| IMPMSMV-7520 | 419 |
| IMPMSMV-8003 | 419 |
| IMPMSMV-8304 | 420 |
| IMPMSMV-8401 | 421 |
| IMPMSMV-8600 | 422 |
| IMPMSMV-8610 | 422 |
| IMPMSMV-8620 | 423 |

| IMPMSMV-8623 | 423 |
|--------------|-----|
| IMPMSMV-8630 | 424 |
| IMPMSMV-8631 | 424 |
| IMPMSMV-8632 | 425 |
| IMPMSMV-8640 | 425 |
| IMPMSMV-8650 | 426 |
| IMPMSMV-8656 | 426 |
| IMPMSMV-8660 | 427 |
| IMPMSMV-8670 | 427 |
| IMPOAX-124   | 428 |
| IMPOAX-148   | 429 |
| IMPOAX-252   | 429 |
| IMPOAX-332   | 431 |
| IMPOAX-335   | 432 |
| IMPOAX-392   | 432 |
| IMPOAX-433   | 433 |
| IMPOAX-503   | 434 |
| IMPOAX-571   | 435 |
| IMPOAX-606   | 436 |
| IMPOAX-618   | 437 |
| IMPOAX-683   | 438 |
| IMPOAX-684   | 439 |
| IMPOAX-720   | 441 |
| IMPOAX-745   | 442 |
| IMPOAX-750   | 443 |
| IMPOAX-755   | 444 |
| IMPOAX-757   | 446 |
| IMPOAX-773   | 448 |
| IMPOAX-774   | 449 |
| IMPOAX-923   | 450 |
| IMPOAX-931   | 451 |
| IMPOAX-956   | 453 |
| IMPOAX-986   | 454 |
| IMPOAX-1017  | 456 |
| IMPOAX-1034  | 457 |
| IMPOAX-1050  | 458 |
| IMPOAX-1092  | 458 |
|              |     |

| IMPOAX-1151 | 460 |
|-------------|-----|
| IMPOAX-1255 | 460 |
| IMPOAX-1257 | 462 |
| IMPOAX-1265 | 462 |
| IMPOAX-1266 | 463 |
| IMPOAX-1274 | 463 |
| IMPOAX-1275 | 465 |
| IMPOAX-1307 | 467 |
| IMPOAX-1313 | 468 |
| IMPOAX-1609 | 469 |
| IMPOAX-1625 | 469 |
| IMPOAX-1751 | 472 |
| IMPOAX-1753 | 472 |
| IMPOAX-5110 | 473 |
| IMPOAX-6022 | 476 |
| IMPOAX-6024 | 477 |
| IMPOGDS-391 | 477 |
| IMPOGDS-392 | 478 |
| IMPOGDS-399 | 478 |
| IMPOPT-132  | 479 |
| IMPOPT-136  | 479 |
| IMPOPT-306  | 480 |
| IMPOPT-310  | 480 |
| IMPOPT-393  | 481 |
| IMPOPT-519  | 482 |
| IMPOPT-569  | 482 |
| IMPOPT-576  | 483 |
| IMPOPT-600  | 483 |
| IMPOPT-616  | 484 |
| IMPOPT-622  | 485 |
| IMPOPT-624  | 486 |
| IMPOPT-628  | 487 |
| IMPOPT-629  | 487 |
| IMPOPT-655  | 488 |
| IMPOPT-661  | 489 |
| IMPOPT-665  | 489 |
| IMPOPT-800  | 490 |

| IMPOPT-801  | 490 |
|-------------|-----|
| IMPOPT-802  | 491 |
| IMPOPT-803  | 491 |
| IMPOPT-2901 | 492 |
| IMPOPT-2902 | 492 |
| IMPOPT-2903 | 493 |
| IMPOPT-2904 | 493 |
| IMPOPT-2907 | 494 |
| IMPOPT-2909 | 494 |
| IMPOPT-3000 | 495 |
| IMPOPT-3001 | 495 |
| IMPOPT-3025 | 496 |
| IMPOPT-3034 | 497 |
| IMPOPT-3035 | 497 |
| IMPOPT-3040 | 498 |
| IMPOPT-3050 | 498 |
| IMPOPT-3058 | 499 |
| IMPOPT-3080 | 500 |
| IMPOPT-3115 | 500 |
| IMPOPT-3121 | 501 |
| IMPOPT-3129 | 501 |
| IMPOPT-3135 | 502 |
| IMPOPT-3142 | 503 |
| IMPOPT-3144 | 503 |
| IMPOPT-3180 | 504 |
| IMPOPT-3186 | 505 |
| IMPOPT-3195 | 506 |
| IMPOPT-3213 | 506 |
| IMPOPT-3225 | 507 |
| IMPOPT-3313 | 508 |
| IMPOPT-3314 | 508 |
| IMPOPT-3315 | 509 |
| IMPOPT-3318 | 509 |
| IMPOPT-3319 | 510 |
| IMPOPT-3326 | 510 |
| IMPOPT-3327 | 511 |
| IMPOPT-3328 | 512 |

| IMPOPT-3396 | 512 |
|-------------|-----|
| IMPOPT-3465 | 513 |
| IMPOPT-3466 | 513 |
| IMPOPT-3467 | 514 |
| IMPOPT-3468 | 514 |
| IMPOPT-3481 | 515 |
| IMPOPT-3531 | 516 |
| IMPOPT-3532 | 516 |
| IMPOPT-3535 | 517 |
| IMPOPT-3543 | 517 |
| IMPOPT-3547 | 518 |
| IMPOPT-3560 | 519 |
| IMPOPT-3563 | 519 |
| IMPOPT-3579 | 520 |
| IMPOPT-3580 | 520 |
| IMPOPT-3581 | 521 |
| IMPOPT-3585 | 521 |
| IMPOPT-3588 | 522 |
| IMPOPT-3593 | 522 |
| IMPOPT-3594 | 523 |
| IMPOPT-3596 | 524 |
| IMPOPT-3600 | 524 |
| IMPOPT-3602 | 525 |
| IMPOPT-3610 | 526 |
| IMPOPT-3611 | 526 |
| IMPOPT-3626 | 527 |
| IMPOPT-3629 | 527 |
| IMPOPT-3631 | 528 |
| IMPOPT-3634 | 528 |
| IMPOPT-3638 | 529 |
| IMPOPT-3649 | 530 |
| IMPOPT-3654 | 530 |
| IMPOPT-3655 | 531 |
| IMPOPT-3657 | 532 |
| IMPOPT-3663 | 533 |
| IMPOPT-3665 | 533 |
| IMPOPT-3714 | 534 |

| IMPOPT-6022 | 535 |
|-------------|-----|
| IMPOPT-6055 | 535 |
| IMPOPT-6056 | 536 |
| IMPOPT-6064 | 538 |
| IMPOPT-6072 | 538 |
| IMPOPT-6080 | 540 |
| IMPOPT-6089 | 540 |
| IMPOPT-6095 | 541 |
| IMPOPT-6108 | 542 |
| IMPOPT-6111 | 542 |
| IMPOPT-6115 | 543 |
| IMPOPT-6116 | 544 |
| IMPOPT-6135 | 544 |
| IMPOPT-6206 | 545 |
| IMPOPT-6249 | 545 |
| IMPOPT-7071 | 546 |
| IMPOPT-7075 | 547 |
| IMPOPT-7077 | 547 |
| IMPOPT-7085 | 548 |
| IMPOPT-7253 | 549 |
| IMPOPT-7254 | 549 |
| IMPOPT-7255 | 550 |
| IMPOPT-7256 | 550 |
| IMPOPT-7257 | 551 |
| IMPOPT-7261 | 551 |
| IMPOPT-7262 | 552 |
| IMPOPT-7263 | 552 |
| IMPOPT-7264 | 553 |
| IMPOPT-7266 | 553 |
| IMPOPT-7267 | 553 |
| IMPOPT-7268 | 554 |
| IMPOPT-7269 | 554 |
| IMPOPT-7271 | 555 |
| IMPOPT-7273 | 555 |
| IMPOPT-7275 | 556 |
| IMPPP-133   | 556 |
| IMPPP-188   | 557 |

| IMPPP-190   | 557 |
|-------------|-----|
| IMPPP-333   | 558 |
| IMPPP-354   | 558 |
| IMPPP-362   | 559 |
| IMPPP-527   | 559 |
| IMPPP-543   | 560 |
| IMPPP-557   | 560 |
| IMPPP-4033  | 561 |
| IMPPP-4051  | 561 |
| IMPPP-4055  | 562 |
| IMPPP-4500  | 562 |
| IMPPP-5000  | 563 |
| IMPPPR-638  | 563 |
| IMPPR-641   | 564 |
| IMPPSO-123  | 564 |
| IMPPSO-133  | 565 |
| IMPPSO-134  | 566 |
| IMPPSO-155  | 567 |
| IMPPSO-170  | 568 |
| IMPPSO-186  | 569 |
| IMPPSO-187  | 569 |
| IMPPSO-188  | 570 |
| IMPPSO-192  | 571 |
| IMPPSO-206  | 571 |
| IMPPSO-306  | 572 |
| IMPPSO-627  | 572 |
| IMPPSO-800  | 573 |
| IMPPSO-806  | 574 |
| IMPPSO-808  | 574 |
| IMPPSO-809  | 575 |
| IMPPSO-906  | 575 |
| IMPPSO-907  | 576 |
| IMPPSO-1551 | 576 |
| IMPPTN-90   | 577 |
| IMPPTN-100  | 579 |
| IMPPTN-233  | 579 |
| IMPPTN-426  | 580 |

| IMPPTN-427  | 581 |
|-------------|-----|
| IMPPTN-428  | 582 |
| IMPPTN-429  | 582 |
| IMPPTN-555  | 583 |
| IMPPTN-624  | 584 |
| IMPPTN-646  | 585 |
| IMPPTN-647  | 585 |
| IMPPTN-652  | 586 |
| IMPPTN-716  | 587 |
| IMPPTN-780  | 587 |
| IMPPTN-882  | 588 |
| IMPPTN-946  | 589 |
| IMPPTN-1211 | 590 |
| IMPPTN-1250 | 590 |
| IMPPTN-1520 | 591 |
| IMPPTN-1521 | 591 |
| IMPPTN-1550 | 592 |
| IMPPTN-1669 | 592 |
| IMPPTN-1671 | 594 |
| IMPPTN-1699 | 594 |
| IMPPTN-1704 | 595 |
| IMPPTN-1717 | 596 |
| IMPPTN-1755 | 597 |
| IMPPTN-1802 | 598 |
| IMPPTN-3207 | 599 |
| IMPREPO-102 | 600 |
| IMPRM-143   | 600 |
| IMPRM-148   | 602 |
| IMPSC-1001  | 603 |
| IMPSC-1010  | 604 |
| IMPSC-1022  | 604 |
| IMPSC-1138  | 605 |
| IMPSE-31    | 606 |
| IMPSE-32    | 607 |
| IMPSE-34    | 607 |
| IMPSE-35    | 608 |
| IMPSER-514  | 608 |

| IMPSP-101  | 609 |
|------------|-----|
| IMPSP-105  | 609 |
| IMPSP-157  | 610 |
| IMPSP-167  | 611 |
| IMPSP-182  | 611 |
| IMPSP-183  | 612 |
| IMPSP-185  | 613 |
| IMPSP-259  | 613 |
| IMPSP-260  | 614 |
| IMPSP-263  | 614 |
| IMPSP-270  | 616 |
| IMPSP-288  | 616 |
| IMPSP-300  | 617 |
| IMPSP-305  | 618 |
| IMPSP-307  | 618 |
| IMPSP-308  | 619 |
| IMPSP-309  | 619 |
| IMPSP-315  | 620 |
| IMPSP-357  | 621 |
| IMPSP-362  | 621 |
| IMPSP-365  | 622 |
| IMPSP-372  | 624 |
| IMPSP-373  | 625 |
| IMPSP-374  | 625 |
| IMPSP-452  | 626 |
| IMPSP-508  | 627 |
| IMPSP-514  | 628 |
| IMPSP-1760 | 629 |
| IMPSP-2002 | 630 |
| IMPSP-2020 | 630 |
| IMPSP-2021 | 632 |
| IMPSP-2022 | 633 |
| IMPSP-2041 | 633 |
| IMPSP-2044 | 634 |
| IMPSP-2702 | 635 |
| IMPSP-2704 | 635 |
| IMPSP-2707 | 636 |

| IMPSP-2717  | 636 |
|-------------|-----|
| IMPSP-2901  | 637 |
| IMPSP-2902  | 637 |
| IMPSP-2903  | 638 |
| IMPSP-5101  | 639 |
| IMPSP-5106  | 640 |
| IMPSP-5113  | 640 |
| IMPSP-5119  | 641 |
| IMPSP-5123  | 642 |
| IMPSP-5125  | 643 |
| IMPSP-5131  | 644 |
| IMPSP-5134  | 646 |
| IMPSP-5140  | 646 |
| IMPSP-5144  | 647 |
| IMPSP-5157  | 648 |
| IMPSP-5164  | 649 |
| IMPSP-5169  | 649 |
| IMPSP-5170  | 650 |
| IMPSP-5178  | 651 |
| IMPSP-5216  | 651 |
| IMPSP-5217  | 652 |
| IMPSP-5259  | 652 |
| IMPSP-6014  | 653 |
| IMPSP-7207  | 654 |
| IMPSP-7208  | 655 |
| IMPSP-9025  | 655 |
| IMPSP-9042  | 656 |
| IMPSP-9053  | 657 |
| IMPSP-9514  | 657 |
| IMPSP-9516  | 658 |
| IMPSP-9528  | 659 |
| IMPSP-9542  | 659 |
| IMPSP-15450 | 660 |
| IMPSR-211   | 660 |
| IMPSR-212   | 661 |
| IMPSR-215   | 661 |
| IMPSR-216   | 662 |

| IMPSR-217   | 662 |
|-------------|-----|
| IMPSR-218   | 663 |
| IMPSR-219   | 663 |
| IMPSR-221   | 664 |
| IMPSR-222   | 664 |
| IMPSR-223   | 665 |
| IMPSR-344   | 665 |
| IMPSR-345   | 666 |
| IMPSR-346   | 666 |
| IMPSR-347   | 667 |
| IMPSR-348   | 667 |
| IMPSR-349   | 668 |
| IMPSR-794   | 668 |
| IMPSR-1256  | 669 |
| IMPSR-1972  | 669 |
| IMPSR-1974  | 670 |
| IMPSR-2457  | 670 |
| IMPSR-2459  | 671 |
| IMPSR-2617  | 671 |
| IMPSR-4006  | 672 |
| IMPSYC-2    | 672 |
| IMPSYC-179  | 673 |
| IMPSYC-194  | 674 |
| IMPSYC-959  | 674 |
| IMPSYC-1636 | 675 |
| IMPSYC-1816 | 677 |
| IMPSYC-1919 | 678 |
| IMPSYC-1921 | 678 |
| IMPSYC-1922 | 679 |
| IMPSYC-1923 | 679 |
| IMPSYC-2100 | 680 |
| IMPSYC-3161 | 681 |
| IMPSYC-3166 | 681 |
| IMPSYC-6114 | 682 |
| IMPSYC-6152 | 682 |
| IMPSYC-6164 | 683 |
| IMPSYC-6375 | 683 |

| IMPSYC-6376   | 684 |
|---------------|-----|
| IMPSYT-6260   | 684 |
| IMPSYT-6284   | 685 |
| IMPSYT-7221   | 685 |
| IMPSYT-16038  | 686 |
| IMPSYT-40503  | 687 |
| IMPSYUTIL-96  | 687 |
| IMPSYUTIL-106 | 688 |
| IMPTB-2       | 688 |
| IMPTB-36      | 689 |
| IMPTB-178     | 690 |
| IMPTB-521     | 690 |
| IMPTB-522     | 691 |
| IMPTCM-42     | 691 |
| IMPTR-1107    | 692 |
| IMPTR-1109    | 693 |
| IMPTR-2108    | 694 |
| IMPTR-2322    | 695 |
| IMPTR-2325    | 695 |
| IMPTR-7111    | 696 |
| IMPTR-7122    | 697 |
| IMPTR-8007    | 698 |
| IMPTR-8015    | 698 |
| IMPTS-16      | 699 |
| IMPTS-17      | 699 |
| IMPTS-282     | 700 |
| IMPTS-302     | 701 |
| IMPTS-313     | 701 |
| IMPTS-403     | 702 |
| IMPTS-414     | 702 |
| IMPTS-415     | 703 |
| IMPTS-423     | 703 |
| IMPTS-429     | 704 |
| IMPTS-451     | 704 |
| IMPTS-452     | 705 |
| IMPTS-455     | 705 |
| IMPVAC-0      | 706 |

| IMPVAC-96  | 706 |
|------------|-----|
| IMPVAC-131 | 707 |
| IMPVCM-7   | 707 |
| IMPVFC-3   | 708 |
| IMPVFC-16  | 708 |
| IMPVFC-92  | 709 |
| IMPVFC-93  | 709 |
| IMPVFC-200 | 710 |
| IMPVFC-250 | 710 |
| IMPVFC-266 | 711 |
| IMPVFG-216 | 711 |
| IMPVL-159  | 712 |
| IMPVL-209  | 712 |
| IMPVL-327  | 713 |
| IMPVL-346  | 713 |
| IMPVL-349  | 714 |
| IMPVL-356  | 714 |
| IMPVL-366  | 715 |
| IMPVL-377  | 716 |
| IMPVL-503  | 716 |
| IMPVL-520  | 717 |
| IMPVL-904  | 717 |
| IMPVL-909  | 718 |
| IMPVPA-1   | 718 |
| IMPVPA-22  | 719 |
| IMPVPA-55  | 719 |
| NRDB-18    | 720 |
| NRDB-37    | 720 |
| NRDB-51    | 721 |
| NRDB-87    | 721 |
| NRDB-158   | 722 |
| NRDB-164   | 723 |
| NRDB-166   | 723 |
| NRDB-319   | 724 |
| NRDB-331   | 724 |
| NRDB-605   | 726 |
| NRDB-608   | 726 |

| NRDB-609  | 727 |
|-----------|-----|
| NRDB-628  | 728 |
| NRDB-629  | 729 |
| NRDB-631  | 730 |
| NRDB-676  | 730 |
| NRDB-682  | 731 |
| NRDB-728  | 732 |
| NRDB-733  | 732 |
| NRDB-741  | 733 |
| NRDB-778  | 735 |
| NRDB-855  | 735 |
| NRDB-874  | 736 |
| NRDB-897  | 737 |
| NRDB-898  | 737 |
| NRDB-899  | 738 |
| NRDB-900  | 738 |
| NRDB-912  | 739 |
| NRDB-944  | 739 |
| NRDB-954  | 740 |
| NRDB-955  | 741 |
| NRDB-965  | 741 |
| NRDB-976  | 742 |
| NRDB-1007 | 743 |
| NRDB-2005 | 743 |
| NRDB-2016 | 744 |
| NRDB-2026 | 744 |
| NRDB-2040 | 745 |
| NRDB-2048 | 746 |
| NRDB-2050 | 747 |
| NRDB-2062 | 747 |
| NRDB-2081 | 748 |
| NRDB-2085 | 748 |
| NRDB-2106 | 749 |
| NRDB-2111 | 750 |
| NRDR-4    | 750 |
| NRDR-12   | 751 |
| NRDR-13   | 751 |

| NRDR-30     | 752 |
|-------------|-----|
| NRDR-123    | 753 |
| NRDR-126    | 754 |
| NRDR-129    | 755 |
| NRDR-175    | 755 |
| NRDR-240    | 756 |
| NRDR-328    | 757 |
| NRDR-334    | 757 |
| NREX-32     | 758 |
| NRFL-215    | 758 |
| NRFL-217    | 759 |
| NRFL-374    | 760 |
| NRGR-21     | 760 |
| NRGR-59     | 761 |
| NRGR-145    | 761 |
| NRGR-164    | 762 |
| NRGR-190    | 762 |
| NRGR-228    | 763 |
| NRGR-261    | 764 |
| NRIG-34     | 764 |
| NRIG-43     | 765 |
| NRIG-74     | 766 |
| NRIG-77     | 767 |
| NRIG-96     | 767 |
| NRIG-117    | 768 |
| NRTM-24     | 769 |
| PRL-0389    | 769 |
| PRL-0390    | 770 |
| PTNASMD-90  | 770 |
| PTNASMD-100 | 772 |
| PTNASMD-233 | 772 |
| PTNASMD-426 | 773 |
| PTNASMD-427 | 774 |
| PTNASMD-428 | 775 |
| PTNASMD-429 | 775 |
| PTNASMD-555 | 776 |
| PTNASMD-624 | 777 |

| PTNASMD-646  | 778 |
|--------------|-----|
| PTNASMD-647  | 778 |
| PTNASMD-652  | 779 |
| PTNASMD-716  | 780 |
| PTNASMD-780  | 780 |
| PTNASMD-882  | 781 |
| PTNASMD-946  | 782 |
| PTNASMD-1211 | 782 |
| PTNASMD-1250 | 783 |
| PTNASMD-1520 | 784 |
| PTNASMD-1521 | 784 |
| PTNASMD-1550 | 785 |
| PTNASMD-1669 | 785 |
| PTNASMD-1671 | 787 |
| PTNASMD-1699 | 787 |
| PTNASMD-1704 | 788 |
| PTNASMD-1717 | 788 |
| PTNASMD-1755 | 790 |
| PTNASMD-1802 | 791 |
| PTNASMD-3207 | 792 |
| PTNFEED-90   | 792 |
| PTNFEED-100  | 794 |
| PTNFEED-233  | 795 |
| PTNFEED-426  | 796 |
| PTNFEED-427  | 797 |
| PTNFEED-428  | 797 |
| PTNFEED-429  | 798 |
| PTNFEED-555  | 799 |
| PTNFEED-624  | 800 |
| PTNFEED-646  | 801 |
| PTNFEED-647  | 801 |
| PTNFEED-652  | 802 |
| PTNFEED-716  | 802 |
| PTNFEED-780  | 803 |
| PTNFEED-882  | 804 |
| PTNFEED-946  | 805 |
| PTNFEED-1211 | 805 |

| PTNFEED-1250 | 806 |
|--------------|-----|
| PTNFEED-1520 | 806 |
| PTNFEED-1521 | 807 |
| PTNFEED-1550 | 807 |
| PTNFEED-1669 | 808 |
| PTNFEED-1671 | 809 |
| PTNFEED-1699 | 810 |
| PTNFEED-1704 | 810 |
| PTNFEED-1717 | 811 |
| PTNFEED-1755 | 812 |
| PTNFEED-1802 | 814 |
| PTNFEED-3207 | 814 |
| PTNPART-90   | 815 |
| PTNPART-100  | 817 |
| PTNPART-233  | 817 |
| PTNPART-426  | 818 |
| PTNPART-427  | 819 |
| PTNPART-428  | 820 |
| PTNPART-429  | 820 |
| PTNPART-555  | 821 |
| PTNPART-624  | 822 |
| PTNPART-646  | 823 |
| PTNPART-647  | 823 |
| PTNPART-652  | 824 |
| PTNPART-716  | 825 |
| PTNPART-780  | 825 |
| PTNPART-882  | 826 |
| PTNPART-946  | 827 |
| PTNPART-1211 | 827 |
| PTNPART-1250 | 828 |
| PTNPART-1520 | 829 |
| PTNPART-1521 | 829 |
| PTNPART-1550 | 830 |
| PTNPART-1669 | 830 |
| PTNPART-1671 | 832 |
| PTNPART-1699 | 832 |
| PTNPART-1704 | 833 |
|              |     |

| PTNPART-1717 | 833 |
|--------------|-----|
| PTNPART-1755 | 835 |
| PTNPART-1802 | 836 |
| PTNPART-3207 | 837 |
| PTNPIN-90    | 837 |
| PTNPIN-100   | 839 |
| PTNPIN-233   | 840 |
| PTNPIN-426   | 841 |
| PTNPIN-427   | 842 |
| PTNPIN-428   | 842 |
| PTNPIN-429   | 843 |
| PTNPIN-555   | 844 |
| PTNPIN-624   | 845 |
| PTNPIN-646   | 846 |
| PTNPIN-647   | 846 |
| PTNPIN-652   | 847 |
| PTNPIN-716   | 847 |
| PTNPIN-780   | 848 |
| PTNPIN-882   | 849 |
| PTNPIN-946   | 850 |
| PTNPIN-1211  | 850 |
| PTNPIN-1250  | 851 |
| PTNPIN-1520  | 851 |
| PTNPIN-1521  | 852 |
| PTNPIN-1550  | 852 |
| PTNPIN-1669  | 853 |
| PTNPIN-1671  | 854 |
| PTNPIN-1699  | 855 |
| PTNPIN-1704  | 855 |
| PTNPIN-1717  | 856 |
| PTNPIN-1755  | 857 |
| PTNPIN-1802  | 859 |
| PTNPIN-3207  | 859 |
| SPEF-1123    | 860 |
| SPEF-1124    | 861 |
| SPEF-1125    | 861 |
| SPEF-1127    | 862 |
|              |     |

| SPEF-1132                          | 862 |
|------------------------------------|-----|
| SPEF-1134                          | 863 |
| SPEF-1135                          | 863 |
| SPEF-1149                          | 864 |
| SPEF-1152                          | 864 |
| SPEF-1155                          | 865 |
| TAMODEL-101                        | 865 |
| TAMODEL-112                        | 866 |
| TAMODEL-113                        | 866 |
| TAMODEL-114                        | 867 |
| TAMODEL-115                        | 867 |
| TAMODEL-116                        | 868 |
| TAMODEL-117                        | 868 |
| TAMODEL-301                        | 869 |
| TAMODEL-303                        | 869 |
| TAMODEL-307                        | 870 |
| TAMODEL-308                        | 870 |
| TAMODEL-309                        | 871 |
| TAMODEL-310                        | 871 |
| TAMODEL-311                        | 872 |
| TAMODEL-312                        | 872 |
| TAMODEL-313                        | 873 |
| TAMODEL-314                        | 873 |
| TAMODEL-315                        | 874 |
| TAMODEL-316                        | 874 |
| TAMODEL-317                        | 875 |
| TAMODEL-319                        | 875 |
| TAMODEL-320                        | 876 |
| TAMODEL-321                        | 876 |
| TAMODEL-322                        | 877 |
| TAMODEL-323                        | 877 |
| TAMODEL-324                        | 878 |
| TAMODEL-325                        | 878 |
| TAMODEL-326                        | 879 |
| TCLCMD-ERR_COMCMD86                | 879 |
| TCLCMD-ERR_INVALID_DATA_REQUESTED2 | 880 |
| TCLCMD-ERR_MODCMD2                 | 881 |

| TCLCMD-ERR_TACMD6                          | 881 |
|--------------------------------------------|-----|
| TCLCMD-ERR_VIEWCMD1                        | 882 |
| TCLCMD-WARN_COMCMD8                        | 882 |
| TCLCMD-WARN_VERBOSE_PBA_EXHAUSTIVE_LIMIT_1 | 883 |
| TCLCMD-WARN_WRGCF1                         | 883 |
| TCLCMD-WARN_WRGCF3                         | 884 |
| TCLCMD-WARN_WRGCF4                         | 884 |
| TCLCMD-WARN_WRGCF5                         | 885 |
| TCLCMD-WARN_WRGCF12                        | 885 |
| TCLCMD-WARN_WRGCF13                        | 886 |
| TCLCMD-WARN_WRGCF14                        | 886 |
| TCLCMD-WARN_WRGCF15                        | 886 |
| TCLCMD-WARN_WRGCF16                        | 887 |
| TCLCMD-WARN_WRGCF19                        | 887 |
| TCLCMD-WARN_WRGCF20                        | 888 |
| TCLCMD-WARN_WRGCF21                        | 888 |
| TCLCMD-WARN_WRGCF30                        | 889 |
| TECHLIB-103                                | 889 |
| TECHLIB-104                                | 890 |
| TECHLIB-106                                | 890 |
| TECHLIB-107                                | 891 |
| TECHLIB-122                                | 891 |
| TECHLIB-123                                | 892 |
| TECHLIB-152                                | 892 |
| TECHLIB-169                                | 893 |
| TECHLIB-180                                | 893 |
| TECHLIB-183                                | 894 |
| TECHLIB-184                                | 894 |
| TECHLIB-190                                | 895 |
| TECHLIB-191                                | 895 |
| TECHLIB-246                                | 896 |
| TECHLIB-248                                | 896 |
| TECHLIB-249                                | 897 |
| TECHLIB-257                                | 897 |
| TECHLIB-258                                | 898 |
| TECHLIB-263                                | 898 |
| TECHLIB-264                                | 899 |

| TECHLIB-265 | 899 |
|-------------|-----|
| TECHLIB-266 | 900 |
| TECHLIB-269 | 900 |
| TECHLIB-270 | 901 |
| TECHLIB-271 | 901 |
| TECHLIB-272 | 902 |
| TECHLIB-274 | 902 |
| TECHLIB-275 | 903 |
| TECHLIB-276 | 903 |
| TECHLIB-277 | 904 |
| TECHLIB-278 | 904 |
| TECHLIB-279 | 905 |
| TECHLIB-280 | 905 |
| TECHLIB-281 | 906 |
| TECHLIB-282 | 906 |
| TECHLIB-302 | 907 |
| TECHLIB-305 | 907 |
| TECHLIB-311 | 908 |
| TECHLIB-313 | 908 |
| TECHLIB-318 | 909 |
| TECHLIB-319 | 909 |
| TECHLIB-324 | 909 |
| TECHLIB-327 | 910 |
| TECHLIB-336 | 910 |
| TECHLIB-338 | 911 |
| TECHLIB-342 | 911 |
| TECHLIB-357 | 912 |
| TECHLIB-368 | 912 |
| TECHLIB-369 | 913 |
| TECHLIB-377 | 913 |
| TECHLIB-381 | 914 |
| TECHLIB-382 | 914 |
| TECHLIB-383 | 915 |
| TECHLIB-385 | 915 |
| TECHLIB-386 | 916 |
| TECHLIB-387 | 916 |
| TECHLIB-389 | 916 |

| TECHLIB-390 | 917 |
|-------------|-----|
| TECHLIB-391 | 918 |
| TECHLIB-392 | 918 |
| TECHLIB-393 | 919 |
| TECHLIB-395 | 919 |
| TECHLIB-397 | 920 |
| TECHLIB-398 | 920 |
| TECHLIB-399 | 921 |
| TECHLIB-400 | 921 |
| TECHLIB-401 | 922 |
| TECHLIB-402 | 922 |
| TECHLIB-403 | 923 |
| TECHLIB-404 | 923 |
| TECHLIB-405 | 924 |
| TECHLIB-406 | 924 |
| TECHLIB-407 | 925 |
| TECHLIB-408 | 925 |
| TECHLIB-409 | 926 |
| TECHLIB-410 | 926 |
| TECHLIB-411 | 927 |
| TECHLIB-412 | 927 |
| TECHLIB-413 | 928 |
| TECHLIB-414 | 928 |
| TECHLIB-415 | 929 |
| TECHLIB-416 | 929 |
| TECHLIB-417 | 930 |
| TECHLIB-418 | 930 |
| TECHLIB-419 | 931 |
| TECHLIB-420 | 931 |
| TECHLIB-421 | 932 |
| TECHLIB-422 | 932 |
| TECHLIB-423 | 933 |
| TECHLIB-424 | 933 |
| TECHLIB-425 | 934 |
| TECHLIB-426 | 934 |
| TECHLIB-427 | 935 |
| TECHLIB-428 | 935 |

| TECHLIB-429 | 936 |
|-------------|-----|
| TECHLIB-430 | 936 |
| TECHLIB-431 | 937 |
| TECHLIB-432 | 937 |
| TECHLIB-433 | 938 |
| TECHLIB-434 | 938 |
| TECHLIB-435 | 939 |
| TECHLIB-436 | 939 |
| TECHLIB-437 | 940 |
| TECHLIB-452 | 940 |
| TECHLIB-453 | 941 |
| TECHLIB-458 | 941 |
| TECHLIB-459 | 942 |
| TECHLIB-460 | 942 |
| TECHLIB-461 | 943 |
| TECHLIB-604 | 943 |
| TECHLIB-606 | 944 |
| TECHLIB-608 | 944 |
| TECHLIB-609 | 945 |
| TECHLIB-620 | 945 |
| TECHLIB-622 | 946 |
| TECHLIB-700 | 946 |
| TECHLIB-701 | 947 |
| TECHLIB-702 | 947 |
| TECHLIB-703 | 948 |
| TECHLIB-704 | 948 |
| TECHLIB-705 | 949 |
| TECHLIB-707 | 949 |
| TECHLIB-708 | 950 |
| TECHLIB-709 | 950 |
| TECHLIB-710 | 951 |
| TECHLIB-711 | 951 |
| TECHLIB-712 | 952 |
| TECHLIB-713 | 952 |
| TECHLIB-715 | 953 |
| TECHLIB-716 | 953 |
| TECHLIB-800 | 954 |

| TECHLIB-802  | 954 |
|--------------|-----|
| TECHLIB-804  | 955 |
| TECHLIB-805  | 955 |
| TECHLIB-806  | 956 |
| TECHLIB-807  | 956 |
| TECHLIB-808  | 957 |
| TECHLIB-809  | 957 |
| TECHLIB-810  | 958 |
| TECHLIB-811  | 959 |
| TECHLIB-812  | 959 |
| TECHLIB-814  | 960 |
| TECHLIB-816  | 960 |
| TECHLIB-817  | 961 |
| TECHLIB-818  | 961 |
| TECHLIB-819  | 962 |
| TECHLIB-820  | 962 |
| TECHLIB-827  | 963 |
| TECHLIB-828  | 964 |
| TECHLIB-904  | 964 |
| TECHLIB-905  | 965 |
| TECHLIB-906  | 965 |
| TECHLIB-908  | 966 |
| TECHLIB-914  | 966 |
| TECHLIB-915  | 967 |
| TECHLIB-916  | 967 |
| TECHLIB-919  | 968 |
| TECHLIB-921  | 968 |
| TECHLIB-922  | 969 |
| TECHLIB-924  | 969 |
| TECHLIB-925  | 970 |
| TECHLIB-935  | 970 |
| TECHLIB-1001 | 971 |
| TECHLIB-1002 | 971 |
| TECHLIB-1003 | 972 |
| TECHLIB-1004 | 972 |
| TECHLIB-1005 | 973 |
| TECHLIB-1006 | 973 |

| TECHLIB-1007 | 974 |
|--------------|-----|
| TECHLIB-1010 | 974 |
| TECHLIB-1051 | 975 |
| TECHLIB-1056 | 975 |
| TECHLIB-1064 | 976 |
| TECHLIB-1068 | 976 |
| TECHLIB-1069 | 977 |
| TECHLIB-1070 | 977 |
| TECHLIB-1071 | 978 |
| TECHLIB-1073 | 978 |
| TECHLIB-1076 | 979 |
| TECHLIB-1077 | 979 |
| TECHLIB-1078 | 980 |
| TECHLIB-1103 | 980 |
| TECHLIB-1104 | 981 |
| TECHLIB-1105 | 981 |
| TECHLIB-1106 | 982 |
| TECHLIB-1107 | 982 |
| TECHLIB-1108 | 983 |
| TECHLIB-1109 | 983 |
| TECHLIB-1114 | 984 |
| TECHLIB-1115 | 984 |
| TECHLIB-1116 | 985 |
| TECHLIB-1117 | 985 |
| TECHLIB-1118 | 986 |
| TECHLIB-1119 | 986 |
| TECHLIB-1120 | 987 |
| TECHLIB-1123 | 987 |
| TECHLIB-1131 | 988 |
| TECHLIB-1135 | 988 |
| TECHLIB-1141 | 989 |
| TECHLIB-1142 | 989 |
| TECHLIB-1143 | 990 |
| TECHLIB-1144 | 990 |
| TECHLIB-1145 | 991 |
| TECHLIB-1146 | 991 |
| TECHLIB-1147 | 992 |

| TECHLIB-1148 | 992  |
|--------------|------|
| TECHLIB-1150 | 993  |
| TECHLIB-1151 | 993  |
| TECHLIB-1152 | 994  |
| TECHLIB-1153 | 994  |
| TECHLIB-1154 | 995  |
| TECHLIB-1156 | 995  |
| TECHLIB-1157 | 996  |
| TECHLIB-1161 | 996  |
| TECHLIB-1170 | 997  |
| TECHLIB-1171 | 997  |
| TECHLIB-1172 | 998  |
| TECHLIB-1173 | 998  |
| TECHLIB-1174 | 999  |
| TECHLIB-1175 | 999  |
| TECHLIB-1176 | 1000 |
| TECHLIB-1177 | 1000 |
| TECHLIB-1179 | 1001 |
| TECHLIB-1180 | 1001 |
| TECHLIB-1181 | 1002 |
| TECHLIB-1182 | 1002 |
| TECHLIB-1183 | 1003 |
| TECHLIB-1184 | 1003 |
| TECHLIB-1185 | 1004 |
| TECHLIB-1186 | 1004 |
| TECHLIB-1187 | 1005 |
| TECHLIB-1188 | 1005 |
| TECHLIB-1189 | 1006 |
| TECHLIB-1190 | 1006 |
| TECHLIB-1191 | 1007 |
| TECHLIB-1192 | 1007 |
| TECHLIB-1193 | 1008 |
| TECHLIB-1194 | 1008 |
| TECHLIB-1195 | 1009 |
| TECHLIB-1196 | 1009 |
| TECHLIB-1197 | 1010 |
| TECHLIB-1198 | 1010 |

| TECHLIB-1199 | 1011 |
|--------------|------|
| TECHLIB-1200 | 1011 |
| TECHLIB-1201 | 1012 |
| TECHLIB-1202 | 1012 |
| TECHLIB-1203 | 1013 |
| TECHLIB-1204 | 1013 |
| TECHLIB-1205 | 1014 |
| TECHLIB-1206 | 1014 |
| TECHLIB-1207 | 1015 |
| TECHLIB-1208 | 1015 |
| TECHLIB-1209 | 1016 |
| TECHLIB-1210 | 1016 |
| TECHLIB-1211 | 1017 |
| TECHLIB-1212 | 1017 |
| TECHLIB-1213 | 1018 |
| TECHLIB-1214 | 1018 |
| TECHLIB-1215 | 1019 |
| TECHLIB-1216 | 1019 |
| TECHLIB-1217 | 1020 |
| TECHLIB-1218 | 1020 |
| TECHLIB-1220 | 1021 |
| TECHLIB-1221 | 1021 |
| TECHLIB-1222 | 1022 |
| TECHLIB-1223 | 1022 |
| TECHLIB-1224 | 1023 |
| TECHLIB-1225 | 1023 |
| TECHLIB-1226 | 1024 |
| TECHLIB-1227 | 1024 |
| TECHLIB-1228 | 1025 |
| TECHLIB-1229 | 1025 |
| TECHLIB-1230 | 1026 |
| TECHLIB-1231 | 1026 |
| TECHLIB-1232 | 1027 |
| TECHLIB-1233 | 1027 |
| TECHLIB-1234 | 1028 |
| TECHLIB-1235 | 1028 |
| TECHLIB-1236 | 1029 |

| TECHLIB-1237 | 1029 |
|--------------|------|
| TECHLIB-1238 | 1030 |
| TECHLIB-1239 | 1030 |
| TECHLIB-1240 | 1031 |
| TECHLIB-1241 | 1031 |
| TECHLIB-1242 | 1032 |
| TECHLIB-1244 | 1032 |
| TECHLIB-1245 | 1033 |
| TECHLIB-1246 | 1033 |
| TECHLIB-1247 | 1034 |
| TECHLIB-1248 | 1034 |
| TECHLIB-1249 | 1035 |
| TECHLIB-1250 | 1035 |
| TECHLIB-1251 | 1036 |
| TECHLIB-1252 | 1036 |
| TECHLIB-1253 | 1037 |
| TECHLIB-1254 | 1037 |
| TECHLIB-1255 | 1038 |
| TECHLIB-1256 | 1038 |
| TECHLIB-1257 | 1039 |
| TECHLIB-1258 | 1039 |
| TECHLIB-1259 | 1040 |
| TECHLIB-1260 | 1040 |
| TECHLIB-1261 | 1041 |
| TECHLIB-1262 | 1041 |
| TECHLIB-1263 | 1042 |
| TECHLIB-1264 | 1042 |
| TECHLIB-1265 | 1043 |
| TECHLIB-1266 | 1043 |
| TECHLIB-1267 | 1044 |
| TECHLIB-1269 | 1044 |
| TECHLIB-1270 | 1045 |
| TECHLIB-1271 | 1045 |
| TECHLIB-1272 | 1046 |
| TECHLIB-1273 | 1046 |
| TECHLIB-1274 | 1047 |
| TECHLIB-1276 | 1047 |

| TECHLIB-1277 | 1048 |
|--------------|------|
| TECHLIB-1278 | 1048 |
| TECHLIB-1279 | 1049 |
| TECHLIB-1280 | 1049 |
| TECHLIB-1281 | 1050 |
| TECHLIB-1282 | 1050 |
| TECHLIB-1283 | 1051 |
| TECHLIB-1284 | 1051 |
| TECHLIB-1285 | 1052 |
| TECHLIB-1286 | 1052 |
| TECHLIB-1287 | 1053 |
| TECHLIB-1288 | 1054 |
| TECHLIB-1290 | 1054 |
| TECHLIB-1291 | 1055 |
| TECHLIB-1292 | 1055 |
| TECHLIB-1293 | 1056 |
| TECHLIB-1294 | 1056 |
| TECHLIB-1295 | 1057 |
| TECHLIB-1296 | 1057 |
| TECHLIB-1297 | 1058 |
| TECHLIB-1298 | 1058 |
| TECHLIB-1299 | 1059 |
| TECHLIB-1300 | 1059 |
| TECHLIB-1301 | 1060 |
| TECHLIB-1302 | 1060 |
| TECHLIB-1303 | 1061 |
| TECHLIB-1304 | 1061 |
| TECHLIB-1305 | 1062 |
| TECHLIB-1306 | 1062 |
| TECHLIB-1307 | 1063 |
| TECHLIB-1308 | 1063 |
| TECHLIB-1309 | 1064 |
| TECHLIB-1310 | 1064 |
| TECHLIB-1311 | 1065 |
| TECHLIB-1312 | 1065 |
| TECHLIB-1313 | 1066 |
| TECHLIB-1314 | 1066 |

| TECHLIB-1315 | 1067 |
|--------------|------|
| TECHLIB-1316 | 1067 |
| TECHLIB-1317 | 1068 |
| TECHLIB-1318 | 1068 |
| TECHLIB-1319 | 1069 |
| TECHLIB-1320 | 1069 |
| TECHLIB-1321 | 1070 |
| TECHLIB-1322 | 1070 |
| TECHLIB-1323 | 1071 |
| TECHLIB-1324 | 1071 |
| TECHLIB-1325 | 1072 |
| TECHLIB-1327 | 1072 |
| TECHLIB-1329 | 1073 |
| TECHLIB-1330 | 1073 |
| TECHLIB-1331 | 1074 |
| TECHLIB-1332 | 1074 |
| TECHLIB-1333 | 1075 |
| TECHLIB-1334 | 1075 |
| TECHLIB-1335 | 1076 |
| TECHLIB-1336 | 1077 |
| TECHLIB-1337 | 1077 |
| TECHLIB-1338 | 1078 |
| TECHLIB-1339 | 1078 |
| TECHLIB-1340 | 1079 |
| TECHLIB-1341 | 1079 |
| TECHLIB-1342 | 1080 |
| TECHLIB-1343 | 1081 |
| TECHLIB-1344 | 1081 |
| TECHLIB-1345 | 1082 |
| TECHLIB-1346 | 1082 |
| TECHLIB-1347 | 1083 |
| TECHLIB-1348 | 1083 |
| TECHLIB-1349 | 1084 |
| TECHLIB-1350 | 1084 |
| TECHLIB-1351 | 1085 |
| TECHLIB-1352 | 1085 |
| TECHLIB-1353 | 1086 |

| TECHLIB-1354 | 1086 |
|--------------|------|
| TECHLIB-1355 | 1087 |
| TECHLIB-1356 | 1087 |
| TECHLIB-1357 | 1088 |
| TECHLIB-1358 | 1088 |
| TECHLIB-1359 | 1089 |
| TECHLIB-1360 | 1089 |
| TECHLIB-1361 | 1090 |
| TECHLIB-1362 | 1090 |
| TECHLIB-1363 | 1091 |
| TECHLIB-1364 | 1091 |
| TECHLIB-1365 | 1092 |
| TECHLIB-1366 | 1092 |
| TECHLIB-1367 | 1093 |
| TECHLIB-1368 | 1093 |
| TECHLIB-1369 | 1094 |
| TECHLIB-1370 | 1094 |
| TECHLIB-1371 | 1095 |
| TECHLIB-1372 | 1095 |
| TECHLIB-1374 | 1096 |
| TECHLIB-1377 | 1096 |
| TECHLIB-1378 | 1097 |
| TECHLIB-1379 | 1097 |
| TECHLIB-1380 | 1098 |
| TECHLIB-1381 | 1098 |
| TECHLIB-1382 | 1099 |
| TECHLIB-1383 | 1099 |
| TECHLIB-1384 | 1100 |
| TECHLIB-1385 | 1100 |
| TECHLIB-1386 | 1101 |
| TECHLIB-1388 | 1101 |
| TECHLIB-1389 | 1102 |
| TECHLIB-1391 | 1102 |
| TECHLIB-1392 | 1103 |
| TECHLIB-1393 | 1103 |
| TECHLIB-1394 | 1104 |
| TECHLIB-1395 | 1104 |

| TECHLIB-1396 | 1105 |
|--------------|------|
| TECHLIB-1397 | 1105 |
| TECHLIB-1398 | 1106 |
| TECHLIB-1399 | 1106 |
| TECHLIB-1400 | 1107 |
| TECHLIB-1401 | 1107 |
| TECHLIB-1402 | 1108 |
| TECHLIB-1403 | 1108 |
| TECHLIB-1404 | 1109 |
| TECHLIB-1405 | 1109 |
| TECHLIB-1406 | 1110 |
| TECHLIB-1407 | 1110 |
| TECHLIB-1408 | 1111 |
| TECHLIB-1409 | 1111 |
| TECHLIB-1410 | 1112 |
| TECHLIB-1411 | 1112 |
| TECHLIB-1412 | 1113 |
| TECHLIB-1413 | 1113 |
| TECHLIB-1414 | 1114 |
| TECHLIB-1415 | 1114 |
| TECHLIB-1416 | 1115 |
| TECHLIB-1417 | 1116 |
| TECHLIB-1418 | 1116 |
| TECHLIB-1419 | 1117 |
| TECHLIB-1420 | 1117 |
| TECHLIB-1421 | 1118 |
| TECHLIB-1422 | 1118 |
| TECHLIB-1423 | 1119 |
| TECHLIB-1424 | 1119 |
| TECHLIB-1425 | 1120 |
| TECHLIB-1426 | 1120 |
| TECHLIB-1427 | 1121 |
| TECHLIB-1428 | 1121 |
| TECHLIB-1429 | 1122 |
| TECHLIB-1430 | 1122 |
| TECHLIB-1431 | 1123 |
| TECHLIB-1433 | 1123 |

| TECHLIB-1434 | 1124 |
|--------------|------|
| TECHLIB-1435 | 1124 |
| TECHLIB-1436 | 1125 |
| TECHLIB-1437 | 1125 |
| TECHLIB-1438 | 1126 |
| TECHLIB-1439 | 1126 |
| TECHLIB-1440 | 1127 |
| TECHLIB-1441 | 1127 |
| TECHLIB-1442 | 1128 |
| TECHLIB-1443 | 1128 |
| TECHLIB-1444 | 1129 |
| TECHLIB-1445 | 1129 |
| TECHLIB-9001 | 1130 |
| TECHLIB-9002 | 1130 |
| TECHLIB-9004 | 1131 |
| TECHLIB-9007 | 1131 |
| TECHLIB-9008 | 1132 |
| TECHLIB-9009 | 1132 |
| TECHLIB-9010 | 1133 |
| TECHLIB-9011 | 1133 |
| TECHLIB-9012 | 1134 |
| TECHLIB-9016 | 1134 |
| TECHLIB-9017 | 1135 |
| TECHLIB-9018 | 1135 |
| TECHLIB-9019 | 1136 |
| TECHLIB-9023 | 1136 |
| TECHLIB-9024 | 1137 |
| TECHLIB-9025 | 1137 |
| TECHLIB-9026 | 1138 |
| TECHLIB-9027 | 1138 |
| TECHLIB-9028 | 1139 |
| TECHLIB-9030 | 1139 |
| TECHLIB-9031 | 1140 |
| TECHLIB-9032 | 1140 |
| TECHLIB-9034 | 1141 |
| TECHLIB-9035 | 1141 |
| TECHLIB-9036 | 1142 |

| TECHLIB-9037 | 1142 |
|--------------|------|
| TECHLIB-9038 | 1143 |
| TECHLIB-9039 | 1143 |
| TECHLIB-9040 | 1144 |
| TECHLIB-9041 | 1144 |
| TECHLIB-9042 | 1145 |
| TECHLIB-9044 | 1145 |
| TECHLIB-9045 | 1146 |
| TECHLIB-9048 | 1146 |
| TECHLIB-9053 | 1147 |
| TECHLIB-9056 | 1147 |
| TECHLIB-9057 | 1148 |
| TECHLIB-9058 | 1148 |
| TECHLIB-9059 | 1149 |
| TECHLIB-9060 | 1149 |
| TECHLIB-9061 | 1150 |
| TECHLIB-9062 | 1150 |
| TECHLIB-9063 | 1151 |
| TECHLIB-9064 | 1151 |
| TECHLIB-9065 | 1152 |
| TECHLIB-9066 | 1152 |
| TECHLIB-9067 | 1153 |
| TECHLIB-9068 | 1153 |
| TECHLIB-9069 | 1154 |
| TECHLIB-9070 | 1154 |
| TECHLIB-9071 | 1155 |
| TECHLIB-9072 | 1155 |
| TECHLIB-9073 | 1156 |
| TECHLIB-9074 | 1156 |
| TECHLIB-9081 | 1157 |
| TECHLIB-9082 | 1157 |
| TECHLIB-9084 | 1158 |
| TECHLIB-9085 | 1158 |
| TECHLIB-9086 | 1159 |
| TECHLIB-9087 | 1159 |
| TECHLIB-9088 | 1160 |
| TECHLIB-9089 | 1160 |

| TECHLIB-9090 | 1161 |
|--------------|------|
| TECHLIB-9091 | 1161 |
| TECHLIB-9092 | 1162 |
| TECHLIB-9093 | 1162 |
| TECHLIB-9095 | 1163 |
| TECHLIB-9096 | 1163 |
| TECHLIB-9097 | 1164 |
| TECHLIB-9098 | 1164 |
| TECHLIB-9099 | 1165 |
| TECHLIB-9100 | 1165 |
| TECHLIB-9101 | 1166 |
| TECHLIB-9102 | 1166 |
| TECHLIB-9103 | 1167 |
| TECHLIB-9104 | 1167 |
| TECHLIB-9105 | 1168 |
| TECHLIB-9106 | 1168 |
| TECHLIB-9107 | 1169 |
| TECHLIB-9108 | 1169 |
| TECHLIB-9109 | 1170 |
| TECHLIB-9110 | 1170 |
| TECHLIB-9111 | 1171 |
| TECHLIB-9112 | 1172 |
| TECHLIB-9113 | 1172 |
| TECHLIB-9114 | 1173 |
| TECHLIB-9115 | 1174 |
| TECHLIB-9118 | 1174 |
| TECHLIB-9119 | 1175 |
| TECHLIB-9120 | 1175 |
| TECHLIB-9121 | 1176 |
| TECHLIB-9122 | 1176 |
| TECHLIB-9123 | 1177 |
| TECHLIB-9124 | 1177 |
| TECHLIB-9125 | 1178 |
| TECHLIB-9127 | 1178 |
| TECHLIB-9128 | 1179 |
| TECHLIB-9129 | 1179 |
| TECHLIB-9131 | 1180 |

| TECHLIB-9132 | 1180 |
|--------------|------|
| TECHLIB-9133 | 1181 |
| TECHLIB-9134 | 1181 |
| TECHLIB-9135 | 1182 |
| TECHLIB-9136 | 1182 |
| TECHLIB-9137 | 1183 |
| TECHLIB-9138 | 1183 |
| TECHLIB-9139 | 1184 |
| TECHLIB-9140 | 1184 |
| TECHLIB-9141 | 1185 |
| TECHLIB-9142 | 1185 |
| TECHLIB-9143 | 1186 |
| TECHLIB-9144 | 1186 |
| TECHLIB-9145 | 1187 |
| TECHLIB-9147 | 1187 |
| TECHLIB-9148 | 1188 |
| TECHLIB-9149 | 1188 |
| TECHLIB-9150 | 1189 |
| TECHLIB-9152 | 1189 |
| TECHLIB-9153 | 1190 |
| TECHLIB-9154 | 1190 |
| TECHLIB-9155 | 1191 |
| TECHLIB-9156 | 1191 |
| TECHLIB-9157 | 1192 |
| TECHLIB-9161 | 1192 |
| TECHLIB-9162 | 1193 |
| TECHLIB-9164 | 1193 |
| TECHLIB-9166 | 1194 |
| TECHLIB-9167 | 1194 |
| TECHLIB-9168 | 1195 |
| TECHLIB-9170 | 1195 |
| VOLTUS-1186  | 1196 |
| VOLTUS-5348  | 1196 |
| WHATIF-2     | 1197 |
| WHATIF-3     | 1197 |

1

# **Error and Warning Messages**

# **CHKCTS-1**

### NAME

CHKCTS-1

### **SUMMARY**

CTS maximum transition target must be set to a numeric value for delay\_corner %s, delay\_type %s, and %s for clock tree %s and net type %s.

### **DESCRIPTION**

Make sure there is a numeric value set for the cts\_target\_max\_transition\_time attribute for all delay corners and power domains. Run 'help cts\_target\_max\_transition\_time' for more details on how to set the maximum transition time.

# **CHKCTS-2**

## **NAME**

CHKCTS-2

## **SUMMARY**

CTS maximum transition target must be set to a numeric value for the primary corner %s and %s for clock tree %s and net type %s.

#### DESCRIPTION

Make sure there is a numeric value set for the cts\_target\_max\_transition\_time attribute for the primary half corner in all power domains. Run 'help cts\_target\_max\_transition\_time' for more details on how to set the maximum transition time.

# **CHKCTS-3**

### **NAME**

CHKCTS-3

#### **SUMMARY**

CTS maximum transition target %s is too low (minimum %s) for delay\_corner %s and delay\_type %s for clock\_tree %s and net\_type %s.

## **DESCRIPTION**

Increase the value set for the cts\_target\_max\_transition\_time attribute to avoid excessive buffering for this clock\_tree. Run 'help cts\_target\_max\_transition\_time' for more details on how to set the maximum transition time.

# **CHKCTS-4**

#### NAME

CHKCTS-4

## **SUMMARY**

An auto generated scaled skew target of %s will be used for delay\_corner %s and delay\_type %s for skew group %s.

## **DESCRIPTION**

Error and Warning Messages

When using multi-corner skew targets it is recommended to set explicit numeric targets for each delay\_corner you want to balance in. Run 'help cts\_target\_skew' for more details on how to set skew targets.

# **CHKCTS-5**

#### NAME

CHKCTS-5

#### SUMMARY

CTS skew target must be set to a numeric value for the primary corner %s for skew\_group %s.

## **DESCRIPTION**

Set a skew target using the cts\_target\_skew attribute for the primary half corner. Run 'help cts target skew' for more details on how to set skew targets.

# **CHKCTS-6**

## **NAME**

**CHKCTS-6** 

#### SUMMARY

The value for the cts\_target\_skew attribute %s is too low (minimum %s) for skew\_group %s, delay\_corner %s and delay\_type %s.

### DESCRIPTION

Increase the value set for the cts\_target\_skew attribute to avoid excessive buffering for this skew group. Run 'help cts target skew' for more details on how to set skew targets.

### NAME

CHKCTS-9

#### **SUMMARY**

No route type has been specified for clock tree %s and net type %s.

### **DESCRIPTION**

Route types must be created and then specified for use by CTS by setting the cts\_route\_type attribute. Run 'help create\_route\_type' for more details on how to create route\_types. Run 'help cts\_route\_type' for more details on how to specify which route\_types CTS should use.

# CHKCTS-10

#### NAME

CHKCTS-10

#### **SUMMARY**

Route type(s) %s used for trunk or top clock nets do not have a non-default rule (NDR) set.

### DESCRIPTION

Make sure there is a NDR specifed for each route\_type for top and trunk nets. Check the cts\_route\_type attribute to see which route\_types are in use for clock nets. Run 'get\_db route\_type: <name> .rule.name' to see NDR for a route\_type called <name>. Run 'help cts\_route\_type' for more details on how to specify which route\_types CTS should use. Run 'help create\_route\_type' for more details on how to create route\_types.

#### NAME

CHKCTS-12

#### **SUMMARY**

No preferred routing layers are set for route type(s) %s for clock nets.

### **DESCRIPTION**

All route\_types for clock nets should have preferred routing layers set. Check the cts\_route\_type attribute to see which route\_types are in use for clock nets. Run 'get\_db route\_type:<name> .bottom\_preferred\_layer' and 'get\_db route\_type:<name> .top\_preferred\_layer' to see preferred layers for a route\_type called <name>. Run 'help create\_route\_type' for more details on how to create route\_types.

# CHKCTS-13

### **NAME**

CHKCTS-13

#### SUMMARY

More than two preferred routing layers are set for route\_type(s) %s for clock nets, and automatic route type trimming is disabled. This can cause poor routing correlation.

### DESCRIPTION

Either enable automatic route\_type trimming (by running 'set\_db cts\_route\_type\_auto\_trim true'), or manually reduce the number of preferred layers in the route\_type. Run 'get\_db route\_type:<name> .bottom\_preferred\_layer' and 'get\_db route\_type:<name> .top\_preferred\_layer' to see preferred layers for a route\_type called <name>. Run 'help create\_route\_type' for more details on how to

create route\_types.

# CHKCTS-14

#### NAME

CHKCTS-14

#### SUMMARY

Route type(s) %s used for leaf clock nets will use routing layers above those for trunk clock nets.

### DESCRIPTION

Leaf nets should be configured to use lower layers than trunk nets. Check the cts\_route\_type attribute to see which route\_types are in use for clock nets. Run 'get\_db route\_type:<name> .bottom\_preferred\_layer' and 'get\_db route\_type:<name> .top\_preferred\_layer' to see preferred layers for a route\_type called <name>. Run 'help create\_route\_type' for more details on how to create route\_types.

# CHKCTS-15

#### NAME

CHKCTS-15

### **SUMMARY**

Preferred routing layers use Double Pattern Technology (DPT) for route\_type(s) %s for clock nets.

#### DESCRIPTION

It is recommended to use non-DPT layers for clock nets. Check the cts\_route\_type attribute to see which route\_types are in use for clock nets. Run 'get\_db route\_type:<name>
.bottom\_preferred\_layer' and 'get\_db route\_type:<name> .top\_preferred\_layer' to see preferred

Error and Warning Messages

layers for a route\_type called <name>. To check the number of masks for a layer called <name> run 'get\_db layer:<name> .num\_masks'.

# CHKCTS-16

#### NAME

CHKCTS-16

### **SUMMARY**

Preferred routing layers for route\_type %s do not have similar RC characteristics. Mismatch found on layers: %s.

### **DESCRIPTION**

Preferred layer ranges for clock nets should have similar RC characteristics for both horizontal and vertical layers. Check the cts\_route\_type attribute to see which route\_types are in use for clock nets. Run 'help report\_unit\_parasitics' for details on how to check the layer RC values for the preferred layers specified in the route\_type.

# CHKCTS-17

### NAME

CHKCTS-17

### **SUMMARY**

CTS has found the clock tree is inconsistent with the power management setup: %s has %s but drives %s which has %s%s

## **DESCRIPTION**

A clock node cannot drive its fanout since they are in different power domains. Check power

management setup.

# CHKCTS-18

### **NAME**

CHKCTS-18

#### **SUMMARY**

Buffer cells are not specified for these clock\_tree(s): %s.

### **DESCRIPTION**

Clock buffer cells must be specified for CTS. Set the cts\_buffer\_cells attribute to a list of buffers, or a list of patterns to match buffers. Run 'help cts\_buffer\_cells' for more details on how to specify which buffers CTS should use.

# CHKCTS-19

#### NAME

CHKCTS-19

#### **SUMMARY**

Inverter cells are not specified for these clock tree(s): %s.

## **DESCRIPTION**

Clock inverter cells must be specified for CTS. Set the cts\_inverter\_cells attribute to a list of inverters, or a list of patterns to match inverters. Run 'help cts\_inverter\_cells' for more details on how to specify which inverters CTS should use.

#### NAME

CHKCTS-20

#### **SUMMARY**

Clock gating cells are not specified for these clock tree(s): %s.

## **DESCRIPTION**

Clock gating cells must be specified for CTS. Set the cts\_clock\_gating\_cells attribute to a list of clock gates, or a list of patterns to match clock gates. Run 'help cts\_clock\_gating\_cells' for more details on how to specify which clock gates CTS should use.

# CHKCTS-21

#### NAME

CHKCTS-21

#### SUMMARY

Clock logic cells are not specified for these clock tree(s): %s.

### DESCRIPTION

It is recommended to specify clock logic cells for CTS. Set the cts\_logic\_cells attribute to a list of clock logics, or a list of patterns to match clock logics. Run 'help cts\_clock\_logic\_cells' for more details on how to specify which clock logics CTS should use.

#### NAME

CHKCTS-22

### **SUMMARY**

Insufficient number of buffer cells for clock tree %s and power domain %s. Have cells: %s.

## **DESCRIPTION**

Provide at least three cells to allow CTS to choose from a range of different buffer sizes. Run 'help cts buffer cells' for more details on how to specify which buffers CTS should use.

# CHKCTS-23

## **NAME**

CHKCTS-23

## **SUMMARY**

Insufficient number of inverter cells for clock tree %s and power domain %s. Have cells: %s.

### DESCRIPTION

Provide at least three cells to allow CTS to choose from a range of different inverter sizes. Run 'help cts inverter cells' for more details on how to specify which inverters CTS should use.

#### NAME

CHKCTS-24

### **SUMMARY**

Insufficient number of clock gating cells for clock\_tree %s and power\_domain %s. Have cells: %s.

## **DESCRIPTION**

Provide at least three cells to allow CTS to choose from a range of different clock gate sizes. Run 'help cts\_clock\_gating\_cells' for more details on how to specify which clock gates CTS should use.

# CHKCTS-25

## **NAME**

CHKCTS-25

### **SUMMARY**

The pin %s is a sink in skew\_group %s but is not part of any defined clock\_tree.

### **DESCRIPTION**

This may indicate that this pin was expected to be in a clock\_tree.

#### NAME

CHKCTS-29

#### **SUMMARY**

Cannot determine a primary timing corner for %s.

## **DESCRIPTION**

Make sure there is at least one setup delay corner and check the cts\_primary\_delay\_corner attribute. Run 'report\_analysis\_views -setup' to check the current multi-mode multi-corner configuration.

# CHKCTS-30

#### NAME

CHKCTS-30

### **SUMMARY**

The clock instances %s with base cell %s are cant use for the following reason: %s.

#### DESCRIPTION

Check that timing and lef libraries are loaded for all the base\_cells used in the clock\_trees, or specify the cts\_capacitance\_override attribute for all instances of the pins without library data.

#### NAME

CHKCTS-31

### **SUMMARY**

The clock\_tree %s traces through an hterm on hinst %s. This hinst is an instance of module %s which has no definition in the netlist.

### **DESCRIPTION**

Check that there is a definition in the Verilog for the module, and check the log for Verilog parse errors.

# CHKCTS-32

#### NAME

CHKCTS-32

#### SUMMARY

Power domain %s contains clock instances but has no placeable area.

## **DESCRIPTION**

Check the power\_domain definitions are correct and that the specified drivers are compatible with the power\_domain. CTS quality will be impacted since it will be unable to add drivers to this power\_domain.

#### NAME

CHKCTS-37

#### **SUMMARY**

CTS cannot use the preferred layers from route type %s: top %s(%s) and bottom %s(%s) for clock\_tree %s and net\_type %s. CTS will instead use preferred layers: top %s(%s) and bottom %s(%s).

### **DESCRIPTION**

All route\_types for CTS should have at least one horizontal layer and at least one vertical layer. Check the cts\_route\_type attribute to see which route\_types are in use for clock nets. Modify the route\_type preferred layers or change which route\_types will be used for CTS by changing the cts\_route\_type attribute.

# CHKCTS-38

#### NAME

CHKCTS-38

### **SUMMARY**

Found %d clock instances which have been set to fixed placement status by the user. Refer to the CHKCTS-59 messages to identify details of each such fixed node.

## **DESCRIPTION**

Fixed clock tree instances (clock gates, clock drivers and clock logic) cannot be moved or sized by CTS. This can adversely affect clock QoR.

#### NAME

CHKCTS-39

#### **SUMMARY**

More than %.1f%% (%d of %d) of clock instances have been set to fixed placement status by the user.

### **DESCRIPTION**

Fixed clock tree instances (clock gates, clock drivers and clock logic) cannot be moved or sized by CTS. This can adversely affect clock QoR.

# CHKCTS-40

#### NAME

CHKCTS-40

#### SUMMARY

More than half of the clock gates in clock\_tree %s are instances of cells that are not in the clock gating cell lists for the clock tree. These cells are not specified for the clock tree: %s.

### **DESCRIPTION**

Check the cts\_clock\_gating\_cells attribute setting for this clock\_tree. Run 'help cts\_clock\_gating\_cells' for more details on how to specify which clock gates CTS should use.

#### NAME

CHKCTS-41

#### **SUMMARY**

The setting of %s for the cts\_max\_source\_to\_sink\_net\_length attribute for %s may be too low. Increase it to more than %s to avoid this warning.

### **DESCRIPTION**

Check the value of the cts\_max\_source\_to\_sink\_net\_length attribute. Run 'help cts\_max\_source\_to\_sink\_net\_length' for more details on how to control the max net length in CTS.

# CHKCTS-42

#### NAME

CHKCTS-42

#### SUMMARY

The setting of %s for the cts\_max\_source\_to\_sink\_net\_length attribute for %s is too low (less than %s). Increase the value (preferably to at least %s).

### **DESCRIPTION**

Check the value of the cts\_max\_source\_to\_sink\_net\_length attribute or increase the limit. Run 'help cts\_max\_source\_to\_sink\_net\_length' for more details on how to control the max net length in CTS.

#### NAME

CHKCTS-43

#### **SUMMARY**

Buffer cells are not specified for clock tree %s and power domain %s.

## **DESCRIPTION**

Set the cts\_buffer\_cells attribute to a list of buffers, or a list of patterns to match buffers. Run 'help cts buffer cells' for more details on how to specify which buffers CTS should use.

# CHKCTS-44

## **NAME**

CHKCTS-44

### **SUMMARY**

Inverter cells are not specified for clock tree %s and power domain %s.

### DESCRIPTION

Set the cts\_inverters\_cells attribute to a list of inverters, or a list of patterns to match inverters. Run 'help cts\_inverter cells' for more details on how to specify which inverters CTS should use.

### NAME

CHKCTS-45

#### **SUMMARY**

Clock gating cells are not specified for clock tree %s and power domain %s.

## **DESCRIPTION**

Set the cts\_clock\_gating\_cells attribute to a list of clock gates, or a list of patterns to match clock gates. Run 'help cts\_clock\_gating\_cells' for more details on how to specify which clock gates CTS should use.

# CHKCTS-46

#### NAME

CHKCTS-46

#### SUMMARY

Clock logic cells are not specified for clock tree %s and power domain %s.

### DESCRIPTION

Set the cts\_logic\_cells attribute to a list of clock logics, or a list of patterns to match clock logics. Run 'help cts\_clock\_logic\_cells' for more details on how to specify which clock logics CTS should use.

#### NAME

CHKCTS-48

#### **SUMMARY**

The route\_type %s used for net\_type (%s) has a non-default rule (NDR) set but the NDR does not change the width or spacing of the following preferred routing layers: %s.

### **DESCRIPTION**

Check the NDR definition has the intended width and spacing for the preferred routing layers. Run 'get\_db route\_type:<name> .rule.name' to see NDR for a route\_type called <name>.

# CHKCTS-50

#### NAME

CHKCTS-50

## **SUMMARY**

Found one or more hports with the wrong direction. This may cause CTS to crash.

### **DESCRIPTION**

Run 'fix\_multi\_drivers [-report\_only]' to identify and repair incorrect port directions.

# CHKCTS-51

#### NAME

CHKCTS-51

#### **SUMMARY**

The timing analysis type is not set to OCV (on chip variation).

#### **DESCRIPTION**

The analysis type should be set to ocv. Run 'set\_db timing\_analysis\_type ocv' to change to OCV analysis. Without OCV analysis post-CTS timing is inaccurate. Furthermore, OCV analysis is required by the clock source latency update ('IO latency update') that is performed by default during CTS. It is recommended to set the analysis type to OCV before placement, and to ensure the SDC timing constraints are compatible: the analysis type changes the interpretation of any SDC timing constraints using -min and -max qualifiers.

## CHKCTS-53

#### NAME

CHKCTS-53

### **SUMMARY**

Over %s (%d of %d) of clock insts have been set by the user to be don't touch.

#### DESCRIPTION

Too many dont\_touch insts can impact clock QoR. Check the dont\_touch status for clock insts and correct if necessary. Run 'set\_db inst:<name> .dont\_touch none' to clear the flag on an inst called <name>'.

# CHKCTS-54

#### NAME

CHKCTS-54

#### **SUMMARY**

More than %d of the sinks in clock tree source group %s are in the transitive fanout of uncloneable inst %s.

#### **DESCRIPTION**

Multi-tap allocation can be severely impacted by uncloneable insts especially those in the path to many sinks. Refer to the CHKCTS-55 messages to identify details of each such uncloneable inst.

# CHKCTS-55

#### NAME

CHKCTS-55

#### **SUMMARY**

Inst %s in clock tree source group %s can not be cloned for the following reason(s): %s. There are %d sinks in the transitive fanout of this inst.

### **DESCRIPTION**

Multi-tap allocation can be severely impacted by uncloneable insts especially those in the path to many sinks. Run 'cts\_cannot\_clone\_reasons' for more details on the possible reasons why a clock inst may be uncloneable.

# CHKCTS-56

#### NAME

CHKCTS-56

#### **SUMMARY**

Net %s cannot be buffered for reason(s): %s. (HPL: %s, Num fanout: %u, Transitive fanout: %u)

### **DESCRIPTION**

Unbufferable nets can severely impact QoR. Check the reason(s) why this net cannot be buffered, and correct the configuration if needed. This check is sorted by importance, based on fanout count and half perimeter length of the net bounding box (HPL).

# CHKCTS-58

#### NAME

CHKCTS-58

## **SUMMARY**

Found a user don't touch instance %s (source is %s).

#### DESCRIPTION

If this is not desired then remove the user don't touch setting. Run 'set\_db inst:<name> .dont\_touch none' to clear the flag on an inst called <name>'.

#### NAME

**CHKPTNFEED-90** 

#### SUMMARY

Pin %s of abutted partition %s could not be assigned. Could not find a feasible slot for the pin. Create more feasible location before for pin assignment by inserting feedthrough buffers using add\_partition\_feedthrus command or allowing more layers for assigning pins or using set\_db assign\_pins\_strict\_abutment false or using set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true for relaxing this check.

#### DESCRIPTION

In order to resolve this issue, do the following before pin assignment:

#1 In abutted designs, pins of following type can not be placed on common edges between two adjoining partitions.

.in +2

- A. Pins of net not connected to adjacent partition (fences of the two partitions being connected are not touching each other in create floorplan).
- B. Pins of nets having connections to two or more partitions any pin belonging to net of above type will have to route over an unconnected partition and result in illegal routing.

Feedthrough step is required to get rid of pins which connect non-adjacent partitions or multiple partitions, by changing netlist and making all pins connect to only one pin on adjacent partition to make the routing of net feasible/legal

C. Floating pins

.in

#2. Create additional location for pins

.in +2

A. By removing blockages

- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

- #3. Use set\_db assign\_pins\_strict\_abutment false to relax abutment violations checks for placing multi partition pin of a net, non neighbor pins of a net and floating pins on abutted edges.
- #4. Use set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true to relax abutment violations checks for placing floating pins on abutted edges.

#### Example:

-----

eg. if pins are not assigned for a net which has more than two partition pins to connect use add\_partition\_feedthrus command to change netlist to have new nets added and older net modified in way that, now nets only connect two pins of adjacent partitions only.

## **CHKPTNFEED-100**

#### NAME

CHKPTNFEED-100

#### SUMMARY

The net %s is not connected to any terminal. This net will not be considered for feedthrough buffer insertion. Correct the netlist to get this net considered for feedthrough buffer insertion.

#### **DESCRIPTION**

An unconnected net will not be considered for feedthrough insertion. The net should be connected

to an output port and an input port to be considered for feedthrough insertion.

## **CHKPTNFEED-233**

#### NAME

CHKPTNFEED-233

#### **SUMMARY**

No legal free slots available for %s of partition %s. Create additional slots using create\_partition command or by removing blockage before pin assignment.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

#### NAME

CHKPTNFEED-426

#### **SUMMARY**

Adjusting partition %s core to left from %f to %f because specified core spacing value is not multiple of placement grid.

#### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

#### Example:

-----

<CMD> create\_partition -hinst uCORE/uPKTSS/uPKTSS\_PPCS\_PMA\_SYS -core\_spacing {2.7 2.7 1.9 1.9} -reserved\_layer {1 2 3 4 5 6 7 8} -route\_halo 1.9 -route\_halo\_top\_layer 7 - route\_halo\_bottom\_layer 1 -place\_halo {2.7 2.7 1.9 1.9} -rail\_width 0.1 -min\_pitch\_left 3 - min\_pitch\_right 3 -min\_pitch\_top 3 -min\_pitch\_bottom 3 -pin\_layer\_top {3 5} -pin\_layer\_bottom {3 5} -pin\_layer\_left {4 6} -pin\_layer\_right {4 6}

Creating partition PKTSS\_PPCS\_PMA\_SYS.

- \*\*WARN: (IMPPTN-426): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to left from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-427): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to right from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-428): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to top from 2.700000 to 2.850000.
- \*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

Placement grid is at 0.135 x-direction, 0.095 y-direction.

#### NAME

CHKPTNFEED-427

#### SUMMARY

Adjusting partition %s core to right from %f to %f because specified core spacing value is not multiple of placement grid.

#### **DESCRIPTION**

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

\_\_\_\_\_

## **CHKPTNFEED-428**

#### **NAME**

CHKPTNFEED-428

## **SUMMARY**

Adjusting partition %s core to top from %f to %f because specified core spacing value is not multiple of placement grid.

<sup>\*\*</sup>WARN: (IMPPTN-427): Adjusting partition lbrx\_top\_0 core to right from 0.000000 to 0.100000.

Error and Warning Messages

#### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

\*\*WARN: (IMPPTN-428): Adjusting partition lbrx\_top\_0 core to top from 0.000000 to 3.680000.

## **CHKPTNFEED-429**

#### NAME

CHKPTNFEED-429

#### **SUMMARY**

Adjusting partition %s core to bottom from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

\*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

#### NAME

CHKPTNFEED-555

#### SUMMARY

A feasible legal location was not found for %d (out of %d) pins. Consequently, the following pins could not be assigned:

#### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

#### NAME

CHKPTNFEED-624

#### SUMMARY

add\_partition\_feedthrus could not find a path for net '%s' to reach '%s'. If the -topoFile option is being used, the topology specified for this net is incomplete.

### **DESCRIPTION**

In case automatic feedthrough insertion is being done, it means that a path to some of the terminals could not be found. If the routeBased option is used, the routing may be incomplete. For the case the topology file is used an explanation follows.

Tool issues above warning during add\_partition\_feedthrus command step, when topology file provided with -topoFile is used to guide the tool for creating the feedthrough in a specified partition for multi-fanout nets. You will get above warning if the topology file did not define for all the terminals for a multi-fanout net. Always follow the convention from\_pin to to\_pin for writing the topology file.

#### Example:

If the net goes to three partition A, B and C and you want to make a part of the net from A to D then to C, then you can use the following approach to write the topology file.

net n123 hinst-hinst A D; hinst-hinst D C; hinst-hinst A B;

end net

So, here all the combinations are covered where the net goes, instead of defining the A-D-C.

#### NAME

CHKPTNFEED-646

#### SUMMARY

add\_partition\_feedthrus is trying to find a feedthrough path for net %s. It could not find a path to partition or terminal [%s]. Partitions connected to this net may not be adjacent to each other.

#### DESCRIPTION

Automatic feedthrough insertion derives the feedthrough topology using the placement. It assumes a channel-less design. The possibility of routing through channels is considered minimal. In this design a path to a partition or terminal connected to the above mentioned net could not be found without avoiding the channels.

## **CHKPTNFEED-647**

#### NAME

**CHKPTNFEED-647** 

#### SUMMARY

add\_partition\_feedthrus skipping net [%s] because a path to some of the partitions or terminals could not be found. It might not be necessary to insert feedthrough buffers for this net. If you wish to insert feedthrough buffers for this net, then use the topology file for guided feedthrough buffer insertion or use the -routeBased option after routing the net.

#### DESCRIPTION

add\_partition\_feedthrus assumes the design to be channel-less and partitions to be in the line of sight for feedthrough path to pass from one partition to another. In case of channel based designs

Error and Warning Messages

where this is not true, the named net is ignored. In case feedthrough insertion is required for the net, either route the design and used add\_partition\_feedthrus -routeBased or define the path for the net in a topology file and use add\_partition\_feedthrus -topoFile <filename>

Example:
----route\_early\_global
add\_partition\_feedthrus -routeBased
Or
add\_partition\_feedthrus -topoFile <filename>

## **CHKPTNFEED-652**

#### NAME

CHKPTNFEED-652

### **SUMMARY**

The push\_down\_buffer command cannot create an instance with name [%s%s]. An instance with this name already exists in the design. Using default prefix and name [%s] for this instance.

### **DESCRIPTION**

This message is issued if the push\_down\_buffer uses the prefix provided with the -prefix option and the resulting name has a conflict with an existing instance name. No action needs to be taken as it will make another name with the default prefix.

## CHKPTNFEED-716

#### NAME

CHKPTNFEED-716

#### **SUMMARY**

Partition %s constraint missing. Specify a Guide, Region, Fence constraint on the partition or place the blackbox instance.

#### **DESCRIPTION**

While committing partitions 1. Blackboxes should be placed inside core 2. Partitions fences must be core

# **CHKPTNFEED-780**

#### NAME

CHKPTNFEED-780

### **SUMMARY**

Selected pin assignment: could not assign %d (out of %d) pins because feasible legal location was not found for following pins, need legal locations for pin to be assigned.

## **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

A. By removing blockages

B. By removing PG stripes

C. Allow more layers for pin assignment

.in

.in +4

Error and Warning Messages

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## **CHKPTNFEED-882**

#### NAME

CHKPTNFEED-882

#### **SUMMARY**

The add\_partition\_feedthrus command was invoked with the -routeBased option, but the design has not yet been routed. The add\_partition\_feedthrus command will skip the nets that are not routed. Route the design using route\_early\_global for these nets to be considered for feedthrough insertion.

### DESCRIPTION

The add\_partition\_feedthrus command invoked with the -routeBased option requires routing for the net to find a path based on which it will insert the feedthrough ports.

The net reported is not routed so it gets ignored. Route the design prior to running this command. The route\_early\_global command can be used to route the design.

Otherwise add\_partition\_feedthrus should be invoked without using the -routeBased option in which case the command will try to find a path for the net based on the create\_floorplan and placement (placement based feedthrough insertion).



### NAME

CHKPTNFEED-946

#### **SUMMARY**

Pin named [%s] does not exist in cell [%s]. Ignoring the pin. Check and correct the pin name.

### **DESCRIPTION**

Pin name specified for the specified partition does not exist. Check the pin name and partition name and correct accordingly. Problem could be case sensitivity. Command requires exact name which is case sensitive or incorrect manipulation of "alphabet I or numeric 1" "likewise "alphabet o and numeric 0"

Example:

-----

Pin name could be "isCaseSensitive" but pin name supplied could be "iscasesensitive

# **CHKPTNFEED-1211**

### **NAME**

CHKPTNFEED-1211

### **SUMMARY**

Specified layer [%s] is not within the allowed pin layer range [%s] and [%s] of the partition %s. Respecify a valid pin layer value or change the partition definition to allow this pin layer and rerun the command again.

## **DESCRIPTION**

Specified layer is not within the allowed pin layer range of the specified partition. Use the Partition->Specify Partition GUI to view the current specified allowed layers. Edit the current allowed pin layers of the partition to include this specified pin layer or re-specify pin layer and rerun the command again.

# **CHKPTNFEED-1250**

#### NAME

CHKPTNFEED-1250

#### **SUMMARY**

Pin placement has been enabled on metal layer 1.

### **DESCRIPTION**

You have this message because you have enabled metal layer 1 for pin placement. However, metal layer 1 is generally reserved for follow pins. Make sure follow pins are already routed, to ensure that the pins do not block follow pins creation.

Example:

-----

set\_db design\_bottom\_routing\_layer 1 enables pins in M1

## **CHKPTNFEED-1520**

### **NAME**

CHKPTNFEED-1520

### **SUMMARY**

Pin '%s' of %s '%s' cannot be placed at the constrained location [%0.2f %0.2f] due to a blocked pin slot close to the location. Placing the pin at location [%0.2f %0.2f].

#### DESCRIPTION

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## **CHKPTNFEED-1521**

### **NAME**

CHKPTNFEED-1521

### **SUMMARY**

Unable to get any valid location for the constrained pin [%s] at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## **CHKPTNFEED-1550**

#### NAME

CHKPTNFEED-1550

#### **SUMMARY**

Cell [%s] cannot be specified as a black box because the design does not have any instance associated with this cell or instance may create nested blackBox. Ensure the design has an instance referenced to this cell or specify correct name of cell and rerun %s again.

#### DESCRIPTION

Specified cell cannot be defined as a black box because the design does not have any instance that is referenced to this cell or instance may create nested blackBox. Ensure there is at least one instance that is associated with this cell and rerun the command again.

## **CHKPTNFEED-1669**

#### NAME

CHKPTNFEED-1669

#### **SUMMARY**

Ptn %s does not have any reserved slots for assigning ptn pins. Check the allowed layers for the partition and make sure that layers based on preferred routing tracks are reserved.

#### **DESCRIPTION**

This warning message is issued while assigning pins on a partition using the Innovus GUI with Partition => Assign Pin... or when using the assign\_partition\_pins Tcl command.

The create\_floorplan likely contains a problem with routing tracks and/or pin layer definitions. The problem can be debugged graphically using: Partition => Specify Partition

Select the offending partition and review the Partition Pin Layer Used section. Make sure the layers defined for pins are included in the Layers Reserved For Partition. Corrections may be made and applied with this form. Check the min max layer allowed though get\_db another reason could be presence of route blockage or PG on partition edge blocking the routing tracks.

Next, confirm there are preferred routing tracks defined for the pin layers using the Layer Control =>

Error and Warning Messages

Track => Pref Track and the Wire&Via layer defined for the pins. If the tracks are incorrect, they may be regenerated using the "generateTracks" Tcl command.

### Example:

get pin constraint -cell c -side all -layer

Constraint on partition c:

Allowed layer on side [top]: 246

Allowed layer on side [left]: 35

Allowed layer on side [bottom]: 2 4 6

Allowed layer on side [right]: 35

get db design bottom routing layer design top routing layer

design bottom routing layer 2 # string, default=""

design top routing layer 15 # string, default=""

{design bottom routing layer 2} {design top routing layer 15}

Look for the Tracks in a section with: Track:

While corrections can be made to the tmp.fp file and reloaded with the "read\_floorplan tmp.fp" Tcl command, it is generally easier to do make changes with the Innovus GUI.

## **CHKPTNFEED-1671**

#### NAME

CHKPTNFEED-1671

#### SUMMARY

The option %s cannot be used for updating pin attribute. Correct the command options and run the command again.

#### **DESCRIPTION**

Specified option cannot be used for just updating pin attribute. This option is used with other options for assigning pin location. Check the reference manual for the legal specified options. Then

correct the command options and rerun the editPin command again.

## **CHKPTNFEED-1699**

#### NAME

CHKPTNFEED-1699

#### SUMMARY

Selective-pin-assignment by specifying just partition name(s) to command assign\_partition\_pins is obsolete and will be removed in future releases. The old usage still works in this release, but to avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with "assign\_partition\_pins -partitions -pins".

#### DESCRIPTION

To avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with 'assign\_partition\_pins -partitions <ptnName> -pins <pinName>'

### Example:

-----

\* The following command assign pins name starting with "in" of partition "A" and pins name starting with "out" of partition "B"

assign\_partition\_pins -partitions {A} -pins {in\*} -partitions {B} -pins {out\*}

\* The following command accept a file pinLst.txt that contains the list of pins to be placed for partition A and partition B.

assign\_partition\_pins -partitions A -partitions B -pin\_file pinLst.txt

## CHKPTNFEED-1704

#### NAME

CHKPTNFEED-1704

#### **SUMMARY**

The options [-row] and [-bringBackRow] are obsolete. Rows are brought back automatically, without using any of these options. To avoid this warning and ensure compatibility with future releases, update your script to not use any of these options.

#### **DESCRIPTION**

This messages is issued when obsolete options are used. Using these options will have no impact in this case.

Example:
----eg. use uncommit\_partitions

# **CHKPTNFEED-1717**

#### **NAME**

CHKPTNFEED-1717

## **SUMMARY**

The specifyPartition command will be obsolete in the next release. Use the create\_partition command to define the partitions.

## **DESCRIPTION**

The message occurs because you are using 'specifyPartition' which is obsoletelease use the 'create\_partition' command to define the partitions.

| Example:                                   |
|--------------------------------------------|
|                                            |
| The following example defines a partition: |
| create_partition \                         |
| -hinst ctr_inst \                          |

```
-core_spacing 0.56 0.56 0.0 0.0 \\
-rail_width 0.0 \\
-min_pitch_left 2 \\
-min_pitch_right 2 \\
-min_pitch_top 2 \\
-min_pitch_bottom 2 \\
-reserved_layer {1 2 3 4} \\
-pin_layer_top {2 4} \\
-pin_layer_left {3} \\
-pin_layer_bottom {2 4} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_halo 1.0 1.0 1.0 1.0 \\
-route_halo_bottom_layer 7 \\
-route_halo_bottom_layer 1
```

### **NAME**

CHKPTNFEED-1755

### **SUMMARY**

Pin [%s] of %s [%s] connected to net [%s] is [%s] at location (%8.3f, %8.3f) on layer %1d %s.

## **DESCRIPTION**

Message reports specific error/violation on a partition pin.

Error and Warning Messages

#### Example of ABUTMENT violation on a pin:

-----

Pin [pin\_1] of partition [ptn\_1] connected to net [net\_1] is [PLACED] at location (210.452, 540.160) on layer 8 has ABUTMENT violation WITH partition chip.

In above example error/violation is being reported for partition "ptn\_1" pin's "pin\_1" which is connected to net "net\_1" and is placed at location "210.452, 540.160" on layer "8" having assignment status as "placed". Pin has abutment (is placed on adjoining boundary of "ptn\_1" and "chip") violation with partition named "chip". Ideally the pin pair of two adjoining (abutting) partitions should be placed on same track on edge of partition boundaries, touching each other (abutting).

Abutment violation could be because of following two reasons:

- 1. Net has multi-partition-pins. Since all other pins of different partitions cannot be placed at same location (no electrical connection through any overlap of physical shape), so it is reported as abutment violation.
- 2. "pin\_1" pin of net "net\_1" is not connected to any pin of adjoining (abutted) partition "chip".

List other violations on pin:

- pin min-width violation
- pin min-depth violation
- pin missing metal shape violation
- pin min-area violation
- pin-color violation
- pin not on routing track (or ndr-rule-routing-track) violation
- pin not on fence violation
- pin spacing (drc and spacing constraints) violation
- pin not on allowed layer violation
- For nested partition it checks for child fence area violation
- pin outside pin-guide or bus-guide violation
- Pin associated pin-group or net-group violation

#### NAME

CHKPTNFEED-1802

#### SUMMARY

Route layer setting through routing modes [set\_db %s <value>] or [set\_db %s <value>] setting will not be honored. Set the value using setDesignMode command [set\_db %s <value>] and run the command again.

### **DESCRIPTION**

This message is reported related to IO pin routing if there are any IO pins falls above maxRouteLayer. Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer, and user would like to set min/max layer of pin that is different from route\_early\_global. Innovus checks for this issue and generate the message as user may forget to set min/max layer of pin when it differs from route\_early\_global.



Because of the following reason the ENCPTN-1802 is reported.

Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set db or set db for minLayer but has missed to set setDesignMode for minLayer.

Use "set\_db design\_top\_routing\_layer <layer>" to placing IO pins, to avoid this problem.

## **CHKPTNFEED-3207**

### **NAME**

CHKPTNFEED-3207

#### **SUMMARY**

The hierarchical-PG net %s is connected to an instance term %s inside the partition hinst %s. However, it is not connected to any PG port of the partition hinst. This is erroneous data. As a consequence, instance term %s will become unconnected. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside the partition, and run the command again.

#### DESCRIPTION

Reason of such incorrect PG net connection is generally introduced by either incorrect UPF or incorrect GNC rule. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside partition. Or, if this connection is not needed inside the partition hinst, then ensure that the net does not connect to any of the PG terms inside the partition hinst.

## **CHKPTNPIN-90**

### **NAME**

CHKPTNPIN-90

#### **SUMMARY**

Pin %s of abutted partition %s could not be assigned. Could not find a feasible slot for the pin. Create more feasible location before for pin assignment by inserting feedthrough buffers using add\_partition\_feedthrus command or allowing more layers for assigning pins or using set\_db assign\_pins\_strict\_abutment false or using set\_db assign\_pins\_allow\_unconnected in abutted edge true for relaxing this check.

#### DESCRIPTION

In order to resolve this issue, do the following before pin assignment:

#1 In abutted designs, pins of following type can not be placed on common edges between two adjoining partitions.

Error and Warning Messages

.in +2

- A. Pins of net not connected to adjacent partition (fences of the two partitions being connected are not touching each other in create\_floorplan).
- B. Pins of nets having connections to two or more partitions any pin belonging to net of above type will have to route over an unconnected partition and result in illegal routing.

Feedthrough step is required to get rid of pins which connect non-adjacent partitions or multiple partitions, by changing netlist and making all pins connect to only one pin on adjacent partition to make the routing of net feasible/legal

C. Floating pins

.in

#2. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

- #3. Use set\_db assign\_pins\_strict\_abutment false to relax abutment violations checks for placing multi partition pin of a net, non neighbor pins of a net and floating pins on abutted edges.
- #4. Use set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true to relax abutment violations checks for placing floating pins on abutted edges.

| Exa | -   |    |   |
|-----|-----|----|---|
| ᄆᇂᅬ | 111 | וו | _ |
|     |     |    |   |

-----

eg. if pins are not assigned for a net which has more than two partition pins to connect use add\_partition\_feedthrus command to change netlist to have new nets added and older net modified in way that, now nets only connect two pins of adjacent partitions only.

# **CHKPTNPIN-100**

#### NAME

CHKPTNPIN-100

#### SUMMARY

The net %s is not connected to any terminal. This net will not be considered for feedthrough buffer insertion. Correct the netlist to get this net considered for feedthrough buffer insertion.

#### **DESCRIPTION**

An unconnected net will not be considered for feedthrough insertion. The net should be connected to an output port and an input port to be considered for feedthrough insertion.

# **CHKPTNPIN-233**

#### NAME

CHKPTNPIN-233

#### SUMMARY

No legal free slots available for %s of partition %s. Create additional slots using create\_partition command or by removing blockage before pin assignment.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

Error and Warning Messages

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

## **CHKPTNPIN-426**

#### NAME

CHKPTNPIN-426

#### SUMMARY

Adjusting partition %s core to left from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

<CMD> create\_partition -hinst uCORE/uPKTSS/uPKTSS\_PPCS\_PMA\_SYS -core\_spacing {2.7 2.7 1.9 1.9} -reserved\_layer {1 2 3 4 5 6 7 8} -route\_halo 1.9 -route\_halo\_top\_layer 7 - route\_halo\_bottom\_layer 1 -place\_halo {2.7 2.7 1.9 1.9} -rail\_width 0.1 -min\_pitch\_left 3 - min\_pitch\_right 3 -min\_pitch\_top 3 -min\_pitch\_bottom 3 -pin\_layer\_top {3 5} -pin\_layer\_bottom {3 5} -pin\_layer\_left {4 6} -pin\_layer\_right {4 6}

Error and Warning Messages

Creating partition PKTSS\_PPCS\_PMA\_SYS.

- \*\*WARN: (IMPPTN-426): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to left from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-427): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to right from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-428): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to top from 2.700000 to 2.850000.
- \*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

Placement grid is at 0.135 x-direction, 0.095 y-direction.

# **CHKPTNPIN-427**

#### NAME

CHKPTNPIN-427

#### SUMMARY

Adjusting partition %s core to right from %f to %f because specified core spacing value is not multiple of placement grid.

#### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

<sup>\*\*</sup>WARN: (IMPPTN-427): Adjusting partition lbrx\_top\_0 core to right from 0.000000 to 0.100000.

# **CHKPTNPIN-428**

#### NAME

CHKPTNPIN-428

#### SUMMARY

Adjusting partition %s core to top from %f to %f because specified core spacing value is not multiple of placement grid.

#### **DESCRIPTION**

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

\_\_\_\_\_

## **CHKPTNPIN-429**

#### **NAME**

CHKPTNPIN-429

## **SUMMARY**

Adjusting partition %s core to bottom from %f to %f because specified core spacing value is not multiple of placement grid.

<sup>\*\*</sup>WARN: (IMPPTN-428): Adjusting partition lbrx\_top\_0 core to top from 0.000000 to 3.680000.

#### DESCRIPTION

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

\*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

# **CHKPTNPIN-555**

#### NAME

CHKPTNPIN-555

#### **SUMMARY**

A feasible legal location was not found for %d (out of %d) pins. Consequently, the following pins could not be assigned:

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

A. By removing blockages

B. By removing PG stripes

C. Allow more layers for pin assignment

.in

.in +4

Error and Warning Messages

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## **CHKPTNPIN-624**

#### NAME

CHKPTNPIN-624

#### SUMMARY

add\_partition\_feedthrus could not find a path for net '%s' to reach '%s'. If the -topoFile option is being used, the topology specified for this net is incomplete.

### **DESCRIPTION**

In case automatic feedthrough insertion is being done, it means that a path to some of the terminals could not be found. If the routeBased option is used, the routing may be incomplete. For the case the topology file is used an explanation follows.

Tool issues above warning during add\_partition\_feedthrus command step, when topology file provided with -topoFile is used to guide the tool for creating the feedthrough in a specified partition for multi-fanout nets. You will get above warning if the topology file did not define for all the terminals for a multi-fanout net. Always follow the convention from\_pin to to\_pin for writing the topology file.

#### Example:

If the net goes to three partition A, B and C and you want to make a part of the net from A to D then to C, then you can use the following approach to write the topology file.

net n123

hinst-hinst A D;

hinst-hinst D C;

Error and Warning Messages

hinst-hinst A B;

end net

So, here all the combinations are covered where the net goes, instead of defining the A-D-C.

## **CHKPTNPIN-646**

#### NAME

**CHKPTNPIN-646** 

### **SUMMARY**

add\_partition\_feedthrus is trying to find a feedthrough path for net %s. It could not find a path to partition or terminal [%s]. Partitions connected to this net may not be adjacent to each other.

#### DESCRIPTION

Automatic feedthrough insertion derives the feedthrough topology using the placement. It assumes a channel-less design. The possibility of routing through channels is considered minimal. In this design a path to a partition or terminal connected to the above mentioned net could not be found without avoiding the channels.

# **CHKPTNPIN-647**

### NAME

CHKPTNPIN-647

#### SUMMARY

add\_partition\_feedthrus skipping net [%s] because a path to some of the partitions or terminals could not be found. It might not be necessary to insert feedthrough buffers for this net. If you wish to insert feedthrough buffers for this net, then use the topology file for guided feedthrough buffer insertion or use the -routeBased option after routing the net.

Error and Warning Messages

#### DESCRIPTION

add\_partition\_feedthrus assumes the design to be channel-less and partitions to be in the line of sight for feedthrough path to pass from one partition to another. In case of channel based designs where this is not true, the named net is ignored. In case feedthrough insertion is required for the net, either route the design and used add\_partition\_feedthrus -routeBased or define the path for the net in a topology file and use add\_partition\_feedthrus -topoFile <filename>

Example:
----route\_early\_global
add\_partition\_feedthrus -routeBased
Or
add\_partition\_feedthrus -topoFile <filename>

# **CHKPTNPIN-652**

#### NAME

CHKPTNPIN-652

#### SUMMARY

The push\_down\_buffer command cannot create an instance with name [%s%s]. An instance with this name already exists in the design. Using default prefix and name [%s] for this instance.

#### DESCRIPTION

This message is issued if the push\_down\_buffer uses the prefix provided with the -prefix option and the resulting name has a conflict with an existing instance name. No action needs to be taken as it will make another name with the default prefix.

# **CHKPTNPIN-716**

#### NAME

CHKPTNPIN-716

#### SUMMARY

Partition %s constraint missing. Specify a Guide, Region, Fence constraint on the partition or place the blackbox instance.

#### **DESCRIPTION**

While committing partitions 1. Blackboxes should be placed inside core 2. Partitions fences must be core

# **CHKPTNPIN-780**

#### NAME

CHKPTNPIN-780

#### SUMMARY

Selected pin assignment: could not assign %d (out of %d) pins because feasible legal location was not found for following pins, need legal locations for pin to be assigned.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

Error and Warning Messages

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

# **CHKPTNPIN-882**

### NAME

CHKPTNPIN-882

#### SUMMARY

The add\_partition\_feedthrus command was invoked with the -routeBased option, but the design has not yet been routed. The add\_partition\_feedthrus command will skip the nets that are not routed. Route the design using route\_early\_global for these nets to be considered for feedthrough insertion.

### **DESCRIPTION**

The add\_partition\_feedthrus command invoked with the -routeBased option requires routing for the net to find a path based on which it will insert the feedthrough ports.

The net reported is not routed so it gets ignored. Route the design prior to running this command. The route\_early\_global command can be used to route the design.

Otherwise add\_partition\_feedthrus should be invoked without using the -routeBased option in which case the command will try to find a path for the net based on the create\_floorplan and placement (placement based feedthrough insertion).

Error and Warning Messages

| Example:                             |
|--------------------------------------|
|                                      |
| route_early_global                   |
| add_partition_feedthrus -routeBased. |

# **CHKPTNPIN-946**

### **NAME**

CHKPTNPIN-946

### **SUMMARY**

Pin named [%s] does not exist in cell [%s]. Ignoring the pin. Check and correct the pin name.

### **DESCRIPTION**

Pin name specified for the specified partition does not exist. Check the pin name and partition name and correct accordingly. Problem could be case sensitivity. Command requires exact name which is case sensitive or incorrect manipulation of "alphabet I or numeric 1" "likewise "alphabet o and numeric 0"

Example:

-----

Pin name could be "isCaseSensitive" but pin name supplied could be "iscasesensitive

# **CHKPTNPIN-1211**

### **NAME**

CHKPTNPIN-1211

Error and Warning Messages

### **SUMMARY**

Specified layer [%s] is not within the allowed pin layer range [%s] and [%s] of the partition %s. Respecify a valid pin layer value or change the partition definition to allow this pin layer and rerun the command again.

### DESCRIPTION

Specified layer is not within the allowed pin layer range of the specified partition. Use the Partition->Specify Partition GUI to view the current specified allowed layers. Edit the current allowed pin layers of the partition to include this specified pin layer or re-specify pin layer and rerun the command again.

# CHKPTNPIN-1250

#### NAME

CHKPTNPIN-1250

### SUMMARY

Pin placement has been enabled on metal layer 1.

### DESCRIPTION

You have this message because you have enabled metal layer 1 for pin placement. However, metal layer 1 is generally reserved for follow pins. Make sure follow pins are already routed, to ensure that the pins do not block follow pins creation.



# **CHKPTNPIN-1520**

### NAME

CHKPTNPIN-1520

### **SUMMARY**

Pin '%s' of %s '%s' cannot be placed at the constrained location [%0.2f %0.2f] due to a blocked pin slot close to the location. Placing the pin at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

# **CHKPTNPIN-1521**

### NAME

CHKPTNPIN-1521

### **SUMMARY**

Unable to get any valid location for the constrained pin [%s] at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

\t 1. pin blockages

Error and Warning Messages

- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## **CHKPTNPIN-1550**

#### NAME

CHKPTNPIN-1550

### **SUMMARY**

Cell [%s] cannot be specified as a black box because the design does not have any instance associated with this cell or instance may create nested blackBox. Ensure the design has an instance referenced to this cell or specify correct name of cell and rerun %s again.

### **DESCRIPTION**

Specified cell cannot be defined as a black box because the design does not have any instance that is referenced to this cell or instance may create nested blackBox. Ensure there is at least one instance that is associated with this cell and rerun the command again.

# **CHKPTNPIN-1669**

### NAME

CHKPTNPIN-1669

### **SUMMARY**

Ptn %s does not have any reserved slots for assigning ptn pins. Check the allowed layers for the partition and make sure that layers based on preferred routing tracks are reserved.

### DESCRIPTION

This warning message is issued while assigning pins on a partition using the Innovus GUI with Partition => Assign Pin... or when using the assign partition pins Tcl command.

The create\_floorplan likely contains a problem with routing tracks and/or pin layer definitions. The problem can be debugged graphically using: Partition => Specify Partition

Select the offending partition and review the Partition Pin Layer Used section. Make sure the layers defined for pins are included in the Layers Reserved For Partition. Corrections may be made and applied with this form. Check the min max layer allowed though get\_db another reason could be presence of route blockage or PG on partition edge blocking the routing tracks.

Next, confirm there are preferred routing tracks defined for the pin layers using the Layer Control => Track => Pref Track and the Wire&Via layer defined for the pins. If the tracks are incorrect, they may be regenerated using the "generateTracks" Tcl command.

### Example:

get pin constraint -cell c -side all -layer

Constraint on partition c:

Allowed layer on side [top]: 2 4 6

Allowed layer on side [left]: 35

Allowed layer on side [bottom]: 246

Allowed layer on side [right]: 35

get db design bottom routing layer design top routing layer

design bottom routing layer 2 # string, default=""

design top routing layer 15 # string, default=""

{design\_bottom\_routing\_layer 2} {design\_top\_routing\_layer 15}

Look for the Tracks in a section with: Track:

While corrections can be made to the tmp.fp file and reloaded with the "read\_floorplan tmp.fp" Tcl command, it is generally easier to do make changes with the Innovus GUI.

# **CHKPTNPIN-1671**

### NAME

CHKPTNPIN-1671

### SUMMARY

The option %s cannot be used for updating pin attribute. Correct the command options and run the command again.

### **DESCRIPTION**

Specified option cannot be used for just updating pin attribute. This option is used with other options for assigning pin location. Check the reference manual for the legal specified options. Then correct the command options and rerun the editPin command again.

# **CHKPTNPIN-1699**

### NAME

CHKPTNPIN-1699

### SUMMARY

Selective-pin-assignment by specifying just partition name(s) to command assign\_partition\_pins is obsolete and will be removed in future releases. The old usage still works in this release, but to avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with "assign partition pins-partitions-pins".

## **DESCRIPTION**

To avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with 'assign\_partition\_pins -partitions <ptnName> -pins <pinName>'

Example:

Error and Warning Messages

-----

\* The following command assign pins name starting with "in" of partition "A" and pins name starting with "out" of partition "B"

assign partition pins -partitions {A} -pins {in\*} -partitions {B} -pins {out\*}

\* The following command accept a file pinLst.txt that contains the list of pins to be placed for partition A and partition B.

assign\_partition\_pins -partitions A -partitions B -pin\_file pinLst.txt

## CHKPTNPIN-1704

#### NAME

CHKPTNPIN-1704

### SUMMARY

The options [-row] and [-bringBackRow] are obsolete. Rows are brought back automatically, without using any of these options. To avoid this warning and ensure compatibility with future releases, update your script to not use any of these options.

### **DESCRIPTION**

This messages is issued when obsolete options are used. Using these options will have no impact in this case.

Example:

-----

eg. use uncommit\_partitions

# **CHKPTNPIN-1717**

### **NAME**

CHKPTNPIN-1717

### **SUMMARY**

The specifyPartition command will be obsolete in the next release. Use the create\_partition command to define the partitions.

### **DESCRIPTION**

The message occurs because you are using 'specifyPartition' which is obsoletelease use the 'create\_partition' command to define the partitions.

```
Example:
The following example defines a partition:
create_partition \
-hinst ctr_inst \
-core spacing 0.56 0.56 0.0 0.0 \
-rail width 0.0 \
-min_pitch_left 2 \
-min pitch right 2 \
-min pitch top 2 \
-min_pitch_bottom 2 \
-reserved_layer {1 2 3 4} \
-pin layer top {2 4} \
-pin_layer_left {3} \
-pin_layer_bottom {2 4} \
-pin layer right {3} \
-place halo 1.0 1.0 1.0 1.0 \
-route halo 1.0 \
-route_halo_top_layer 7 \
-route halo bottom layer 1
```

# **CHKPTNPIN-1755**

### NAME

CHKPTNPIN-1755

### SUMMARY

Pin [%s] of %s [%s] connected to net [%s] is [%s] at location (%8.3f, %8.3f) on layer %1d %s.

### **DESCRIPTION**

Message reports specific error/violation on a partition pin.

Example of ABUTMENT violation on a pin:

-----

Pin [pin\_1] of partition [ptn\_1] connected to net [net\_1] is [PLACED] at location (210.452, 540.160) on layer 8 has ABUTMENT violation WITH partition chip.

In above example error/violation is being reported for partition "ptn\_1" pin's "pin\_1" which is connected to net "net\_1" and is placed at location "210.452, 540.160" on layer "8" having assignment status as "placed". Pin has abutment (is placed on adjoining boundary of "ptn\_1" and "chip") violation with partition named "chip". Ideally the pin pair of two adjoining (abutting) partitions should be placed on same track on edge of partition boundaries, touching each other (abutting).

Abutment violation could be because of following two reasons:

- 1. Net has multi-partition-pins. Since all other pins of different partitions cannot be placed at same location (no electrical connection through any overlap of physical shape), so it is reported as abutment violation.
- 2. "pin\_1" pin of net "net\_1" is not connected to any pin of adjoining (abutted) partition "chip".

List other violations on pin:

- pin min-width violation
- pin min-depth violation
- pin missing metal shape violation

- pin min-area violation
- pin-color violation
- pin not on routing track (or ndr-rule-routing-track) violation
- pin not on fence violation
- pin spacing (drc and spacing constraints) violation
- pin not on allowed layer violation
- For nested partition it checks for child fence area violation
- pin outside pin-guide or bus-guide violation
- Pin associated pin-group or net-group violation

# **CHKPTNPIN-1802**

### NAME

CHKPTNPIN-1802

### SUMMARY

Route layer setting through routing modes [set\_db %s <value>] or [set\_db %s <value>] setting will not be honored. Set the value using setDesignMode command [set\_db %s <value>] and run the command again.

### DESCRIPTION

This message is reported related to IO pin routing if there are any IO pins falls above maxRouteLayer. Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer, and user would like to set min/max layer of pin that is different from route\_early\_global. Innovus checks for this issue and generate the message as user may forget to set min/max layer of pin when it differs from route\_early\_global.



-----

Because of the following reason the ENCPTN-1802 is reported.

Error and Warning Messages

Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer.

Use "set\_db design\_top\_routing\_layer <layer>" to placing IO pins, to avoid this problem.

# **CHKPTNPIN-3207**

### NAME

CHKPTNPIN-3207

### SUMMARY

The hierarchical-PG net %s is connected to an instance term %s inside the partition hinst %s. However, it is not connected to any PG port of the partition hinst. This is erroneous data. As a consequence, instance term %s will become unconnected. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside the partition, and run the command again.

### **DESCRIPTION**

Reason of such incorrect PG net connection is generally introduced by either incorrect UPF or incorrect GNC rule. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside partition. Or, if this connection is not needed inside the partition hinst, then ensure that the net does not connect to any of the PG terms inside the partition hinst.

## CHKTB-2

### NAME

CHKTB-2

### **SUMMARY**

Cannot complete command %s, not able to open %s for write, provide a file path which can be

opened for write to complete execution.

### DESCRIPTION

The possible reasons you have this message might be:

- 1. You may not have necessary file operation permissions to create a file on current working directory.
- 2. There is a same-name file which you do not have write permission on it.
- 3. You may have run out of disk space.

Example:

Check whether you have permission to create a file on current working directory:

innovus 7> file writable [pwd]

1

Check whether you have a same-name file which you do not have write permission on it on current working directory:

```
set fileName innovus.log1

if {[file exists $fileName]} {

puts [file writable $fileName]
} else {

puts 0
}
```

Check if you have run out of disk space:

innovus 16> df -kH [pwd]

Filesystem Size Used Avail Use% Mounted on

/dir/subdirectory1/case/case11189 2.2T 2.0T 271G 88% /dir/subdirectory1/case/case11189

# **CHKTB-36**

### NAME

CHKTB-36

### **SUMMARY**

Partition name %s does not match a hierarchical instance or a black box and will be ignored.

### **DESCRIPTION**

The specified name does not match an uncommitted partition (hierarchical instance with a fence) or a black box (create\_floorplan block object).

Example:

create\_timing\_budget -partitions ptnA

Warning: Partition name ptnA does not match a hierarchical instance or a black box and will be ignored.

# **CHKTB-178**

### **NAME**

CHKTB-178

### **SUMMARY**

Command set\_fixed\_budget cannot accept option "-from\_flops\_of" and "-to\_flops\_of" together.

### **DESCRIPTION**

set\_fixed\_budget command can only be applied on a path segment. Please use it with pins at either "-from" or "-to" option.

# **CHKTB-521**

### NAME

CHKTB-521

### **SUMMARY**

No SDC file found for analysis view %s. Make sure analysis views are properly constrained prior to running create timing budget.

### **DESCRIPTION**

Check if viewDefinition file has correct SDC files (not a physical only flow or absent timing constraints).

# **CHKTB-522**

### NAME

CHKTB-522

## **SUMMARY**

Partition %s's ports %s and %s are connected through verilog assign. Budgeting requires a physical pin inside partition in order to budget timing path inside partition.

### **DESCRIPTION**

Verilog assign statements can be removed using 'delete\_assigns -buffering' command before running create\_timing\_budget.

### NAME

IMPAFP-1873

### SUMMARY

Old constraint file format for plan design.

### **DESCRIPTION**

This message occurs because the constraint file format you have specified for plan\_design is not up-to-date. Please use 'plan\_design -generate\_template\_only <file>'to get a template file or use 'mp::dumpConstraint <outFile>' to convert your constraint to new format.

### Example:

For more detail, please run 'man plan design'.

# **IMPAFP-1909**

### **NAME**

**IMPAFP-1909** 

### **SUMMARY**

Same seed name %s specified twice in constraint file.

### DESCRIPTION

If constraint file has same seed name defined under BEGIN SEED statement then the commands "plan\_design -constraint <file\_name>" and "multiPlanDesign-constraint <file\_name> on " will output this warning.

Example:

Error and Warning Messages

Say a constraint file 'seed.txt' has the below content :-

**BEGIN SEED** 

name= DTMF INST/SPI INST util=0.6 createFence=true

name= DTMF INST/SPI INST util=0.75 createFence=true minFenceToFenceSpace=60

**END SEED** 

Then, 'plan\_design -constraint seed.txt' or 'plan\_design\_multi -constraint seed.txt on' will give the warning. " \*\*WARN: (IMPAFP-1909): Same seed name DTMF INST/SPI INST specified twice in constraint file.

# **IMPAFP-2031**

### NAME

IMPAFP-2031

### **SUMMARY**

Module %s has a createFence=true constraint on it, but it already has a fence in the database. Check constraint file and remove this constraint to avoid this message.

## **DESCRIPTION**

When parsing the constraints file plan\_design verifies modules with createFence=true are not already defined as fences in the create\_floorplan. If they are, this error message is issued. To avoid this error remove this constraint from the plan\_design constraint file or edit the attributes of the module and change its Constraint Type to None.

Example:

**BEGIN SEED** 

name=%s createFence=true

### NAME

IMPAFP-3353

### SUMMARY

Failed to honor at least one MPGroup Fence|Hard or Power Domain constraint.

### **DESCRIPTION**

Check plan\_design constraint file whether the seed names are provided correctly."name" in the constraint file should be a hierarchy or inst group.

Example:

Example:

**BEGIN SEED** 

name=A1/B2 util=0.75

name=C1/D3/M5 createFence=true minFenceToFenceSpace=60

name=E1 minWHRatio=0.25 maxWHRatio=4.0

name=F2 master=E1 cloneOrient={R0|MX}

name=PDGp1 util=0.6 createFence=true minFenceToInsideMacroSpace=10

# H1 and H2 can be existing fences.

name=H1 minFenceToInsideMacroSpace=10 minFenceToOutsideMacroSpace=10

name=H2 minInsideFenceMacroToMacroSpace=15

**END SEED** 

### NAME

IMPAFP-3928

### SUMMARY

Something wrong in parsing your seed file %s.

### **DESCRIPTION**

The message is issued due to syntax error that is parsed as constraint file for plan\_design. User to look and correct the syntax.

Example:

Follow below example for correct syntax

For example:

**BEGIN SEED** 

name=A1/B2 util=0.75

name=C1/D3/M5 createFence=true minFenceToFenceSpace=60

name=E1 minWHRatio=0.25 maxWHRatio=4.0

name=F2 master=E1 cloneOrient={R0|MX}

name=PDGp1 util=0.6 createFence=true minFenceToInsideMacroSpace=10

# H1 and H2 can be existing fences.

name=H1 minFenceToInsideMacroSpace=10 minFenceToOutsideMacroSpace=10

name=H2 minInsideFenceMacroToMacroSpace=15

**END SEED** 

### NAME

IMPAFP-3952

### **SUMMARY**

It is not recommended to run plan design with too many instances (%d) already pre-placed.

### **DESCRIPTION**

Too many preplaced std. cells can affect plan\_design quality as well as slow down run. So we will issue this ERROR message when pre-placed instances is over 5000 for non-IO & non-Hardmacro.

Example:

[DEV]innovus 4> place\_itag -nrRowLeft 8 -nrRowRight 8 -nrRowTop 8 -nrRowBottom

[DEV]innovus 4> plan\_design

**Design Statistics:** 

Fixed StdCells: 9113, Fixed HMs: 0, IO Cells: 982

\*\*ERROR: (SOCAFP-3952): It is not recommended to run plan design with too many

instances (9113) already pre-placed.

The limit is 5000 non-IO non-Hardmacro pre-placed standard cells.

Please use setPlanDesignMode -freePreplaced or setPlanDesignMode

-ignorePreplaced to continue

# **IMPAFP-5000**

#### NAME

IMPAFP-5000

### **SUMMARY**

Seed constraint %s at line %d is not a fence in db. Ignore this constraint.

### DESCRIPTION

check\_floorplan\_space will check fences inside Masterplan constraint file. If it is not fence, it will issue this message to tell user check floorplan space will not check it.

### Example:

(1) Seed file

**VERSION 1.0** 

**BEGIN SEED** 

name=U\_IOP/U\_IOP\_MPI

name=U IOP/U IOP MPI

**END SEED** 

(2)

<CMD> check floorplan space -reportWarning -constraint tn seed

\*\*WARN: (IMPAFP-5000): Seed constraint U\_IOP/U\_IOP\_MPI at line 3 is not a

fence in db. Ignore this constraint.

# **IMPAFP-5002**

### NAME

IMPAFP-5002

#### SUMMARY

Macro constraint %s at line %d is not placed in db (macro %s). Ignore this macro.

### **DESCRIPTION**

This warning comes during plan\_design -constraint <> or multiPlanDesign-constraint <> when there is Macro defined in Macro Section BEGIN MACRO ... END MACRO in constraint file without isCell=true/false defined for the macro.

# **IMPAFP-5029**

### NAME

IMPAFP-5029

#### SUMMARY

Found Fence to fence violation on area %.3f %.3f %.3f %.3f for fence %s and %s.

## **DESCRIPTION**

We could add this line along with the existing WARN message. There is not enough area for fence to adjust its location inside core area hence there is overlap between fences.

### Example:

(1) Seed file

**VERSION 1.0** 

**BEGIN SEED** 

name=U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[9].U\_IOP\_CHANNEL createfence=true util=0.75 minFenceToFenceSpace=50

name=U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[10].U\_IOP\_CHANNEL createfence=true util=0.75 minFenceToFenceSpace=50

name=U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[11].U\_IOP\_CHANNEL createfence=true util=0.75 minFenceToFenceSpace=50

**END SEED** 

(2)

<CMD> plan\_design -constraints\_file tn\_seed.11

Error and Warning Messages

\*\*WARN: There is not enough area for fence to adjust its location inside core area hence there is overlap between fences.

\*\*WARN: (IMPAFP-5029): Found Fence to fence violation on area 995.150 335.650 1203.670 335.750 for fence

U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[9].U\_IOP\_CHANNEL and U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[11].U\_IOP\_CHANNEL.

# **IMPAFP-9003**

### **NAME**

IMPAFP-9003

### **SUMMARY**

No license for %s In Innovus 11.1 and prior.

### **DESCRIPTION**

The error is reported because Innovus does not have the proper license available to run these features.%s requires one of the following licenses. The command in parenthesis shows what options to use when invoking the tool to check out the proper license:For more information on Innovus Digital Implementation (Innovus) System licensing and packaging please see the chapter titled "Product and Licensing Information"in the Innovus User Guide.

#### Example:

First Innovus XL or GXL (innovus -fext or -fegxt)

SOC Innovus XL or GXL (innovus -socexl or -socegxl)

Innovus Digital Implementation System L or XL (velocity -edsl or -edsxl)

### NAME

IMPAFP-9021

### SUMMARY

Failed to read in timing data, check timing constraint or library, set timing Driven false.

### **DESCRIPTION**

plan\_design command in Innovus generates a quick, initial create\_floorplan that can be used as a starting point for making the final create\_floorplan. Use the plan\_design command to create multiple alternative floorplans. User can then test the floorplans to find the one that gives the best placement and routing results. PlanDesign can be run in timingDrivenMode. By default, Automatic Floorplan Synthesis takes timing constraints into account during create\_floorplan generation, if timing libraries (.lib) and SDC constraint files are loaded in the design. It will not perform timing aware floorplanning if either the timing library or constraint file is not loaded, and if either liberty or constraint file is missing plan\_design would issue the warning message: "Failed to read in timing data, check timing constraint or library, set timingDriven false." This warning message is added to tell user the reason is that the timing data is lacking or not colmplete.

# IMPAFP-9117

### **NAME**

**IMPAFP-9117** 

## **SUMMARY**

Set option %s to on, it is invalid to use -autoTrial -%s on\_off.

## **DESCRIPTION**

Error and Warning Messages

If you specify the -auto\_trials parameter, you can specify only the on value for boolean parameters. You cannot specify on\_off. For example, you can specify -boundaryPlace on, but you cannot specify -boundaryPlace on\_off.

### Example:

- <CMD> plan design multi -auto trials 2 -cong aware on off
- -effort medium # string, default=medium
- \*\*WARN: (IMPAFP-9117): Set option congAware to on, it is invalid to use
- -autoTrial -congAware on off.

# IMPAFP-9641

#### NAME

IMPAFP-9641

### **SUMMARY**

Constraint file %s does not exist. Check input.

### **DESCRIPTION**

The message is issued due to syntax error that is parsed as constraint file for plan\_design. User to look and correct the syntax.

### Example:

Follow below example for correct syntax

For example:

**BEGIN SEED** 

name=A1/B2 util=0.75

name=C1/D3/M5 createFence=true minFenceToFenceSpace=60

name=E1 minWHRatio=0.25 maxWHRatio=4.0

name=F2 master=E1 cloneOrient={R0|MX}

Error and Warning Messages

name=PDGp1 util=0.6 createFence=true minFenceToInsideMacroSpace=10 # H1 and H2 can be existing fences.

name=H1 minFenceToInsideMacroSpace=10 minFenceToOutsideMacroSpace=10 name=H2 minInsideFenceMacroToMacroSpace=15

**END SEED** 

# IMPAFP-9642

### NAME

IMPAFP-9642

### **SUMMARY**

The utilization of seed %s is greater than %100.

### **DESCRIPTION**

Density over 100% is likely caused by PlanDesign shrinking its constraint to avoid an overlap. One solution for this case is to setPlanDesign -refineSeed{-rectilinearGuides}. This will enable the refineSeed to create the rectilinear guides to avoid overlaps. In default, plan\_design only create rectangle guides.

Example:

setPlanDesign -refineSeed {-rectilinearGuides}

# **IMPAFP-9643**

### **NAME**

IMPAFP-9643

### **SUMMARY**

The needed area is greater than the available place area in fence %s with current utilization %f, adjust the fence utilization to %f.

### **DESCRIPTION**

This Warning message is generated when total cell area of the module/modules assigned to this fence is greater than available placable area in the fence

### Example:

In order to fix this issue the user needs to change the fence utilization,

thereby increasing placement area in the Fence. This can be done using

Move/Resize/Reshape button in the create\_floorplan GUI or by re-running "create\_fence"

command with the increased box size

# IMPAFP-9644

### **NAME**

IMPAFP-9644

### **SUMMARY**

Adjust the seed %s utilization from %f to %f.

### DESCRIPTION

When defining utilization for fence is too small in Masterplan constraint file,total fence area is possible too large and over core area. In this condition,tool will issue this message. We could add this line along with the existing WARN message being specified.

### Example:

(1) Seed file:

**VERSION 1.0** 

#### **BEGIN SEED**

name=U IOP/U IOP MPI createfence=true util=0.3

name=U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[0].U\_IOP\_CHANNEL

createfence=true util=0.3

name=U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[1].U\_IOP\_CHANNEL

createfence=true util=0.3

#### **END SEED**

(2) plan\_design -constraints\_file tn\_seed.11

\*\*WARN: (IMPAFP-9644): Adjust the seed U\_IOP/U\_IOP\_MPI utilization from

0.300000 to 0.727028.

\*\*WARN: (IMPAFP-9644): Adjust the seed

U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[0].U\_IOP\_CHANNEL utilization from 0.300000 to 0.727028.

\*\*WARN: (IMPAFP-9644): Adjust the seed

U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[1].U\_IOP\_CHANNEL utilization from 0.300000 to 0.727028.

# IMPAFP-9645

### NAME

IMPAFP-9645

### SUMMARY

The needed area is greater than the available place area in top level, adjust the fence utilization to %f.

### DESCRIPTION

When fence utilization in the Masterplan constraint file is too small, the fence area is possible

Error and Warning Messages

greater than the available place area in top level. In this scenario, it will issue this message.

### Example:

(1) Seed file of tn\_seed.11

**VERSION 1.0** 

**BEGIN SEED** 

name=U IOP/U IOP MPI createfence=true util=0.3

name=U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[0].U\_IOP\_CHANNEL

createfence=true util=0.3

name=U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[1].U\_IOP\_CHANNEL createfence=true util=0.3

#### **END SEED**

(2) plan\_design -constraints\_file tn\_seed.11

\*\*WARN: (IMPAFP-9645): The needed area is greater than the available place area in top level, adjust the fence utilization to 0.727028.

\*\*WARN: (IMPAFP-9644): Adjust the seed U\_IOP/U\_IOP\_MPI utilization from 0.300000 to 0.727028.

\*\*WARN: (IMPAFP-9644): Adjust the seed

U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[0].U\_IOP\_CHANNEL utilization from 0.300000 to 0.727028.

\*\*WARN: (IMPAFP-9644): Adjust the seed

U\_IOP/INSTANCE\_IOP\_CHANNEL\_AND\_CLK\_GATING[1].U\_IOP\_CHANNEL utilization from 0.300000 to 0.727028.

# IMPAFP-9649

### NAME

IMPAFP-9649

### **SUMMARY**

The option %s is not supported in high effort; it is a medium effort option.

### **DESCRIPTION**

setPlanDesignMode -keepGuide is only supported when Automatic FloorPlan Synthesis is run in medium effort.Module guides created as part of Automatic FloorPlan Synthesis can be either retained or discarded. This can be controlled by option:

### Example:

The following script will result in this error when using Innovus version 13.1 and

older

setPlanDesignMode -effort high

setPlanDesignMode -keepGuide false

plan\_design

To avoid this error, change effort from -high to -medium

setPlanDesignMode -effort medium

setPlanDesignMode -keepGuide false

plan\_design

# **IMPAFP-9801**

#### NAME

IMPAFP-9801

### SUMMARY

Cannot find any instance pins or hierarchical instance pins from specified %s points '%s'.

### DESCRIPTION

Error and Warning Messages

The specified start points or end points should be hinst or hinst pins or instance pins.

### Example:

```
<CMD> create dataflow bus -name dataflow1 {{hinst1/inst1*/out* hinst2/inst2*/in*}}
```

<CMD> create\_dataflow\_bus -name dataflow2 {{hinst1 hinst2} {hinst1 hinst3}}

# **IMPAFP-9805**

### NAME

IMPAFP-9805

### **SUMMARY**

The format of data flow bus definition is not correct.

## **DESCRIPTION**

The format is {{<startPoint> <endPoint>}\*}

### Example:

<CMD> create dataflow bus -name dataflow1 {{hinst1/inst1\*/out\* hinst2/inst2\*/in\*}}

<CMD> create\_dataflow\_bus -name dataflow2 {{hinst1 hinst2} {hinst1 hinst3}}

# **IMPAFP-9811**

### NAME

IMPAFP-9811

### **SUMMARY**

Not flatten '%s' since no hierarchical instances under '%s' will be placed.

#### DESCRIPTION

If the area of a hierarchical instance is less than one fiftieth of parent's, it will not be placed. Please check if there are hierarchical instances under the specified module and the area of hierarchical instances.

# **IMPAFPU-3817**

#### NAME

IMPAFPU-3817

### SUMMARY

-timing is ignored because .lib or sdc is not available.

### **DESCRIPTION**

The option -timing is ignored because timing information is not available. Check to make sure both timing libraries and SDC constraints have been loaded properly. Timing libraries are defined using create\_library\_set and SDC constraints are defined using create\_constraint\_mode. These commands are either part of a user initialization (TCL) script or in the viewDefinition.tcl file that is part of the design database. Verify that this information is being defined properly and that the relevant files exist and are readable.

# **IMPAFPU-3819**

## **NAME**

IMPAFPU-3819

### **SUMMARY**

-timing is ignored in low effort.

#### DESCRIPTION

Command analyze\_floorplan with low effort provides cluster mode placement (non-timing driven). This results in low analysis accuracy, but a fast run time. Option '-timing' is ignored in low effort because placement is in cluster mode and without timing driven. Option '-timing' can be specified in medium or high effort analyze\_floorplan.

# **IMPAFPU-9005**

### **NAME**

IMPAFPU-9005

### **SUMMARY**

In Flex-model flow, 'analyze\_floorplan -cong' should be run before 'analyze\_floorplan -timing' to ensure the design is routable before checking timing.

## **DESCRIPTION**

In Flex-model flow, analyze\_floorplan -timing is running by 4 iterations of timing-driven route\_trial by default. During the flex model flow the first call to analyze\_floorplan is recommended to use analyze\_floorplan -cong (instead of -timing) to run route\_trial only once and make sure quickly that your design is routable.

# **IMPAFPU-9201**

## **NAME**

IMPAFPU-9201

### **SUMMARY**

The created fence of %s overlaps with HInst %s.

#### DESCRIPTION

Fence has a boundary shape that overlaps with the bounding box for another hierarchical instance. Remove the overlap by resizing one of the objects. To do this, select the object in the GUI and use the resize button or use set\_obj\_floorplan\_box and set\_floorplan\_rects commands to redefine the boundary.

# **IMPAFPU-9202**

### **NAME**

IMPAFPU-9202

### **SUMMARY**

The created fence of %s overlaps with Inst %s.

### **DESCRIPTION**

Fence has a bounding box that overlaps with the placement of instance. If the instance should be placed inside the fence, then add it to the instance group using 'update\_inst\_group <group> <instance>'. If not, then remove the overlap by resizing the fence or by moving the instance.

# IMPCCD-3001

### **NAME**

IMPCCD-3001

### **SUMMARY**

To avoid passing multi-view timing information to CCD when only one view's constraints are read in by CCD, please use: %s -view <view name>

### DESCRIPTION

In MMMC Mode, constraints may be specified using the -view or -constraints options. By default, a timing report file is generated for all MMMC views but given that CCD only supports reading a single mode SDC there may be a mismatch between the multi-view timing information and single-view constraints passed to CCD To ensure CCD is passed the same view timing and SDCs, use: deriveFalsePathCCD -view <view\_name> Example:

**IMPCCOPT-1007** 

### **NAME**

IMPCCOPT-1007

### **SUMMARY**

Did not meet the max transition constraint, %s

deriveFalsePathCCD -view mission+worst-rcTyp

#### DESCRIPTION

Failure to meet a maximum transition time constraint in the clock tree network usually occurs because:

- Specified transition time is too low. Use 'get\_db cts\_target\_max\_transition\_time' to check the global setting, and 'get\_db clock\_tree:<clk> .cts\_target\_max\_transition\_time' to check the setting on each clock tree. Use 'report\_clock\_trees' to get a list of violating pins, then check the dont\_touch attribute on the attached net.
- A net cannot be buffered because it has been marked dont\_touch. Use 'report\_clock\_trees' to get a list of violating pins, then check the dont\_touch attribute on the attached net.
- A net cannot be buffered because some aspect of the floorplan (power domains, blockages,

Error and Warning Messages

regions, macros or other fixed instances), prevent placement of buffers.

- Detailed routing of the clock tree has produced routing detours, or excessive numbers of small jogs with vias.

For floorplan and/or routing issues, find the offending net(s) with 'report\_clock\_trees' as above, and observe the floorplan where the net has been routed.

# **IMPCCOPT-1013**

#### NAME

IMPCCOPT-1013

### SUMMARY

The cts\_target\_max\_transition\_time is too low for at least one clock tree, net type and timing corner. Search the log for the string 'Too low;' to find the minimum acceptable targets for each combination. CTS will now terminate.

### **DESCRIPTION**

This usually occurs because:

- The transition time specified has no units specified. For example a user may specify a transition time target of 0.1, not realizing that the library units are ps. In this case, specify the units explicitly (0.1ns instead of 0.1).
- The specified list of clock tree cells (buffers, inverters, clock gates) is very weak. Use 'check\_cts\_config' to obtain a list of clock tree cells used, and check their drive strength.

If you have reason to believe this is not a problem in your design (eg. it only applies to one power domain which does not need buffering), then the test can be overridden with the attribute cts\_exit\_if\_transition\_target\_over\_constrained. Forcing CTS to proceed with a value that is too low here may cause long runtimes.

#### NAME

IMPCCOPT-1014

#### SUMMARY

In power domain %s, CTS has found that %s can drive %lfcm of wire. This will effectively result in CTS ignoring placement. %s

### **DESCRIPTION**

CTS timing code has found that a single buffer can drive a huge amount of wire in a given power domain. This could be caused by one or more of the following:

- 1) The layer technology information in the LEF file(s) might be missing or incorrect.
- 2) An operating condition might be incorrectly configured or using incorrect library data.
- 3) A capacitance or resistance multiplier may be set incorrectly.
- 4) The QRC technology file (or captables if no QRC technology file is present) is incorrect.
- 5) A buffer cell may be poorly characterized.
- 6) The SDC file and .lib files may be in different time or capacitance units.

## **IMPCCOPT-1020**

### **NAME**

IMPCCOPT-1020

### SUMMARY

None of the base\_cells specified in CCOpt attribute %s are usable. Clock tree synthesis for clock tree %s will not be possible.

#### DESCRIPTION

Clock tree synthesis requires at least one buffer cell and one inverter cell to start. When these cannot be found, there are several possible causes:

-There is no explicit cell list set, and all of the clock tree buffers and inverters in the library are marked dont\_Use. Either set an explicit list of cells, or mark the clock tree cells needed as 'dont Use false' (see examples below).

If you have set an explicit list of cells, this message could occur because:

1.the cells listed are missing descriptions in one more analysis views.

2.the cells listed are not usable in a power domain where the named clock tree must be buffered.

3.none of the cells listed have balanced rise/fall characteristics.

For Example:

To designate an explicit lists of cells as buffer cells, inverter cells (NOTE:Both should be set in all cases):

set\_db cts\_buffer\_cells <cell list> [-clock\_tree <name>]

set db cts inverter cells <cell list> [-clock tree <name>]

To set cells with name pattern CK\* as usable cell:

innovus> set opt dont use CK\* false

## IMPCCOPT-1021

#### NAME

IMPCCOPT-1021

### **SUMMARY**

The lib cell '%s' specified in %s attribute is not a valid %s. Either remove this cell from the list, or check the .lib model description.

### **DESCRIPTION**

The user has specified a lib cell in a list of cells to be used by CTS (buffers, inverters, clock gates,

delay cells), but the cell specified does not have the requisite function. Either remove the cell from the list defined by CCOpt attributes (cts\_buffer\_cells, cts\_inverter\_cells, cts\_clock\_gating\_cells, cts\_logic\_cells, cts\_delay\_cells), or look closely at the .lib model description.

## **IMPCCOPT-1023**

#### NAME

IMPCCOPT-1023

#### **SUMMARY**

Did not meet the skew target of %s

#### **DESCRIPTION**

The user can specify the skew limit on specific skew groups (explore set\_db cts\_target\_skew). Failure to meet this constraint could occur because the skew limit target (set by the CCOpt property cts\_target\_skew) is too tight for CTS to achieve. If that target is reasonable, then check the result of 'report\_skew\_groups' for the following items:

- 1. One or more nets in the clock tree are unbufferable.
- 2. Poor availability of clock tree buffer/inverter cells.
- 3. A skew target had to be slackened off due to conflicts with other skew groups. Check the log file for messages containing the phrase 'slackened off'.

## **IMPCCOPT-1026**

### **NAME**

IMPCCOPT-1026

#### SUMMARY

Did not meet the insertion delay target of %s

#### DESCRIPTION

The user can specify the insertion delay limit on specific skew groups (explore set\_db cts\_skew\_group\_target\_insertion\_delay). Failure to meet this constraint could occur because the insertion delay limit target (set by the CCOpt attribute cts\_skew\_group\_target\_insertion\_delay) is too tight for CTS to achieve. If that target is reasonable, then check the result of 'report\_skew\_groups' for the following items:

- 1. One or more nets in the clock tree are unbufferable.
- 2. Poor availability of clock tree buffer/inverter cells.
- 3. An insertion delay target had to be slackened off due to conflicts with other skew groups. Check the log file for messages containing the phrase\0'slackened off'.

## IMPCCOPT-1033

#### NAME

IMPCCOPT-1033

### **SUMMARY**

Did not meet the max capacitance constraint of %s

#### DESCRIPTION

This warning at the end of the CCOpt run indicates that the max\_capacitance constraint is not met on certain clock tree cell in a given clock tree.

This could happen for the following reasons:

- 1. Inappropriate max capacitance constraint on clock tree cells (too tight to be achieved).
- 2. One or more of the nets in the clock tree are unbufferable, due to power\_domain, blockages, region constraints or dont\_touch settings.
- 3. Congestion has yielded detoured nets during detailed routing of the clock nets.
- 4. The clock tree has a very large load (such as memory, hard blocks) that exceeds the max\_capacitance limit on its own.

#### NAME

IMPCCOPT-1038

#### SUMMARY

CTS cannot be performed on this design currently because no area is available in which to place clock tree cells in the entire floorplan. Check that you have some rows defined which are not covered by blockages.

### **DESCRIPTION**

CTS cannot be performed on this design currently because no area is available in which to place clock tree cells in the entire floorplan. Check that you have some rows defined which are not covered by blockages. You can use the attribute cts\_exit\_if\_no\_placeable\_area to control whether the CTS step should halt when this problem is detected.

## IMPCCOPT-1041

#### NAME

IMPCCOPT-1041

#### **SUMMARY**

The cts\_clock\_tree\_source\_output\_max\_transition\_time is set for %s, but cts\_clock\_tree\_source\_max\_capacitance is not. %s will assume a maximum driven capacitance of %s.

### **DESCRIPTION**

At the root pin of the clock tree, the user has set a target for the transition time at the output pin, but has not a max capacitance constraint at the pin. CTS will compute and use a reasonable value for

Error and Warning Messages

the maximum capacitance. If you are satisfied with this setting, you need not do anything. If not, then set cts\_clock\_tree\_source\_max\_capacitance explicitly.

## IMPCCOPT-1051

#### NAME

IMPCCOPT-1051

### **SUMMARY**

No sources are specified for skew group %s. At least one pin must be specified as the source of a skew group.

### **DESCRIPTION**

This skew group is missing its source pin(s), i.e. the reference pin(s) relative to which all of the sinks will be balanced. Correcting this requires deleting and redefining this skew group, making sure the '-sources' argument is included when you redefine it.

## **IMPCCOPT-1052**

#### NAME

IMPCCOPT-1052

#### **SUMMARY**

Skew group %s has source %s which is in the transitive fanout of source %s. Skew group sources must be unrelated to balance the skew group. This can probably be fixed by removing the redundant/conflicting sources.

## **DESCRIPTION**

A skew group in CCOpt may have multiple sources, but among the sources of a skew group no

Error and Warning Messages

source may be in the fanout cone of any other. This must be resolved by removing the source that is in the fanout cone. Also, check the SDC file to see if the sources of the corresponding SDC clock are correct.

## **IMPCCOPT-1053**

#### NAME

IMPCCOPT-1053

#### SUMMARY

CTS has set the cts\_opt\_ignore attribute on clock tree %s. This clock tree cannot be synthesized. It is most likely that there are no buffers or inverters available for this clock tree, or this clock tree is in a dont\_touch module or all nets in this clock tree are dont\_touch or this clock tree is in an unbufferable or fully blocked power-domain.

#### DESCRIPTION

CTS has set the cts\_opt\_ignore attribute on the cts\_clock\_tree. This clock tree cannot be synthesized.

This may have occurred for any/all of the following reasons:

- 1) All nets in the clock tree are dont touch.
- 2) The clock tree is in a dont touch module.
- 3) The clock tree is in an unbufferable or fully-blocked power-domain.
- 4) There are no buffers or inverters available to use for the clock tree. You may be able to fix this issue by specifying base\_cells for CTS to use, with the cts\_buffer\_cells and cts\_inverter\_cells attributes on this clock tree.

## **IMPCCOPT-1062**

#### NAME

IMPCCOPT-1062

## **SUMMARY**

The following skew groups have invalid sink and/or ignore\_pin assignments: %s

#### **DESCRIPTION**

This occurs when one or more has been specified as either active sink pins or ignore pins of a skew group, but the pin does not reside in the clock tree network. All pins on skew groups must reside in the clock tree network. This usually occurs because of incorrect user edits made to the skew groups and/or clock trees after automatic creation of the clock tree specification with create clock tree spec.

# **IMPCCOPT-1070**

#### NAME

IMPCCOPT-1070

### **SUMMARY**

Found no matching paths from %s.

### **DESCRIPTION**

The source indicated was specified as an argument to -from in the report\_skew\_groups command, however no paths matched begin at this pin.

# **IMPCCOPT-1071**

## **NAME**

IMPCCOPT-1071

### **SUMMARY**

Found no matching paths through %s.

### **DESCRIPTION**

The pin indicated was specified as an argument to -through in the report\_skew\_groups command, however no paths matched run through this pin.

# **IMPCCOPT-1072**

### NAME

IMPCCOPT-1072

## **SUMMARY**

Found no matching paths to %s.

## **DESCRIPTION**

The sink indicated was specified as an argument to -to in the report\_skew\_groups command, however no paths matched terminate at this pin.

# **IMPCCOPT-1073**

#### NAME

IMPCCOPT-1073

## **SUMMARY**

Found no matching paths in any skew groups.

## **DESCRIPTION**

The arguments supplied define no paths through any skew group.

## **IMPCCOPT-1074**

### **NAME**

IMPCCOPT-1074

#### SUMMARY

Created clock sink for %s, which was an enable pin of a clock gate.

### DESCRIPTION

A clock gate enable pin was found in the clock tree and a clock sink was created. This means the clock gate will not be subject to some optimizations, and will be treated as if it were a piece of combinational logic. It will appear in the clock tree visualizations with a question-mark symbol.

# **IMPCCOPT-1075**

#### NAME

IMPCCOPT-1075

#### SUMMARY

In %s, CTS timing code has found that %s is unable to drive any amount of wire when buffering another instance of itself. %s

#### DESCRIPTION

CTS timing code has found that a single buffer is unable to drive any amount of wire when buffering another instance of itself. This could be caused by one or more of the following:

1) The wire data in the loaded LEF file(s) might be missing or broken.

Error and Warning Messages

- 2) An operating condition might be incorrectly configured or using incorrect library data.
- 3) A capacitance multiplier may be set incorrectly.
- 4) A resistance multiplier may be set incorrectly.
- 5) A buffer cell may be poorly characterized.
- 6) The SDC file and .lib files may be in different time or capacitance units.

# **IMPCCOPT-1080**

#### NAME

IMPCCOPT-1080

### **SUMMARY**

Unable to find a %d signal from %s to %s.

### **DESCRIPTION**

Either a rise or fall (or both) output signal from one cell to the pin of another could not be determined.

## **IMPCCOPT-1081**

#### NAME

IMPCCOPT-1081

### **SUMMARY**

Could not determine if the lib\_cell %s has at least one valid %s.

## **DESCRIPTION**

During balancing, a lib cell can be rejected if at least one input and one output could not be found.

## **IMPCCOPT-1088**

### **NAME**

IMPCCOPT-1088

#### SUMMARY

The clustering attempt breaks insertion delay targets. Trying again.

### DESCRIPTION

A clustering attempt breaks insertion delay constraints. After CCOpt issues this message, an additional clustering will be attempted to try and meet the constraints.

## IMPCCOPT-1089

#### NAME

IMPCCOPT-1089

### **SUMMARY**

Did not meet the cts max source to sink net length constraint of %s

### **DESCRIPTION**

This warning at the end of the CCOpt run indicates that the cts\_max\_source\_to\_sink\_net\_length constraint is not met below certain clock tree cell in a given clock tree.

This could happen for the following reasons:

1. Inappropriate cts\_max\_source\_to\_sink\_net\_length constraint (too tight to be achieved).

Error and Warning Messages

- 2. One or more of the nets in the clock tree are unbufferable, due to power\_domain, blockages, region constraints or dont\_touch settings.
- 3. Congestion has yielded detoured nets during detailed routing of the clock nets.

## **IMPCCOPT-1090**

#### NAME

IMPCCOPT-1090

#### **SUMMARY**

Did not meet the cts max source to sink net resistance constraint of %s

### **DESCRIPTION**

This warning at the end of the CCOpt run indicates that the cts\_max\_source\_to\_sink\_net\_resistance constraint is not met below certain clock tree cell in a given clock tree.

This could happen for the following reasons:

- 1. Inappropriate cts max source to sink net resistance constraint (too tight to be achieved).
- 2. One or more of the nets in the clock tree are unbufferable, due to power\_domain, blockages, region constraints or dont\_touch settings.
- 3. Congestion has yielded detoured nets during detailed routing of the clock nets.

## **IMPCCOPT-1092**

#### NAME

IMPCCOPT-1092

Error and Warning Messages

### **SUMMARY**

A target has been set on skew group %s where the constrains attribute is set to none. The target will not be optimized for.

#### **DESCRIPTION**

A skew or insertion delay target has been set on an unconstrained skew group. The target will not be optimized for unless the constrains attribute for the skew group is changed.

## **IMPCCOPT-1093**

#### NAME

IMPCCOPT-1093

### **SUMMARY**

The constrains attribute has been set to none for skew group %s which also has skew or insertion delay targets set. The targets will not be optimized for.

## **DESCRIPTION**

A skew group with insertion delay or skew target has the constrains attribute set to none. The target will not be optimized for.

## **IMPCCOPT-1107**

## **NAME**

IMPCCOPT-1107

### **SUMMARY**

Error and Warning Messages

An over latency of %s is present at the start of skew fixing.

#### DESCRIPTION

Skew fixing expects no over latency to be present when it is run. This indicates a potential mismatch in window constraints between modes.

## **IMPCCOPT-1154**

### NAME

IMPCCOPT-1154

#### SUMMARY

The original placement group of %s is %s and that is not the same as the parent group of the group on the spine, which is: %s.

### **DESCRIPTION**

When setting attribute cts\_legalized\_on\_clock\_spine the pin was in a different power domain to the pins already legalized on the clock spine. The attribute cts\_legalized\_on\_clock\_spine for a pin can only refer to a clock spine which is in the same power domain as the pin.

# **IMPCCOPT-1157**

### **NAME**

**IMPCCOPT-1157** 

#### SUMMARY

Did not meet the cts max fanout constraint. %s

#### DESCRIPTION

This warning at the end of the CCOpt run indicates that the cts\_max\_fanout constraint is not met below certain clock tree cell in a given clock tree.

This could happen due to the following reasons:

- 1. Inappropriate cts max fanout constraint (too small to be achieved).
- 2. One or more of the nets in the clock tree are unbufferable, due to power\_domain, blockages, region constraints or dont\_touch settings.

## **IMPCCOPT-1173**

#### NAME

IMPCCOPT-1173

#### **SUMMARY**

The lib cell %s has an invalid rising arc.

### **DESCRIPTION**

The rising arc of the lib\_cell is invalid. This is most likely as a result of invalid or incomplete lib\_cell data.

## **IMPCCOPT-1174**

### **NAME**

IMPCCOPT-1174

#### **SUMMARY**

The lib cell %s has an invalid falling arc.

Error and Warning Messages

#### DESCRIPTION

The falling arc of the lib\_cell is invalid. This is most likely as a result of invalid or incomplete lib\_cell data.

## **IMPCCOPT-1195**

#### NAME

IMPCCOPT-1195

#### **SUMMARY**

Path optimization has given up on node %s for this round because it has been optimized too many times. This could mean path optimization would otherwise hang on this node.

#### DESCRIPTION

Path optimization has given up on a node because it has been optimized too many times.

## **IMPCCOPT-1209**

#### NAME

IMPCCOPT-1209

#### **SUMMARY**

Non-leaf slew time target of %s%s is too low on %s. The largest %sclock gate is unable to drive the largest %s in %s. To adhere to the given slope target, you will need to select a stronger clock gate, increase the slew target to at least %s or remove these driver cells from the CTS cell lists: %s %s.

#### **DESCRIPTION**

Slope/slew/transition target for the clock tree is too small.

Error and Warning Messages

CCOpt calculates the slew that arises when you drive a buffer/inverter with a single other buffer/inverter with no wire present between them. If the supplied slew target is smaller than this computed transition time then CTS has no chance of driving multiple buffers so this error is produced and the run stopped.

Increase the slew target to something bigger.

## **IMPCCOPT-1239**

#### NAME

IMPCCOPT-1239

#### SUMMARY

CCOpt has updated an 'ignore' skew target for late timing in the CTS primary delay corner for the skew group %s because it has non ignored targets in another corner.

### **DESCRIPTION**

CCOpt has updated an 'ignore' skew target for late timing in the CTS primary delay corner for a skew group because it has non ignored targets in another corner. If you are trying to do CTS for a design where a skew group should explicitly not be balanced in the primary delay corner, such as for a design which uses dynamic voltage and frequency scaling (DVFS), then you can turn off this behavior by setting the cts\_allow\_ignore\_skew\_in\_primary\_corner\_for\_mmmc attribute to true.

# **IMPCCOPT-1241**

### **NAME**

IMPCCOPT-1241

### **SUMMARY**

ResizeGates hit its iteration limit and gave up.

#### DESCRIPTION

ResizeGates hit its iteration limit and gave up. The iteration limit can be controlled by setting the attribute cts fine balance resize gates iteration limit.

## **IMPCCOPT-1247**

#### NAME

IMPCCOPT-1247

#### SUMMARY

More than %.1f%% of clock instances have been set to fixed placement status by the user (%d instances).

#### DESCRIPTION

A significant proportion of the clock tree instances (clock gates, clock drivers and clock logic) are fixed; either in DEF or fixed by the user. This may adversely affect the clock tree QoR that can be achieved by CCOpt.

If this is a configuration error, the instances can be unlocked using the following command.

foreach inst [get db clock trees .insts] { set db \$inst .place status placed }

# **IMPCCOPT-1260**

### NAME

IMPCCOPT-1260

#### SUMMARY

The skew target of %s for %s is too small. For best results, it is recommended that the skew target be set no lower than %s. Using this skew target anyway, because cts exit if skew target over constrained is not set.

#### DESCRIPTION

Skew target is too small.

CCOpt calculates a minimum skew target which should not lead to excessive buffering. You have set a skew target to a value lower than this minimum.

Either increase the offending skew target, or set the cts\_override\_minimum\_skew\_target attribute to true to disable this check.

## **IMPCCOPT-1261**

#### **NAME**

IMPCCOPT-1261

#### SUMMARY

The skew target of %s for %s is too small. For best results, it is recommended that the skew target be set no lower than %s. The skew target has been relaxed to %s. You may force the use of the tighter skew target by setting cts\_exit\_if\_skew\_target\_over\_constrained to false.

#### DESCRIPTION

Skew target is too small.

CCOpt calculates a minimum skew target which should not lead to excessive buffering. You have set a skew target to a value lower than this minimum.

Either increase the offending skew target, or set the cts\_override\_minimum\_skew\_target attribute to true to disable this check.

## **IMPCCOPT-1262**

#### NAME

IMPCCOPT-1262

#### **SUMMARY**

Slew violating nets have been found in the design, but CCOpt is unlikely to resolve these violations due to the design configuration. Review your configuration for the nets shown, or do {set\_db cts\_error\_on\_problematic\_slew\_violating\_nets 0} to continue with your current configuration. %s

#### DESCRIPTION

Slew violating nets have been found in the design, but CCOpt is unlikely to resolve these violations due to the design configuration. Review your configuration for the nets shown, or do 'set\_db cts error on problematic slew violating nets 0' to continue with your current configuration.

## IMPCCOPT-1263

#### NAME

IMPCCOPT-1263

#### SUMMARY

%s Terminating the run, as it is unlikely to produce good results. Do {set\_db cts error on problematic slew violating nets 0} to continue with your current configuration.

#### **DESCRIPTION**

Slew violating nets have been found in the design, but CCOpt is unlikely to resolve these violations due to the design configuration. Review your configuration for the nets shown, or do 'set\_db cts\_error\_on\_problematic\_slew\_violating\_nets 0' to continue with your current configuration.

## IMPCCOPT-1274

#### **NAME**

IMPCCOPT-1274

### **SUMMARY**

Rejecting rectangle: %s.

### **DESCRIPTION**

The attribute value for cts cell density regions was badly formed and could not be decoded.

# **IMPCCOPT-1275**

### **NAME**

IMPCCOPT-1275

### **SUMMARY**

Attribute value %s is badly formed: %s %s.

## **DESCRIPTION**

The attribute cts\_cell\_density\_regions was badly formed and could not be decoded.

# **IMPCCOPT-1278**

### **NAME**

IMPCCOPT-1278

### **SUMMARY**

Special case dont\_touch logic cell selections:

## **DESCRIPTION**

Error and Warning Messages

When specified, CTS will provide additional log information on the lists of cells that it will consider using when determining if a cell can be resized. This information is only provided for the more specialized cases. Specialized cases include logic cells and any cells marked (either by the user or by an internal constraint) as dont\_touch.

## **IMPCCOPT-1279**

#### NAME

IMPCCOPT-1279

### **SUMMARY**

Special case logic cell selections:

#### DESCRIPTION

When specified, CTS will provide additional log information on the lists of cells that it will consider using when determining if a cell can be resized. This information is only provided for the more specialized cases. Specialized cases include logic cells and any cells marked (either by the user or by an internal constraint) as dont\_touch.

# **IMPCCOPT-1280**

### NAME

IMPCCOPT-1280

#### SUMMARY

Suitable cells available to use for %s are: %s

### **DESCRIPTION**

When specified, CTS will provide additional log information on the lists of cells that it will consider

Error and Warning Messages

using when determining if a cell can be resized. This information is only provided for the more specialized cases. Specialized cases include logic cells and any cells marked (either by the user or by an internal constraint) as dont\_touch.

## **IMPCCOPT-1281**

#### NAME

IMPCCOPT-1281

#### **SUMMARY**

No suitable cells available to use for %s.

#### DESCRIPTION

When specified, CTS will provide additional log information on the lists of cells that it will consider using when determining if a cell can be resized. This information is only provided for the more specialized cases. Specialized cases include logic cells and any cells marked (either by the user or by an internal constraint) as dont\_touch.

## **IMPCCOPT-1282**

#### NAME

IMPCCOPT-1282

#### **SUMMARY**

Special case dont touch cell selections:

#### DESCRIPTION

When specified, CTS will provide additional log information on the lists of cells that it will consider using when determining if a cell can be resized. This information is only provided for the more

specialized cases. Specialized cases include logic cells and any cells marked (either by the user or by an internal constraint) as dont\_touch.

## **IMPCCOPT-1287**

#### NAME

IMPCCOPT-1287

### SUMMARY

CCOpt clustering wanted to clone for insertion delay but the node, %s, cannot be cloned for these reasons: %s.

### **DESCRIPTION**

For more information do:

get\_db -help cts\_cannot\_clone\_reasons

## **IMPCCOPT-1288**

#### NAME

IMPCCOPT-1288

### **SUMMARY**

CCOpt wanted to clone for balancing (cts\_clustering\_clone\_cells\_to\_reduce\_balancing\_conflicts is true) but the node, %s, cannot be cloned for these reasons: %s.

## **DESCRIPTION**

For more information do:

get\_db -help cts\_cannot\_clone\_reasons

### NAME

IMPCCOPT-1289

#### SUMMARY

CCOpt wanted to clone the node, %s, into %d clones for multi-tap off but the node cannot be cloned for these reasons: %s.

#### **DESCRIPTION**

For more information do:

get\_db -help cts\_cannot\_clone\_reasons

# **IMPCCOPT-1299**

#### NAME

IMPCCOPT-1299

### **SUMMARY**

Found attribute cts\_target\_max\_transition\_time set to ignore for clock tree %s in the primary half corner %s and %s, %s will not be possible.

### DESCRIPTION

Consider setting the cts target max transition time attribute.

#### NAME

IMPCCOPT-1314

#### SUMMARY

The setting of %s for the cts\_max\_source\_to\_sink\_net\_length attribute may be too low. Increase it to more than %s to avoid this warning.

#### DESCRIPTION

The lower limit for the attribute is calculated as cts\_max\_source\_to\_sink\_net\_length\_warn\_multiple times the row height.

Check the value of the attribute or reduce cts max source to sink net length warn multiple.

## **IMPCCOPT-1315**

#### NAME

IMPCCOPT-1315

#### **SUMMARY**

The setting of %s for the cts\_max\_source\_to\_sink\_net\_length attribute is too low. Increase it to more than %s to avoid this error.

## **DESCRIPTION**

The lower limit for the attribute is calculated as cts\_max\_source\_to\_sink\_net\_length\_error\_multiple times the row height.

Check the value of the attribute or reduce cts\_max\_source\_to\_sink\_net\_length\_error\_multiple.

### NAME

IMPCCOPT-1316

#### SUMMARY

Reason(s) why cloning is prevented for %s: %s

### **DESCRIPTION**

For more information do:

get\_db -help cts\_cannot\_clone\_reasons

# **IMPCCOPT-1317**

### NAME

IMPCCOPT-1317

### **SUMMARY**

CCOpt clustering wanted to clone to meet DRV constraints, because the cts\_allow\_buffering attribute is false, but the node, %s, cannot be cloned for these reasons: %s.

### **DESCRIPTION**

For more information do:

get\_db -help cts\_cannot\_clone\_reasons

#### NAME

IMPCCOPT-1322

#### SUMMARY

CCOpt clustering wanted to clone to meet a maximum\_stage\_depth constraint but the node, %s, cannot be cloned for these reasons: %s.

### **DESCRIPTION**

For more information do:

get\_db -help cts\_cannot\_clone\_reasons

# **IMPCCOPT-1348**

#### **NAME**

IMPCCOPT-1348

#### SUMMARY

CCOpt wanted to clone %s, but it cannot be cloned for these reasons: %s.

### **DESCRIPTION**

For more information do:

get db -help cts cannot clone reasons

#### NAME

IMPCCOPT-1368

#### SUMMARY

CTS cannot use the preferred layers from route type %s: top %s(%s) and bottom %s(%s). CTS will instead use preferred layers: top %s(%s) and bottom %s(%s).

#### DESCRIPTION

To be suitable for CTS a route\_type must have at least one horizontal layer and one vertical layer. Check the preferred layers for the route type.

## **IMPCCOPT-1372**

#### NAME

IMPCCOPT-1372

#### SUMMARY

Found multiple values of cts\_max\_fanout for cells within the same family (%s). CTS may take the most constraining value for the family (%u). Consider setting cts\_max\_fanout for all family members to the same value.

### **DESCRIPTION**

CTS will try to satisfy cts\_max\_fanout constraints and will report violations. The attribute cts\_max\_fanout can be set per library output pin, however, the same value should be used for all cells in a cell family. Violations of this rule may produce spurious violation reporting or unexpected optimization results.

#### NAME

IMPCCOPT-1373

#### SUMMARY

Found libary-pin specific values of cts\_max\_fanout (%s) that are set higher than the global value (%u). Consider increasing the global value to be larger than the libary-pin specific values.

### **DESCRIPTION**

CTS will try to satisfy cts\_max\_fanout constraints and will report violations. The attribute cts\_max\_fanout can be set per library output pin or globally (without a library pin). Optimization expects that the global value is set >= than the per lib\_cell value. Violations of this rule may produce spurious violation reporting or unexpected optimization results.

## **IMPCCOPT-1405**

#### NAME

IMPCCOPT-1405

### **SUMMARY**

The estimated amount of delay that will be added in Balancing is very high: %s. Delay will be added at many locations in the tree, and continuing will result in high runtimes and poor area.

### DESCRIPTION

Most likely an ideal or dont\_touch net is preventing CTS to add delay high in the clock tree, such that delay is added at many locations lower in the tree.

We suggest doing a trial balancing and investigating with the clock tree debugger.

To force CCOpt to exit please enable the CCOpt attribute "exit\_if\_trial\_balance\_delay\_estimation\_high".

## **IMPCCOPT-1470**

#### NAME

IMPCCOPT-1470

### **SUMMARY**

%s is in the skew group %s but is not a sink of the skew group. Try 'report\_skew\_groups - skew group %s -through %s' instead.

### **DESCRIPTION**

Given pin is in the given skew group but is not a sink of the skew group. When command 'report\_skew\_groups' is used with the argument '-to' expected argument after '-to' is a sink. Try using the argument '-through' instead of '-to'.'

## **IMPCCOPT-1471**

#### NAME

IMPCCOPT-1471

### **SUMMARY**

%s is a source of the skew group %s.

#### **DESCRIPTION**

Given pin is a source of the skew group. When command 'report\_skew\_groups' is used with the argument '-to' expected argument after '-to' is a sink.

#### NAME

IMPCCOPT-2001

#### SUMMARY

Clock domain skew group creation did not visit %s.

### **DESCRIPTION**

Clock domain skew group creation did not visit every node in the clock DAG. The clock domain skew groups may be incomplete which may create problems clustering the clock tree or implementing the clock schedule.

# **IMPCCOPT-2006**

#### NAME

IMPCCOPT-2006

## **SUMMARY**

Output hpin %s is not connected to any driver inside the hInst. Ignoring %s.

### **DESCRIPTION**

An output hpin is not connected to any driver inside the hlnst. You should check the Verilog; one possibility is that the output port should be an input port.

#### NAME

IMPCCOPT-2023

#### SUMMARY

All CCOpt commands require that the ILM type is set to '%s', however, this is currently not the case. The ILM type '%s' will now be set.

#### **DESCRIPTION**

CCOpt requires that all ILMs are flat and configured to use the correct model for the current routing status of the design. Unrouted or partially routed designs should use 'timing' ILMs, while fully routed designs should use 'SI' ILMs. The current routing status can be controlled with the CCOpt attribute 'cts\_force\_design\_routing\_status'.

## **IMPCCOPT-2024**

#### NAME

IMPCCOPT-2024

#### SUMMARY

The command 'set\_ilm\_type -model timing' was run, but did not exit cleanly.

#### DESCRIPTION

The command 'set\_ilm\_type -model timing' was run, but did not exit cleanly. This may lead to problems in the CCOpt flow. Consider setting this manually in your design.

#### NAME

IMPCCOPT-2025

#### SUMMARY

CCOpt attributes set with 'set db' will have no effect when the scripted integration of CCOpt is run.

#### **DESCRIPTION**

CCOpt attributes set with 'set\_db' will have no effect when the scripted integration of CCOpt is run. If you are setting CCOpt attributes, you should switch to the native integration before running optimization by using: 'eval legacy {set ccopt mode -integration native}'.

## **IMPCCOPT-2026**

#### NAME

IMPCCOPT-2026

#### SUMMARY

Always on cell %s will not be used as buffer or inverter in CCOpt because power management checks are turned off.

### **DESCRIPTION**

An always on cell will not be used as buffer or inverter in CCOpt because power management checks are turned off. Set CCOpt attribute 'cts\_consider\_power\_intent' to true to turn on power management checking.

#### NAME

IMPCCOPT-2027

#### SUMMARY

Computing a standard slew value for view '%s' and power domain '%s'. This view/power domain combination did not exist when CCOpt was initialized.

### **DESCRIPTION**

CCOpt had to compute a standard slew value for a view and power domain combination which did not exist when CCOpt was initialized. One possibility is that the active views have changed, which is currently not supported by CCOpt.

# **IMPCCOPT-2267**

### **NAME**

IMPCCOPT-2267

#### SUMMARY

Cell %s will not be used as it is unable to drive %d instances of itself (input cap is %s) because its max cap at clock period %s is %s. The number of instances used in this check can be adjusted with the cts\_frequency\_dependent\_max\_capacitance\_cell\_filtering\_fanout\_factor attribute.

### DESCRIPTION

This message appears when a cell has been found to be unable to drive enough capacitance at a particular frequency. This is determined from the frequency dependent max cap defined in the lib file (the max\_cap attribute on the cell's output pin). In order to build a tree, a cell must be able to drive at least two other cells, and some wire, so CCOpt checks that the cell can drive at least four

Error and Warning Messages

instances of itself at each frequency used in the clock tree. The number of instances used in this calculation can be set using the attribute

cts\_frequency\_dependent\_max\_capacitance\_cell\_filtering\_fanout\_factor. Reducing it may prevent CCOpt from being able to build valid trees, and may introduce runtime issues.

## **IMPCCOPT-2319**

#### NAME

IMPCCOPT-2319

#### **SUMMARY**

ILM pin %s has %u fanout, which is more than the configured limit of %d. CCOpt will consider the fanout as ignore pins.

#### **DESCRIPTION**

An ILM pin had a large number of fanout, probably caused by unsynthesized clock trees in the ILM. This check can be controlled with the attribute cts\_extract\_ilm\_fanout\_limit, but raising it may lead to slow runtimes.

# **IMPCCOPT-2327**

#### NAME

IMPCCOPT-2327

#### SUMMARY

Internal Error: %s power context changed in SetCellDecl on %s.

### **DESCRIPTION**

CCOpt has replaced a cell and now the power context is different. This is an internal error, and

Error and Warning Messages

should not happen. Please report it to your local Cadence support representative. There are likely to be power management violations in the clock tree.

### IMPCCOPT-2347

#### NAME

IMPCCOPT-2347

#### **SUMMARY**

Could not build any timing models for the generated clock tree %s (output pin %s, library cell pin %s). Clock tree timing may be inaccurate.

#### DESCRIPTION

This message appears when CCOpt is unable to set up a timing model for the specified output pin and may be caused by e.g. missing timing arcs for that pin in the Liberty data for one or more analysis views. This will prevent the tool from correctly determining the transition time and delay at the specified output pin and may lead to inaccurate optimization and reporting of delays and DRVs.

To avoid this situation, the Liberty timing data (.lib data) must be checked and corrected to ensure arcs are present for the library pin in question for all analysis views. Alternatively, consider setting the attribute cts\_clock\_tree\_source\_output\_max\_transition\_time.

More detailed reporting of which timing arcs are missing is avialable in the 'Missing Timing Arcs' table produced by report clock trees.

### **IMPCCOPT-2393**

#### **NAME**

IMPCCOPT-2393

#### SUMMARY

Useful skew engine failed to restore: encountered %u errors.

#### DESCRIPTION

This message typically indicates that the clock network has been modified such that it is no longer consistent with the saved state of the useful skew engine. Searching earlier in the flow for IMPCCOPT-2231 messages will normally help identify the problem. The number of reported errors gives a sense of the scale of the problem.

### **IMPCCOPT-2396**

#### NAME

IMPCCOPT-2396

#### SUMMARY

Reached the maximum number of arc chains defined by the attribute nma\_finder\_max\_arc\_chains (%d) when adding chain for cell (%s), input (%s), output (%s).

#### **DESCRIPTION**

The number of arc chains reached %d, the maximum defined by attribute nma\_finder\_max\_arc\_chains. Further arcs we be pruned.

### **IMPCCOPT-2400**

#### NAME

IMPCCOPT-2400

### **SUMMARY**

Attribute ccopt\_useful\_skew\_ideal\_mode\_set\_clock\_latency is set to false. Early clock flow pre-CTS useful skew has been disabled.

### **DESCRIPTION**

Error and Warning Messages

If ECF is not able to generate set\_clock\_latency assertions it is unable to implement useful skews. Therefore the useful skew transform is disabled in this case. This situation is probably unintended. To resolve this error, either disable pre-CTS useful skew entirely, or else set the specified attribute back to its default value.

## **IMPCCOPT-3084**

#### NAME

IMPCCOPT-3084

#### **SUMMARY**

%d arguments were supplied to the ccopt\_log command. This is too few. The minimum is a log identifier.

#### DESCRIPTION

Too few argument were supplied to the ccopt log command. The minimum is a log identifier.

### **IMPCCOPT-3085**

#### NAME

**IMPCCOPT-3085** 

#### **SUMMARY**

The log identifier %d was not found. It should appear in a .logid file.

#### **DESCRIPTION**

A log identifier was not found. It should appear in a .logid file.

#### NAME

IMPCCOPT-4144

#### SUMMARY

The SDC clock %s has source pin %s, which is an input pin. Clock trees for this clock will be defined under the corresponding output pins instead.

#### **DESCRIPTION**

An SDC clock has a source pin which is an input pin. There is no obvious output pin on the same cell which propagates the clock signal. No clock tree definition will be extracted for this clock.

### **IMPCCOPT-4156**

#### NAME

IMPCCOPT-4156

#### **SUMMARY**

The SDC clock %s has source pin %s, which drives a net that has other drivers. Clock trees for this clock will be defined on the fanout pins of the net instead.

#### **DESCRIPTION**

The pin (or port) referenced in an SDC create\_clock or create\_generated\_clock is an output pin driving a net that has multiple drivers. CTS cannot build a clock tree rooted at that pin because it is not possible to control the delay since the other drivers of the net are not in the clock tree. CTS will move the clock tree and skew group definitions to the fanout pins, creating a skew group with multiple sources if needed to ensure that the entire transitive fanout of the original pin is included.

To eliminate this message, change the SDC to avoid defining clocks on pins whose driven nets

have multiple drivers.

### **IMPCCOPT-4196**

#### NAME

IMPCCOPT-4196

#### **SUMMARY**

Found a cycle containing the following generated clock trees:%s%s

#### **DESCRIPTION**

Found a cycle caused by generated clock trees. Where possible, this is resolved by removing some parents of generated clock trees.

### **IMPCCOPT-4205**

#### NAME

IMPCCOPT-4205

### **SUMMARY**

Differing SDC set\_clock\_transition constraints exist for the clocks present at %s across the timing configs specified. The tightest found constraint of %f will be used.

### **DESCRIPTION**

An SDC derived clock tree constraint differs between timing configs. The tightest applicable constraint has been applied.

#### NAME

IMPCCOPT-4232

#### SUMMARY

No usable inverter has been found. It could be that there are no inverters defined in the libraries or all inverters are set as dont\_use. Ensure that all required libraries have been loaded and check the dont\_use settings for inverter cells within your libraries.

#### **DESCRIPTION**

For example:

To get a list of all cells marked dont\_use: report\_dont\_use\_cells

To disable a dont\_use on a base\_cell: set\_opt\_dont\_use <cell-name> false

### **IMPCCOPT-4245**

#### NAME

IMPCCOPT-4245

#### **SUMMARY**

The width of the vertical clock spine %s will implicitly be increased so its boundary is aligned on a multiple of the placement site grid. It is now from %s

### **DESCRIPTION**

Spine flow for CCOpt is currently not supported. Please consult support AE.

#### NAME

IMPCCOPT-4246

#### SUMMARY

Found a cell which overlaps a cleared hard clock spine region: %s at %s.

### **DESCRIPTION**

Spine flow for CCOpt is currently not supported. Please consult support AE.

## **IMPCCOPT-4251**

#### **NAME**

IMPCCOPT-4251

### **SUMMARY**

The design database has been modified by one or more Tcl commands and '%s' was unable to resynchronize the CCOpt data structures. The reason is: %s%s

#### DESCRIPTION

The design database has been modified by one or more Tcl commands. The CCOpt data structures could not be resynchronized. The command 'delete\_clock\_tree\_spec' may run internally to reset the CCOpt state.

#### NAME

IMPCCOPT-4318

#### SUMMARY

No default buffer cell family identified.

### **DESCRIPTION**

This message occurs because there is no buffer cell available for clock tree synthesis. Please make sure the buffers you have specified with '-cts\_buffer\_cells' for " are available in the current Innovus session.

For example, the follow example returns the library cells with prefix 'CKBUF':

innovus> get\_lib\_cells CKBUF\*#@innovus> get\_db lib\_cells CKBUF\*

libcell:slowlib/CKBUFD1 libcell:slowlib/CKBUFD2 libcell:fastlib/CKBUFD1 libcell:fastlib/CKBUFD2

### **IMPCCOPT-4319**

#### **NAME**

IMPCCOPT-4319

### **SUMMARY**

Default buffer cell family exemplar %s has all members marked dont\_use.

#### **DESCRIPTION**

All the buffer cells specified by the cts\_buffer\_cells attribute are marked as dont\_use.

Error and Warning Messages

Please check the dont\_use state of the given buffer cells.

For example, resetting dont\_use attribute on cells with prefix 'CK\*':

innovus> set opt dont use CK\* false

### **IMPCCOPT-4320**

#### NAME

IMPCCOPT-4320

#### SUMMARY

No default Inverter cell family identified.

#### **DESCRIPTION**

This message occurs because there is no inverter cell available for clock tree synthesis. Please make sure the inverters you have specified with the cts\_inverter\_cells attribute are available in the current Innovus session.

For example, The follow example returns the library cells with prefix 'CKINV':

@innovus> get\_db lib\_cells CKINV\*

libcell:slowlib/CKINVD1 libcell:slowlib/CKINVD2 libcell:fastlib/CKINVD1 libcell:fastlib/CKINVD2

### **IMPCCOPT-4321**

#### NAME

IMPCCOPT-4321

#### **SUMMARY**

Default inverter cell family exemplar %s has all members marked dont use. It could be that all inverters defined by the cts\_inverter\_cells attribute cannot be used due to dont\_use setting. Check

the dont\_use settings for inverter cells within your libraries.

#### DESCRIPTION

For example:

To get a list of all cells marked dont\_use: report\_dont\_use\_cells

To disable a dont\_use on a library cell: set\_opt\_dont\_use <cell-name> false

### **IMPCCOPT-4322**

#### NAME

IMPCCOPT-4322

#### SUMMARY

No default Or cell family identified.

#### **DESCRIPTION**

This message occurs because there is no OR cell available for clock tree synthesis. Please make sure the OR cells you have specified by the cts\_logic\_cells attribute are available in the current Innovus session.

For example, the follow example returns the library cells with prefix 'CKOR':

@innovus> get\_db lib\_cells CKOR\*

libcell:slowlib/CKORD1 libcell:slowlib/CKORD2 libcell:fastlib/CKORD1 libcell:fastlib/CKORD2

### **IMPCCOPT-4323**

#### NAME

IMPCCOPT-4323

#### SUMMARY

Default OR2 family exemplar %s has all members marked dont\_use. It could be that all the OR2 cells defined in the cts\_logic\_cells attribute are set dont\_use. Check the dont\_use settings for OR gates within your libraries.

#### DESCRIPTION

For example:

To get a list of all cells marked dont use: report dont use cells

To disable a dont\_use on a library cell: set\_opt\_dont\_use <cell-name> false

## **IMPCCOPT-4324**

#### **NAME**

IMPCCOPT-4324

#### SUMMARY

No default Nor cell family identified.

#### **DESCRIPTION**

This message occurs because there is no NOR cell available for clock tree synthesis. Please make sure the NOR cells you have specified in the cts\_logic\_cells attribute are available in the current Innovus session.

For example, the follow example returns the library cells with prefix 'CKNOR':

@innovus> get\_db lib\_cells CKNOR\*

libcell:slowlib/CKNORD1 libcell:slowlib/CKNORD2 libcell:fastlib/CKNORD1 libcell:fastlib/CKNORD2

#### NAME

**IMPCCOPT-4325** 

#### **SUMMARY**

Default NOR2 family exemplar %s has all members marked dont\_use. It could be that all the NOR2 cells defined in the cts\_logic\_cells attribute are set dont\_use. Check the dont\_use settings for NOR gates within your libraries.

#### **DESCRIPTION**

For example:

To get a list of all cells marked dont use: report dont use cells

To disable a dont\_use on a library cell: set\_opt\_dont\_use <cell-name> false

### **IMPCCOPT-4327**

#### NAME

IMPCCOPT-4327

#### **SUMMARY**

Cannot find a smallest inverter. It could be that there are no inverters defined in the libraries or all inverters are set as dont\_use. Ensure that all required libraries have been loaded and check the dont\_use settings for inverter cells.

#### **DESCRIPTION**

For example:

To get a list of all cells marked dont use: report dont use cells

To disable a dont use on a library cell: set opt dont use <cell-name> false

### **IMPCCOPT-4338**

#### NAME

**IMPCCOPT-4338** 

#### SUMMARY

There are %u clock paths leading to %s. This may cause long CCOpt runtimes.

#### **DESCRIPTION**

The design contains a lot of converging clock paths leading to some sinks. This may cause long CCOpt runtimes. The sinks with the most paths leading to them can be found with report\_clock\_tree\_convergence. See CCOpt Clock Tree Specification under Clock Concurrent Optimization in the User Guide for more information.

### **IMPCCOPT-4339**

### **NAME**

IMPCCOPT-4339

#### SUMMARY

CCOpt is unable to time a clock gating check on pin %s. In most cases, this will not prevent optimization but it could result in an incorrect worst chain report.

#### DESCRIPTION

If you see this message during optimization, in most cases, optimization will proceed correctly. If you find the specified gate has not been pushed low enough in the clock tree, you need to add a negative pin insertion delay to the pin in order to push it lower.

Error and Warning Messages

If you see this message just before a worst chain report, be aware that the chain reported may not be the worst chain in the design. The reported chain will be wrong when the gate with the clock gating check is the most critical next or previous path in the chain. In this case, the worst chain will report a different next or previous path.

# **IMPCCOPT-4346**

#### NAME

IMPCCOPT-4346

#### **SUMMARY**

Failed to restore clock tree %s which had source %s.

#### DESCRIPTION

If any clock tree is modified by ECO commands then CCOpt will save its internal state. Any subsequent CCOpt command will prompt a restore from this saved internal state. In some cases CCOpt cannot restore a clock tree. For example, this can occur if the source pin for the clock tree has been deleted by an ECO command.

# **IMPCCOPT-4347**

#### NAME

IMPCCOPT-4347

#### SUMMARY

Failed to restore clock spine %s.

### **DESCRIPTION**

If any clock tree is modified by ECO commands then CCOpt will save its internal state. Any

Error and Warning Messages

subsequent CCOpt command will prompt a restore from this saved internal state. In some cases CCOpt cannot restore a clock spine. For example, this can occur if CCOpt could not restore any of the clock trees in the design after running ECO commands.

### **IMPCCOPT-4348**

#### NAME

IMPCCOPT-4348

#### SUMMARY

Failed to restore flexible H-tree %s.

#### DESCRIPTION

If any clock tree is modified by ECO commands then CCOpt will save its internal state. Any subsequent CCOpt command will prompt a restore from this saved internal state. In some cases CCOpt cannot restore a flexible H-tree. For example, this can occur if the pin where the H-tree was created has been deleted by an ECO command.

### **IMPCCOPT-4349**

#### NAME

IMPCCOPT-4349

#### **SUMMARY**

Failed to restore clock tree source group %s.

#### DESCRIPTION

If any clock tree is modified by ECO commands then CCOpt will save its internal state. Any subsequent CCOpt command will prompt a restore from this saved internal state. In some cases

Error and Warning Messages

CCOpt cannot restore a clock tree source group. For example, this can occur if CCOpt could not restore some of the clock trees in the source group.

### **IMPCCOPT-4350**

#### NAME

IMPCCOPT-4350

#### **SUMMARY**

Failed to restore skew group %s which had source(s) %s.

#### **DESCRIPTION**

If any clock tree is modified by ECO commands then CCOpt will save its internal state. Any subsequent CCOpt command will prompt a restore from this saved internal state. In some cases CCOpt cannot restore a skew group. For example, this can occur if a source pin for the skew group has been deleted by an ECO command.

### **IMPCCOPT-4352**

#### NAME

IMPCCOPT-4352

#### **SUMMARY**

Cannot resolve any source(s) '%s' for auto\_sinks skew group '%s'.

#### DESCRIPTION

CCOpt cannot automatically add sinks to a skew group when it has no resolved source pin(s). Check that the defined source(s) for this skew group are output pins.

#### NAME

IMPCCOPT-4353

#### SUMMARY

Created a new clock tree %s with source %s after failing to restore a generated clock tree with this source.

### **DESCRIPTION**

In some cases CCOpt cannot recreate a generated clock tree when restoring from state saved before a change to the clock trees. For example, this can occur if the generator input pins are not sinks in a parent clock tree. CCOpt has created a new non-generated clock tree with the same source and name as the old generated clock tree. Any skew groups which have this source pin as a source will become constraining skew groups (i.e. the cts\_skew\_group\_constrains attribute for these skew groups will no longer be 'none').

### **IMPCCOPT-4355**

#### NAME

**IMPCCOPT-4355** 

#### **SUMMARY**

Restoring from CCOpt config file '%s' produced %zu error(s). The following command(s) failed: %s

### **DESCRIPTION**

Restoring from a CCOpt config file produced one or more errors. This can happen if the file contains references to insts or pins which no longer exist in the DB, or if the config was saved using a different version of the software. To avoid this warning save the design again: the new CCOpt

config will be up-to-date and should load without errors.

## **IMPCCOPT-4356**

#### **NAME**

IMPCCOPT-4356

#### SUMMARY

Found unexpected period value %f for clock %s in analysis view %s.

#### DESCRIPTION

CCOpt will automatically set the cts\_clock\_period attribute when creating clock trees. The clock period values are extracted from the loaded constraint files. Period values that are not greater than zero are not supported by CCOpt, and will be ignored. To avoid this warning update the -period setting for this clock in your SDC file.

# **IMPCCOPT-4360**

### **NAME**

IMPCCOPT-4360

### **SUMMARY**

Found preserved output port(s) on hierarchical net %s which has Verilog assign(s).

#### DESCRIPTION

Preserved output ports which are assigned to input ports may prevent CCOpt from buffering the hierarchical net connecting the ports. CCOpt will attempt to add a new port to allow for buffering fanout which was connected via a hierarchical net with Verilog assigns. To disable this behavior set the CCOpt attribute cts add new ports to avoid buffering nets with assigns to be false, and

restart your run.

## **IMPCCOPT-4362**

#### **NAME**

IMPCCOPT-4362

#### SUMMARY

Failed to restore preferred cell stripes %s.

#### **DESCRIPTION**

If any clock tree is modified by ECO commands then CCOpt will save its internal state. Any subsequent CCOpt command will prompt a restore from this saved internal state. In this case a preferred cell stripes instance has failed to be restored; this may have happened because it is referencing one or more cell declarations which are no longer available.

# **IMPCCOPT-4375**

### **NAME**

IMPCCOPT-4375

#### SUMMARY

Pin %s (connected to net %s) %s so cannot be used by CCOpt

#### **DESCRIPTION**

A pin cannot be used by CCOpt because it is either an internal pin, a power pin, a ground pin or it has no direction.

CCOpt cannot understand pins without a direction.

Error and Warning Messages

CCOpt cannot query or optimize power or ground pins.

Verify the design data for the pin is correct.

# **IMPCCOPT-4379**

#### NAME

IMPCCOPT-4379

#### **SUMMARY**

Ignoring command which refers to deleted power domain %s (command was '%s').

#### DESCRIPTION

If any clock tree is modified by ECO commands or if a new power intent is committed then CCOpt will save its internal state. Any subsequent CCOpt command will prompt a restore from this saved internal state. In this case a attribute setting cannot be restored because it refers to a power domain that no longer exists. Check your CCOpt configuration for this attribute.

# **IMPCCOPT-4383**

#### NAME

IMPCCOPT-4383

#### SUMMARY

Treating %s port %s as having effective direction %s.

### **DESCRIPTION**

CCOpt is treating a port as having a different direction than is specified in the netlist. CCOpt has calculated this effective direction based on how the port is connected in the netlist. This warning

Error and Warning Messages

can occur if the Verilog port direction is not correct for the way the signal is being used (e.g. an input port driven by an output pin which is inside the hinst). Update the Verilog definition for this port, or change the port connections to avoid this warning.

### **IMPCCOPT-4386**

#### NAME

IMPCCOPT-4386

#### SUMMARY

Encountered clock node input pin %s that is in clock tree %s but is shared with generated clock tree %s. The clock tree below pin %s will be excluded.

#### DESCRIPTION

CCOpt is creating a generated clock tree on the output pin of a multi-output instance, where there also exists a clock node associated with a different output pin of the instance. The latter will have been specified via attribute cts\_spec\_config\_trace\_through\_to. CCOpt is unable to satisfy both of these configurations, so will respect the generated clock tree creation by excluding the clock tree below the existing extract\_through\_to output pin. If the excluded portion of the tree is to be retained, an additional generated clock tree will need to be created with a source of that output pin.

### **IMPCCOPT-4388**

#### **NAME**

IMPCCOPT-4388

#### **SUMMARY**

The pin %s is a non-sink pin in a clock tree. You will need to delete the clock tree before setting this attribute will have any effect.

Error and Warning Messages

#### DESCRIPTION

attributes cts\_sink\_type and cts\_pin\_insertion\_delay affect how the clock trees are traced through the nelist. For this reason, attempting to set such a attribute on a non-sink pin in a clock tree is an error.

It is generally recommended to apply cts\_sink\_type and cts\_pin\_insertion\_delay settings to non-sink pins before creating the clock spec.

However, to make such a setting on a given pin after a spec has been created: first delete the affected clock trees; next apply the setting; and lastly re-create the deleted clock trees. Note that as a consequence of the setting, the re-created clock trees will treat the given pin a clock sink, and will no longer trace past it.

### **IMPCCOPT-5026**

#### NAME

IMPCCOPT-5026

#### SUMMARY

The obstruction grid has %ld cells. This is too large to consider blockages and LEF obstructions. Current limit is %d.

#### DESCRIPTION

The obstruction is too large. Blockages and LEF obstructions are ignored for routing. You can consider blockages and LEF obstructions by increasing the value of the attribute cts\_routing\_max\_num\_obstruction\_grid\_cells.

### IMPCCOPT-5037

#### NAME

IMPCCOPT-5037

### **SUMMARY**

Found %d pre-routed clock net(s). Pre-routed clock nets are treated as dont\_touch and their routing geometry will be preserved.

#### **DESCRIPTION**

Found pre-routed clock net(s). Pre-routed clock nets are treated as dont\_touch and their routing geometry will be preserved.

### **IMPCCOPT-5046**

#### NAME

IMPCCOPT-5046

#### **SUMMARY**

Net '%s' in clock tree '%s' has existing routing that will be removed by CCOpt.

#### **DESCRIPTION**

By default, CCOpt will remove any pre-routing on clock tree nets. To preserve this routing (and treat the net as dont\_touch) change its routing status to FIXED and set the 'skip\_routing' attribute on the net.

# **IMPCCOPT-5047**

### **NAME**

IMPCCOPT-5047

#### **SUMMARY**

Error and Warning Messages

Found %d clock net(s) with existing routing that will be removed by CCOpt.

#### DESCRIPTION

Found clock net(s) with existing routing that will be removed by CCOpt. To preserve this routing (and treat the net as dont\_touch) consider changing its routing status to FIXED or setting the 'skip\_routing' attribute.

# IMPCK-29

#### NAME

IMPCK-29

#### **SUMMARY**

The -routeNonDefaultRule parameter in the setCTSMode command contains an invalid rule name %s.

#### DESCRIPTION

Please specify a valid rule name. A valid rule name is either the name of a NONDEFAULTRULE statement specified in a previouly-loaded LEF/DEF file, or the name of a non-default rule created by command "add ndr".

### **IMPCK-157**

#### NAME

IMPCK-157

#### **SUMMARY**

Cell %s is set as dont\_touch in the timing libraries. May have to use 'set\_dont\_touch [get\_lib\_cells %s] false' in order to delete the buffers in clock tree.

Error and Warning Messages

#### DESCRIPTION

deleteClockTree does not delete the buffer whose dont\_touch attribute is set. But clockDesign will ignore the dont\_touch attribute of buffers and inverters. For details of deleteClockTree and clockDesign usage, see documents.

# **IMPCK-209**

#### **NAME**

IMPCK-209

#### SUMMARY

Clock %s has been synthesized. Type 'man ENCCK-209' to see extended message about this warning.

#### **DESCRIPTION**

This message indicates Clock Tree Synthesis (CTS) thinks this clock tree has already been built and, therefore, will not run. The reason it thinks clock has been synthesized is explained in one of the messages that precede it. For example, if a clock buffer or excluded cell is found on the clock net while tracing it, it will issue an ENCCK-766 or ENCCK-767 message and stop. In order to run CTS you must delete the existing clock tree first.

When running clockDesign it will automatically call deleteClockTree at beginning to remove buffers on the clock. However deleteClockTree cannot remove fixed instances. You should run following command to unfix existing buffers on the clock so deleteClockTree can remove them:

changeClockStatus -clk clockName -noFixedNetWires -noFixedBuffers

This will set status to Placed for all buffers and wires in the specified clock tree. You can use the -all option in place of -clk <clockName> to perform this operation on all clocks defined in the CTS specification file. Once you change the status to Placed, deleteClockTree will be able to remove all existing buffers in the clock tree.

### **IMPCK-361**

#### NAME

IMPCK-361

#### SUMMARY

The parameter '-localSkew' is not supported in Multi-Corner CTS. To run ckECO -localSkew on a single corner, specify the same analysis view for both setup and hold. For example, if the desired analysis view is func\_worst, then do "set\_analysis\_view -setup func\_worst -hold func\_worst" and reload the clock spec file.

#### DESCRIPTION

The above error is generated in Innovus when trying to run command "ckECO -localSkew" in MMMC mode.

What is the recommended way to run "ckECO -localSkew" in MMMC mode?

By default, CTS attempts to optimize across all active setup and hold views.

The -localSkew parameter of ckECO does not support this, and hence the above error is generated.

The workaround is to run "ckECO -localSkew" for a single setup view. Select the setup view which you want to target and specify this view for both setup and hold.

#### Example:

set analysis view -setup setup func -hold setup func

## **IMPCK-657**

#### NAME

IMPCK-657

#### SUMMARY

No cell is specified for clock %s in the clock tree specification file. What CTS is complaining about is the lack of a line specifying which buffers and/or inverters may be used for building the clock tree. THAT'S the cell that is 'not specified'. If you add a line specifying which buffers from your technology library CTS is allowed to use, CTS will run correctly.

#### DESCRIPTION

Why does tool report above error message on running clock tree synthesis?

User has defined a root pin as follows in his clock tree specification file:

AutoCTSRootPin ck

Period \10ns

MaxDelay 0.01ns #sdc driven default

MinDelay Ons #sdc driven default

MaxSkew \400ps #sdc driven default

SinkMaxTran \200ps #sdc driven default

BufMaxTran \200ps #sdc driven default

**END** 

What CTS is complaining about is the lack of a line specifying which buffers and/or inverters may be used for building the clock tree. THAT'S the cell that is 'not specified'. If you add a line specifying which buffers from your technology library CTS is allowed to use, CTS will run correctly:

Current example:

AutoCTSRootPin ck

Error and Warning Messages

Period \10ns

MaxDelay 0.01ns # sdc driven default

MinDelay 0ns # sdc driven default

MaxSkew \400ps # sdc driven default

SinkMaxTran \200ps # sdc driven default

BufMaxTran \200ps # sdc driven default

# Following line was added

Buffer CLKBUFX1 CLKBUFX12 CLKINVX1 CLKINVX12

**END** 

# IMPCK-661

#### NAME

IMPCK-661

#### SUMMARY

Clock %s has multiple definitions in the clock tree specification file.

#### DESCRIPTION

This warning is issued when there are multiple definitions of the clock in the database. This typically occurs when you run specifyClockTree multiple times without running cleanupSpecifyClockTree first. Before running specifyClockTree run cleanupSpecifyClockTree to clear any CTS specification currently in the database. Then run specifyClockTree. Note, if you are running "clockDesign -spefFile specFileName", it automatically runs cleanupSpecifyClockTree before specifyClockTree.

The other cause of this message is if you have multiple autoCTSRootPin

definitions for the same clock inside your CTS constraints file. If this is the case, remove the multiple definitions.

### **IMPCK-766**

#### NAME

IMPCK-766

#### **SUMMARY**

Find excluded cell %s in the clock tree.

#### DESCRIPTION

This message indicates an excluded cell was found downstream of from the clock root you are trying to synthesize. Therefore, Clock Tree Synthesis (CTS) will not run. Avoid this warning by deleting the clock tree prior to CTS using the deleteClockTree command. clockDesign automatically runs deleteClockTree before tracing the clock but deleteClockTree cannot remove fixed instances. Therefore, you should run the following to unfix the clock tree so deleteClockTree can remove the existing buffers in the tree:

changeClockStatus -clk clockName -noFixedNetWires -noFixedBuffers
This will set the placement status to Placed for all buffers and wires in the
specified clock tree. You can use the -all option in place of -clk clockName to
perform this on all clocks defined in the CTS specification file. Once you
set the status to Placed, deleteBufferTree will be able to remove these
existing buffers in the tree.

## **IMPCK-767**

#### NAME

IMPCK-767

#### **SUMMARY**

Find clock buffer %s in the clock tree.

#### **DESCRIPTION**

This message indicates a clock tree buffer was found downstream from the clock root you are trying to synthesize. Therefore, Clock Tree Synthesis (CTS) will not run. Avoid this warning by deleting the clock tree prior to CTS using the deleteClockTree command. clockDesign automatically runs deleteClockTree before tracing the clock but deleteClockTree cannot remove fixed instances. Therefore, you should run the following to unfix the clock tree so deleteClockTree can remove the existing buffers in the tree:

changeClockStatus -clk clockName -noFixedNetWires -noFixedBuffers
This will set the placement status to Placed for all buffers and wires in the
specified clock tree. You can use the -all option in place of -clk clockName to
perform this on all clocks defined in the CTS specification file. Once you
set the status to Placed, deleteBufferTree will be able to remove these
existing buffers in the tree.

Alternatively, if you prefer to preserve portions of the clock tree and synthesize the rest you can use PreservePin. PreservePin preserves the netlist for the pin and pins below the pin in the clock tree. However, CTS considers any synchronized pins after the pin when computing skew. For example: PreservePin

+ CLK L1 I0/A

## **IMPCK-6001**

#### **NAME**

IMPCK-6001

#### SUMMARY

Clock %s has a maximum of %d levels of logic before synthesis. Sample path: %s

#### **DESCRIPTION**

This will make ckSynthesis difficult to balance all sinks and achieve reasonable skew.

Please check those deeply gated clock paths to see if any tracing directive (for example, LeafPin, ExcludedPin, SetDPinAsSync NO) is necessary, but missed from clock spec file.

# **IMPCK-6336**

#### **NAME**

IMPCK-6336

#### **SUMMARY**

Clock %s contains equivalent gates that have bounding boxes of their downstream leaf pins overlapped. This is most probably caused by cloning without adequate placement information. Use one clock gate to drive all leaf pins, or, division of leaf pins based on physical locations between clock gates may help improve this situation.

#### **DESCRIPTION**

This warning is part of the new CTS diagnostic feature which is designed to highlight potential

Error and Warning Messages

issues or inefficiencies in the clock setup.

It is issued by clock gating instance location check at pre-synthesis stage.

The message means that two (or more) cloned gates are driving registers in a common area where the bounding boxes of downstream sinks overlap each other physically. This can lead to poor QoR.

A possible reason for that is previous clock gate cloning was not done properly, therefore they could be good candidates for decloning/cloning by performing ckDecloneGate followed by ckCloneGate on suggested gating instances.

Either one gate could drive all the registers here or the division of the registers between the clock gates could be done better.

## IMPCPF-190

#### NAME

IMPCPF-190

#### **SUMMARY**

INFO: CPF file %s is hierarchical; Flattening hierarchical CPF file, the logfile is %s/flattencpf.log ...

### **DESCRIPTION**

The CPF file is hierarchical CPF format, will be flattened via CLP integrator by read\_power\_intent when 'setMsvMode -supportHierCPF false'

#### Example:

Before hierarchical CPF native support, Innovus needs to flatten it via CLP

integrator and load the flattened CPF file.

With beta-quality hierarchical CPF native support feature 'setMsvMode

-supportHierCPF true', Innovus can load this CPF without flattening

## **IMPCPF-201**

#### NAME

IMPCPF-201

#### **SUMMARY**

error parsing CPF file %s.

### **DESCRIPTION**

This error is a general message issued when the parsing of CPF fails.

This is typically due to syntax errors in the CPF. When you receive this message, review the log file for warning and error messages which precede the IMPCPF-201 message. You should see messages which report the specific lines in CPF which Innovus System is complaining about.

Correct the CPF and then try loading it in again. See the Common Power Format Language Reference for CPF syntax and examples.

# IMPCPF-209

### **NAME**

IMPCPF-209

#### **SUMMARY**

line %s: %s %s not defined.

### **DESCRIPTION**

Error and Warning Messages

This error message happens when a CPF object is used without defining or fails to define it. Check the CPF file for the definition/creating of the object. And also look for any error/warn messages prior to this error.

For example, if 'create\_power\_domain' command errors out due to some reason, the later 'update\_power\_domain' will give this error because the power domain it tries to update is not defined. Please also pay attention to the command order in the CPF file. If some object is defined after it's used, tool will also give this error message.

#### Example:

-----

\*\*ERROR: (IMPCPF-209): line 453: power\_domain PD\_off is not defined.

\*\*ERROR: (IMPCPF-209): line 735: power\_mode PMdvfs2 is not defined

\*\*ERROR: (IMPCPF-209): line 740: global net VDDw is not defined

### **IMPCPF-235**

#### NAME

IMPCPF-235

#### **SUMMARY**

domain '%s' not specified in the -domain conditions list in default power mode%s.

#### **DESCRIPTION**

The message is reported when a power domain (Example: PD\_C2) is given in the domain conditions but the power domain is not defined by create\_power\_domain,means there is no power domain PD\_c2.

#### Example:

In the given example only PD\_C1 is defined but there is no PD\_C2. The below sequence issue the

message.

create\_power\_domain -name PD\_C1
create\_power\_mode -name M1 -default -domain\_conditions {PD\_C1@off PD\_C2@on}

### **IMPCPF-237**

#### NAME

IMPCPF-237

#### SUMMARY

library set not specified for nominal condition %s in default power\_mode %s.Please use CPF update nominal condition -library set to specify its library set.

#### DESCRIPTION

Encounter 13.1 release onwards, tool issues above error message if library sets are not defined in CPF. The library sets can be defined either using viewdefinition.tcl file or using define\_library\_set command in CPF. The library sets defined in CPF can be further associated to nominal condition as shown below:

create\_nominal\_condition -name off -voltage 0 -ground\_voltage 0.0 -state\_off update\_nominal\_condition -name off -library\_set lib set name >

But, if the library sets are not defined in CPF, then CPF will issue above error message while executing create\_power\_mode command: create\_power\_mode -name cpu\_off -domain\_conditions {pd\_1@off pd\_2@on} To resolve this error message and use the library sets defined with viewdefinition.tcl, please set below variable before read\_power\_intent: setMsvMode -useViewDefLibSet true

This makes CPF to recognize the library sets defined in

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

viewdefinition.tcl and do not require update\_nominal\_condition command in CPF to have library sets defined.

## **IMPCPF-238**

### NAME

IMPCPF-238

### **SUMMARY**

ILibrary file %s of library\_set %s used in the CPF file is not loaded from viewDefinition file. It's caused by inconsistent library\_set definition in CPF and viewDefinition file.

## **DESCRIPTION**

Library set in the CPF file needs to contain the same library files as in the viewDefinition file.

This message is reported when CPF file loads a library file that is not loaded into Innovus by viewDefinition file during design initialization.

To solve it, check the library set definitions in CPF and viewDefinition files and make sure them consistent.

A good practice is to define library file paths in a separate file and use variable in CPF and viewDefinition file so that they will always be consistent.

# IMPCPF-239

## **NAME**

IMPCPF-239

### SUMMARY

The default power mode is not defined. Please check if CPF has create\_power\_mode with -default option.

### **DESCRIPTION**

CPF needs a default power mode. Please define a CPF power mode as a default by create\_power\_mode -default.

Example:

-----

## **IMPCPF-243**

## **NAME**

IMPCPF-243

#### SUMMARY

Cannot bind power domain %s to a library\_set.

#### **DESCRIPTION**

Power domain library binding is through either MMMC file(viewDefinition.tcl) or CPF power mode and nominal condition as follows:

- a. viewDefinition.tcl: update\_delay\_corner -name dc1 -power\_domain PD1 -library\_set libSet1
- b. CPF: create\_power\_mode -name PM1 -default -domain\_conditions{PD\_FOOBAR@1.08v} where nominal condition 1.08v is associated to a lib by update\_nominal\_condition -name nc1 library\_set libSet1

<sup>\*\*</sup>ERROR: (IMPCPF-239): The default power mode is not defined.

# **IMPCPF-246**

#### NAME

IMPCPF-246

#### SUMMARY

Must specify sdc\_files for power\_mode %s to be used in analysis\_view %s. Use 'update power mode -sdc files' in the CPF file to specify.

### **DESCRIPTION**

In the CPF file, power mode used in 'create\_analysis\_view' command must have SDC file specified. Because commit\_power\_intent will convert the power mode into constraint mode and it needs to know the SDC file. To specify, use the update power mode command.

### Example:

```
create_power_mode -name PM_HL_FUNC -domain_conditions \\
{AO@high_ao PLL@high_pll TDSPCore@low_tdsp TDSPCore_R@low_tdsp}\
update_power_mode -name PM_HL_FUNC -sdc_files \\
dtmf_recvr_core_gate_wc.sdc
```

Example:

<sup>\*\*</sup>ERROR: (IMPCPF-246): Must specify sdc\_files for power\_mode PM\_LO\_FUNC to be used in analysis\_view AV\_LO\_FUNC\_MAX\_RC1. Use 'update\_power\_mode -sdc\_files' in the CPF file to specify.

# **IMPCPF-247**

### NAME

IMPCPF-247

## **SUMMARY**

The operating\_corner %s %s not specified; the default value %g is used.

## **DESCRIPTION**

The message is issued when operating corner is not defined in CPF.

Example:

Add below command to CPF to avoid this warning create\_operating\_corner -name qc\_max\_corner -process 3 -temperature 125 -voltage 0.99 -library\_set max\_timing

# IMPCPF-249

### **NAME**

IMPCPF-249

### SUMMARY

The CPF file is incomplete.

## **DESCRIPTION**

The CPF file is missing the definition of some key objects. Usually the error message shows up along with some other error messages. Check those error and

fix them before loading the CPF.

Example:

-----

Checking CPF file ...

\*\*ERROR: (IMPCPF-243): Cannot bind power domain VDD1 to a library set.

\*\*ERROR: (IMPCPF-243): Cannot bind power domain VDD2 to a library\_set.

\*\*ERROR: (IMPCPF-243): Cannot bind power domain VDD to a library\_set.

\*\*ERROR: (IMPCPF-239): The default power mode not defined.

\*\*ERROR: (IMPCPF-249): The CPF file is incomplete

## **IMPCPF-251**

### NAME

IMPCPF-251

### SUMMARY

line %s: create\_isolation\_rule -name %s: Can not find an isolation cell with a valid location domain %s and with the isolation output state %s. The possible reasons are: 1) the specified location in update\_isolation\_rule is different from the location in define\_isolation\_cell, or 2) the output state for the valid isolation cell does not match to its output state specified in create\_isolation\_rule.

## **DESCRIPTION**

The message shows that Innovus cannot insert an isolation cell with a valid location and with required isolation\_output state. The reasons could be:

1. The rule-specified location is different from the valid location specified in define\_isolation\_cell. For example: define\_isolation\_cell -cells isoandlow\_f2\_pm -valid\_location on create\_isolation\_rule -name VDD2LSW1\_iso\_low\_from \\

-from PD\_VDD2LSW1

update\_isolation\_rules -names VDD2LSW1\_iso\_low\_from \\

-location from -cells (isoandlow f\* pm)

The rule specifies "-location from" (PD VDD2LSW1 is a switchable power

domain) and "-cells isoandlow f\* pm". But all the isolation cells

isoandlow f\* pm are specified as "-valid location on" which means the

isolation cells are to be placed in an unswitched domain.

Therefore these isoandlow\_f\*\_pm cells do not fit this rule.

If the rule specifies "-location to" in this case, then these cells

would fit the rule.

2. No valid cell can match the rule's output state requirement when

the isolation condition is asserted. For example,

create\_isolation\_rule -name iso\_low -isolation\_output low

update\_isolation\_rules -names iso\_low -cells {isonandhigh\*\_pm}

There are no isolation cells matching the name isonandhigh\*\_pm with

isolation\_output low. Therefore the message of CPF-251 is issued.

Verify the cell name and confirm a cell exists which matches the cell

specified and also matches the required isolation output state.

## **IMPCPF-253**

#### NAME

IMPCPF-253

#### **SUMMARY**

line %s: create\_isolation\_rule -name %s can not insert an inverter in power domain %s to generate the inverted isolation enable signal %s. Most likely, the net is set to 'dont\_touch' or the inverter is not bound to this domain. Please remove the 'dont\_touch' constraint or correct the power domain library

binding.

### DESCRIPTION

This error message was seen either because the net has dont\_touch attribute or the inverter is not available. For the unavailable inverter reason, starting from Encounter 14.1, we recommend users to use viewDefinition.tcl to do the domain binding in a specific domain. check if the specific domain's library binding has the available inverter.

# IMPCPF-289

### NAME

IMPCPF-289

#### SUMMARY

library file %s in library set %s is not loaded, it will be skipped in determining temperature or process of operating corner %s.

### **DESCRIPTION**

The message is issued when the library set is not loaded properly. Check viewdefinition.tcl and correct the library set

# **IMPCPF-310**

#### NAME

IMPCPF-310

#### **SUMMARY**

line %s: create\_isolation\_rule -name %s: location domain %s does not have hinst to insert isolation in the location domain. check if the option in update isolation rules is specified correctly.

#### **DESCRIPTION**

commit power intent will insert the isolation cell based on the isolation rule.

If a rule tells the tool to insert the isolation in a particular domain,

the users need to make sure that this particular domain has a hierarchical instance for the isolation to be inserted logically.

## IMPCPF-311

### **NAME**

IMPCPF-311

### SUMMARY

line %s: create\_level\_shifter\_rule -name %s: location domain %s does not have hinst to insert level\_shifter in the location domain.check if the location option in update\_level\_shifter\_rules is specified correctly.

### **DESCRIPTION**

commit\_power\_intent will insert the level shifter cell based on the level shifter rule.

If a rule tells the tool to insert the level shifter in a particular domain,

the users need to make sure that this particular domain has a hierarchical instance

for the level shifter to be inserted logically

# IMPCPF-312

#### NAME

IMPCPF-312

#### **SUMMARY**

line %s: create\_%s\_rule -name %s: valid %s cells (%s) are not bound to location domain %s; or the library defining those cells are not loaded while executing init\_design. Please check this domain library binding.

### **DESCRIPTION**

This is caused by library which defining those cells are not loaded or binding to domain.

you need to check domain's library binding in view definition.tcl file.

In view\_definition.tcl file, we use command "update\_delay\_corner -power\_domain -library\_set" to specify domain's library.

### Example:

In view definition.tcl:

Only have: "create delay corner-name-library set-rc corner"

No "update delay corner-power domain-library set"

There are two solutions:

- 1. You need to modify this mmmc file by adding "update\_delay\_corner
- -power domain -library set" to specify the domain's library binding.

or

2. In foundation flow, do NOT specify the mmmc file and let CPF to set up the

MMMC. in the file FF/init.tcl,specify the init\_mmmc\_file to an empty string "".

then commit\_power\_intent will setup the MMMC based on the CPF spec and the domain library binding.

# IMPCPF-350

#### NAME

IMPCPF-350

#### **SUMMARY**

Found undefined variable while restoring CPF db, this might be a problem if CPF content is used by certain commands.

### DESCRIPTION

The design might be moved from other location which depends on some user defined variables to complete its content. Problem might arise if users run some commands that will use CPF data in the design, such as runCLP. In that case, users need to define those variables that are referenced by this design, and start over. This message will only be reported once, but there may be more than one undefined variable.

#### Example:

```
set cpf_isolation_rules
set cpf_level_shifter_rules
set cpf_pd_boundary_ports($name) cpf_pd_boundary_ports(load)
```

# IMPCPF-390

## **NAME**

IMPCPF-390

## **SUMMARY**

define\_always\_on\_cell: same %s and %s pins of always\_on cell %s

#### DESCRIPTION

This error is due to wrong pin definition in CPF define\_always\_on. The options -power\_switchalbe and -power (-ground\_switchable and -ground) in this command should not have the same pin name if it is power switchable (ground\_switchable) always on cell as follows:

define\_always\_on\_cell -cells { AlwaysOnCell } -power\_switchable VDD -power VDD -ground VSS Please check the .lib for the correct pin names for -power\_switchable and-power.

## IMPCPF-402

#### **NAME**

IMPCPF-402

#### SUMMARY

Cannot find any matching instance for domain %s -instances name %s.

## **DESCRIPTION**

Innovus issue warning during commit\_power\_intent when the instance provided in the CPF for a powerdomain is not present in the netlist.

#### Example:

## Assume "DTMF/WAON/ping\_mod/inst1" instance is not present in the netlist, but is provided in the CPF, Innovus will issue this warning during commit\_power\_intent. create power domain -name PD AON -instances {DTMF/WAON/ping mod/inst1}

# IMPCPF-403

## **NAME**

IMPCPF-403

#### SUMMARY

Cannot find any matching port for domain %s -boundary\_ports name %s defined in create power domain -boundary ports. Check if this boundary port exists in the netlist.

#### DESCRIPTION

Sometimes, users use create\_power\_domain -boundary\_ports <listOfports> to define the boundary ports' power domain. Users need to make sure the specified list of ports exist in the netlist. Otherwise, commit\_power\_intent will issue the above Error when it can not find the port.

## IMPCPF-701

### **NAME**

IMPCPF-701

### SUMMARY

%s inst %s(cell %s) is not in the valid location '%s', any 2nd P/G pin will not be connected.

#### DESCRIPTION

This message is issued when an iso/shifter instance is found at invalid location.

Such issue might result in no P/G connection of 2nd P/G pin of the cell.

An iso/shifter cell can be limited to be inserted in the power domain of signal's source or sink, if not inserted correctly, its 2nd P/G pins can not be correctly connected.

# IMPCPF-980

### NAME

IMPCPF-980

#### **SUMMARY**

Power domain %s is not bound to any library. Power domain library binding is through 'update\_delay\_corner -power\_domain' in the MMMC file viewDefinition.tcl. Please make sure that 'update\_delay\_corner -power\_domain %s' is specified for each delay corner in the MMMC file.

### **DESCRIPTION**

The WARN happens when CPF does not contain MMMC definition and power domain is not bound to

library through 'update delay corner -power domain' in MMMC file viewDefinition.tcl.

User need to check the sanity of viewDefinition.tcl file and fix the problem by adding

'update\_delay\_corner -power\_domain %s'.

The WARN on non-virtual power domain is critical for whole flow.

Example

\*\*WARN: (IMPCPF-980): Power domain PD3 is not bound to any library. Power domain library binding is through 'update\_delay\_corner -power\_domain' in the MMMC file viewDefinition.tcl. Please make sure that 'update\_delay\_corner -power\_domain PD3' is specified for each delay corner in the MMMC file.

## IMPCPF-2011

### **NAME**

IMPCPF-2011

#### SUMMARY

The switchable power domain %s shutoff condition is not specified in CPF.

### **DESCRIPTION**

When dumping out cpf file using command write\_cpf or write\_power\_intent, there is no "-shutoff\_condition" saved out for switchable power domain.

The case may be non-standard msv flow case, for example, the power domain in the DB are defined but did not follow the "standard" msv flow which uses CPF.

This case need to be converted to CPF case in order for it to be officially supported.

For example, the case is 1801 based case. After "write cpf top.cpf" after init design:

<CMD> write\_cpf top.cpf

\*\*WARN: (IMPCPF-2011): The switchable power domain PD2 shutoff condition is not specified.

\*\*INFO: constraint mode func\_mode is specified in multiple analysis view, the nominal condition for analysis view setup func m40 is used to create corresponding power mode.

# IMPCPF-2204

### NAME

IMPCPF-2204

#### SUMMARY

Cannot get the primary power net for the power domain %s, using first power net %s specified in connections as primary power net.

#### DESCRIPTION

This warning message comes when CPF does not define the primary power net for the %s domain. Example:

-----

Something similar to the following needs to be added: update\_power\_mode -name PM1 -primary\_power\_net VDD1

## IMPCPF-2210

#### NAME

IMPCPF-2210

## **SUMMARY**

The partition CPF %s references the toplevel SDC files. Modify the partition CPF to reference the correct SDC files if necessary.

#### DESCRIPTION

The message is reported when the SDC's in CPF are not point to correct SDC

Example:

Correct SDC path of below command in the CPF update power mode -name PD1 -sdc files \${libDir}/cpf/Block1.sdc

# IMPCPF-2303

#### NAME

IMPCPF-2303

## **SUMMARY**

Using CPF is required to save the database. Please use "write\_power\_intent -cpf <filName>.cpf; read\_power\_intent -cpf <fileName>.cpf; commit\_power\_intent" to write\_db again.For more information about CPF information or a backward compatibility mode, refer to the documentation.

Error and Warning Messages

### DESCRIPTION

This message is issued when the design has power domains, but CPF or IEEE1801 or LP DB is not loaded. Please confirm the power domains are defined through CPF or IEEE1801 file.

## IMPCPF-2500

#### NAME

IMPCPF-2500

#### SUMMARY

Cannot support disjoint power domain with leaf instance(s)

### **DESCRIPTION**

This message is reported while creating disjoint power domain with option -disjoint\_hinst\_box\_list of a PD which have a leaf instance given in CPF for "create\_power\_domain -instance <Hier\_Instt Leaf\_Inst>" along with Hier instance which is not a support model .Explicitly Hier instance should be part of create\_power\_domain PD -instances' of CPF file to create disjoint PD. Correct your CPF by providing only Hier instances and avoid leaf instances in the CPF.

#### Example:

```
update_power_domain PD -disjoint_hinst_box_list {
{A {ax0 ay0 ax1 ay1 ax2 ay2 ax3 ay3}}
{{B C} {bx0 by0 bx1 by1 bx2 by2 bx3 by3}} }
update power domain PD -add block box {block1}
```

Note: disjointHInstBoxList: Specify a disjoint region for the hinsts as a pair of hinsts and region. The region is defined as box list.

# IMPCPF-2510

### NAME

IMPCPF-2510

#### SUMMARY

The box list specified is not disjoint.

## **DESCRIPTION**

In real designs, an RTL or logical-level power domain may have to be implemented into different physical regions with unconnected local power supplies. Such implementation of a power domain is called a Disjoint Power Domain.

#### Example:

1. One box

update\_power\_domain PD1 -disjointBoxList {46 479 319 543}

\*\*ERROR: (IMPCPF-2510): the box list specified is not disjoint

2. Abutted

update power domain PD1 -disjointBoxList {46 479 319 543 46 475 263 479}

\*\*ERROR: (IMPCPF-2510): the box list specified is not disjoint

# IMPCPF-2602

### **NAME**

IMPCPF-2602

### **SUMMARY**

Loading floorplan after commit\_power\_intent may cause inconsistency in power domains. The

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

recommended low power flow is to load floorplan before read power intent.

### DESCRIPTION

This message pops-up when the user tries to load floor-plan file after CPF is loaded and committed to the design

Example:

In order to avoid this issue, the user should load floor-plan file in after design is imported, then load and commit cpf file.

This will ensure correct power intent information being applied to the design

# **IMPCTE-104**

### **NAME**

IMPCTE-104

#### SUMMARY

The constraint mode of this inactive view '%s' has been modified and may need to be reanalyzed to ensure proper timing results. To reanalyze timing for this view make the view active using 'set analysis view' and run timing analysis.

#### **DESCRIPTION**

This warning message appears when 2 or more views are sharing the same constraint mode in the design and also the constraints are changed. For example, In a design, say totally 9 analysis views are created and all these views are sharing the same constraint mode "delay\_constraints" and currently 2 views are in active state, Now, when there is a change in the constraint modes in form of some constraint change, tool is trying to make these changes to all of the inactive views. Hence the warning message clearly shows that the constraint mode has been modified and the particular inactive view should be re-analyzed to make proper timing analysis. There won't be any harm on proceeding further on the design steps.

### NAME

IMPCTE-290

#### **SUMMARY**

Could not locate cell %s in any library for view %s.

### **DESCRIPTION**

This message is issued when cell could not be found in any library of the view. To find the list of libraries associated with the view, use command "report" analysis views -type active".

## **IMPCTE-291**

### **NAME**

IMPCTE-291

## **SUMMARY**

%s is a physical only instance and is ignored. This indicates that the instance is physical only (e.g. a filler/decap cell) and is in the database, but not in timing graph since physical cells do not have timing information. Verify the instance is a physical only cell to confirm that this warning can be ignored.

## **DESCRIPTION**

This warnning is issued when tool tries to do timing analysis for physical only instance. Please check your lib cell whether has (e.g. is filler cell/is decap cell/is tap cell true) attribute.

#### NAME

**IMPCTE-313** 

#### SUMMARY

Paths not in the in2out domain will be added 1000ns slack adjustment.

## **DESCRIPTION**

This warning is issued when path groups are set in input to output mode only.

For all the other paths that are not in the in2out domain, a positive slack of 1000ns is added so that they do not show up as critical paths during analysis.

# **IMPCTE-314**

#### **NAME**

IMPCTE-314

### SUMMARY

Paths not in the in2reg domain will be added 1000ns slack adjustment.

### **DESCRIPTION**

This warning is issued when path groups are set in input to register mode only.

For all the other paths that are not in the in2reg domain, a positive slack of 1000ns is added so that they do not show up as critical paths during analysis.

#### NAME

**IMPCTE-317** 

#### SUMMARY

Paths not in the reg2out domain will be added 1000ns slack adjustment

## **DESCRIPTION**

This warning is issued when path groups are set in register to output mode only.

For all the other paths that are not in the reg2out domain, a positive slack of 1000ns is added so that they do not show up as critical paths during analysis.

# **IMPCTE-318**

## **NAME**

**IMPCTE-318** 

### **SUMMARY**

Paths not in the reg2reg domain will be added 1000ns slack adjustment.

### **DESCRIPTION**

This warning is issued when path groups are set in register to register mode only.

For all the other paths that are not in the reg2reg domain, a positive slack of 1000ns is added so that they do not show up as critical paths during analysis.

#### NAME

**IMPCTE-337** 

#### **SUMMARY**

An unsupported Liberty attribute: max\_clock\_tree\_path - was found on pin %s of cell: %s in library: %s. This attribute is not supported by timing analysis and will be ignored. Type 'man IMPCTE-337' for more detailed information.

### **DESCRIPTION**

Used in timing groups under a clock pin. Defines the maximum clock tree path constraint for a pin driving an internal clock tree for input transition. Please check lib to confirm that this warning can be ignored.

## **IMPCTE-432**

#### NAME

IMPCTE-432

### **SUMMARY**

Failed to convert the next state function %s of cell %s to BDD.

#### DESCRIPTION

This warning is issued when the function expression constains an undeclared variable or port. Please check the timing library where the next state function is defined for the cell.

# **IMPDB-1206**

#### NAME

IMPDB-1206

### **SUMMARY**

Global net name not specified.

## **DESCRIPTION**

This error occured when empty name "" is specified for global net. Need to specify existing net name.

## **IMPDB-1216**

## **NAME**

IMPDB-1216

### **SUMMARY**

The global net '%s' specified in the global net connection(GNC) rule doesn't exist in the design.

### **DESCRIPTION**

This error occurs when power/ground nets are not defined before initializing/loading the design.

To resolve this error, define the power/ground nets before loading the design.

For example, power(VDD) and ground(VSS) nets can be declared as below before initializing the design

set init\_pwr\_net {VDD}

set init pwr net {VSS}

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

## **IMPDB-1220**

#### NAME

IMPDB-1220

#### SUMMARY

A global net connection(GNC) rule for connecting pin '%s' of cell '%s' to global net '%s' was specified. The connection cannot be made because the %s pin and the %s net are not of the same polarity. Check the imported design and make sure the GNC rule is correctly specified or generated. If the polarity mismatch is required, use the 'init\_ignore\_pgpin\_polarity\_check' variable to ignore the polarity check.

#### DESCRIPTION

{Some polarity checks need to be ignored, like for back-bias in Silicon-On-Insulator (SOI) technologies. Please refer to the 'init\_ignore\_pgpin\_polarity\_check'" variable documentation}

## **IMPDB-1284**

### NAME

IMPDB-1284

#### **SUMMARY**

Using lower level net '%s' to connect to higher level instance pgTerm in module '%s' is not allowed. The net needs to be in the same level as instance or in the higher level.

### **DESCRIPTION**

{Connect lower level net to higher level instance pg term is not allowed, ex: connect global net A/B/C/net1 to instance A/B/inst1 pg term won't be honored. Fixing the problem by replacing the net with higher level net A/net2}

# **IMPDB-2148**

### **NAME**

**IMPDB-2148** 

#### SUMMARY

%sterm '%s' of %sinstance '%s' is tied to net '%s'. However, none of the instance's %s terms is connected to the net. Usually an instance's tieHi/Lo term and one of the Power/Ground (P/G) terms of the instance should connect to the same P/G net. Check the input netlist, and also make sure proper global net connections are applied to the instance's tieHi/Lo terms and P/G terms.

## **DESCRIPTION**

Ensure that the global net connectivity for pgpins is defined. globalNetConnect VDD -type pgpin -pin VDD -all

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

globalNetConnect VSS -type pgpin -pin VSS -all

Check if 'globalNetConnect' command is run to specify the tie high/low signal nets.

globalNetConnect VSS -type tielo -all

globalNetConnect VDD -type tiehi -all

## **IMPDB-2504**

### **NAME**

IMPDB-2504

### SUMMARY

Cell '%s' is instantiated in the Verilog netlist, but it is not defined in the library or design data. Its pin directions may be derived incorrectly. Provide the cell definition or its pin information in the library or design data and reload the design to avoid potential issues.

## **DESCRIPTION**

Check running the command 'check\_instance\_library\_in\_views' which checks for missing libraries for instances in the active view.

Check running the command 'check library' which checks the problematic cells that cause issues.

Make sure if there should not mismatch between .lef and .lib for problematic cell, ex: definition or pin direction.

## **IMPDB-2532**

#### NAME

IMPDB-2532

## **SUMMARY**

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

RouteType '%s' already exists.

### DESCRIPTION

This error occurs when the route type being created (create\_route\_type) already exists in the design database. You can query the existing route types using following command:

innovus> dbGet head.routeTypes.name

In Common UI:

innovus> db\_db route\_types .name

## **IMPDB-2550**

#### NAME

IMPDB-2550

## **SUMMARY**

VIARULE '%s' referenced in parameterized via '%s' was not found in technology LEF, but was soft-matched to VIARULE '%s' in technology LEF.

## **DESCRIPTION**

Soft-matched means they have different VIARULE name but with the same content. You can ignore the warning to use the soft-matched VIARULE.

# **IMPDB-5029**

## **NAME**

IMPDB-5029

### **SUMMARY**

This message is issued because one %s cannot belong to two groups at the same time. '%s' was already assigned to group '%s', so it cannot be assigned to another group '%s' again.

### **DESCRIPTION**

Single instance cannot be assigned to multiple instance groups. To assign the instance to another group, you need to remove the instance from the current group. Please update\_group -delete first and retry update\_group -add.

# **IMPDB-7003**

## **NAME**

IMPDB-7003

### **SUMMARY**

Line '%d' is syntax error, MASKSHIFTPATTERN value must be an number array and element is layer shift value combination, eg: 0000 0001 0010 0011.

## **DESCRIPTION**

Define the MASKSHIFTPATTERN according MASKSHIFTLAYER metal layer sequence, only multi-mask layers need to be defined. 1st bit for 1st metal layer (routing or cut layer), 2nd bit for 2nd metal layer (routing or cut layer), and so on. 00 is required which mean the original mask.

## **IMPDBTCL-204**

#### NAME

IMPDBTCL-204

### SUMMARY

'%s' is not a recognized object/attribute for object type '%s'. For help use 'dbSchema %s' to get list of all supported (settable/unsettable) objects and attributes.

#### **DESCRIPTION**

The first field to dbGet must be {<obj>|<objList>|head|top|selected}. Obj or objlist is a pointer or list of pointer of a db object. "head" "top" and "selected" are keyword to the category of different db structure. Head point to the start of library related infomation. top point to start of design information and selected point to the start of selected objects.

#### Example:

Below command results in warning message IMPDBTCL-204

innovus 1> dbGet top.insts.wires

\*\*WARN: (IMPDBTCL-204): 'wires' is not a recognized object/attribute for object type 'inst'. For help use 'dbSchema inst' to get list of all supported (settable/unsettable) objects and attributes.

"dbSchema inst" will output recognized object/attributes for 'inst' object type. Alternatively, you can also use "dbGet top.insts.<tab in>" or "dbGet top.insts.?" to know the recognized objects.

# **IMPDBTCL-205**

#### NAME

**IMPDBTCL-205** 

### SUMMARY

Unknown or unsupported object pointer detected. See 'help dbGet' for more details.

#### DESCRIPTION

This can occur when dbGet is given a pointer which has been deleted from the database such as a wire segment, instance or net. You can verify the object pointer by selecting the object and running 'dbGet selected'. The Design Browser can also be used to search for and select the object. Note

object pointers are unique to each session so scripts should retrieve the object pointers.

## **IMPDBTCL-229**

#### NAME

**IMPDBTCL-229** 

#### SUMMARY

'%s' is not a legal attribute name, you probably have a typo. If it was not intended as an attribute name, you can hide it inside a tcl variable and use the variable instead in the dbget expression. You can use 'dbGet <object>.?h' to get list of all supported objects and attributes.

### **DESCRIPTION**

You may meet unexpected error in dbGet pattern matching if the pattern contains decimal point. For example:

> dbGet top.insts.instTerms.name {U1[0].test/SE}

\*\*ERROR: (IMPDBTCL-229): 'test' is not a legal attribute name, you probably have a typo. If it was not intended as an attribute name, you can hide it inside a tcl variable and use the variable instead in the dbget expression. You can use 'dbGet <object>.?h' to get list of all supported objects and attributes.

0x0

If the decimal point is escaped it works:

> dbGet top.insts.instTerms.name {U1[0]\\.test/SE}

{U1[0].test/SE}

But problems arise again if the result is used in a variable:

> set termName [lindex [dbGet top.insts.instTerms.name {U1[0]\\.test/SE}] 0]

U1[0].test/SE

> puts \$termName

U1[0].test/SE

> dbGet -p top.insts.instTerms.name \$termName

\*\*ERROR: (IMPDBTCL-229): 'test' is not a legal attribute name, you probably have a typo. If it was not intended as an attribute name, you can hide it inside a tcl variable and use the variable instead in the dbget expression. You can use 'dbGet <object>.?h' to get list of all supported objects and attributes.

0x0

Solution

The solution is to use regsub on \$termName to escape the decimal point before using it with dbGet:

> set termName [lindex [dbGet top.insts.instTerms.name {U1[0]\\.test/SE}] 0]

U1[0].test/SE

> puts \$termName

U1[0].test/SE

> regsub {\\.} \$termName {\\\\.} termName

1

> dbGet -p top.insts.instTerms.name \$termName

0x2aaab3f4e158

## **IMPDBTCL-271**

### **NAME**

IMPDBTCL-271

### **SUMMARY**

The root attribute '%s' is not used in this application, so it is ignored.

#### DESCRIPTION

This warning occurs when read\_db reads a root attribute that is not used in the current application. The most common reason is because the attribute was saved by an older release, and it is now obsolete and no longer needed. It is also possible an older release is trying to read a database

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

saved by a newer release, and the older release does not understand the new attribute. In either case, the attribute will be ignored, and will not be saved by a subsequent write\_db command.

## **IMPDBTCL-614**

#### NAME

**IMPDBTCL-614** 

### **SUMMARY**

\*\*INFO: (IMPDBTCL-614): Number of objects exceeds limit.Use setDbGetMode -displayLimit to control the number of objects evaluated by 'dbGet <object>.??' query.

## **DESCRIPTION**

{DEATILMESSAGE}

# **IMPDC-1159**

#### NAME

IMPDC-1159

#### SUMMARY

The input transition time value is less than 0.1ps. Ensure that the input transition time value is greater than or equal to 0.1ps.

## **DESCRIPTION**

This warning is displayed when the value of input transition time specified by you is less than 0.1ps. When you specify an input transition time value that is less than 0.1ps, the software ignores this value and uses the default value of 0.1ps. To avoid this warning, ensure that the input transition time value is greater than or equal to 0.1ps.

## **NAME**

IMPDC-3242

## **SUMMARY**

Total power of the design is not valid.

## **DESCRIPTION**

{DETILMESSAGE}

# **IMPDC-3243**

## **NAME**

IMPDC-3243

## **SUMMARY**

-powerDomain will be ignored in single PD flow.

## **DESCRIPTION**

{DETILMESSAGE}

#### NAME

**IMPDC-3245** 

## **SUMMARY**

The RC data is not in memory or the RC data in memory is for a different RC corner. RC data is being read.

## **DESCRIPTION**

{DETILMESSAGE}

# **IMPDC-3246**

## **NAME**

IMPDC-3246

## **SUMMARY**

Driver %s (cell %s) has different threshold value %s = %d from receiver %s (cell %s) threshold value %s = %d.

## **DESCRIPTION**

{DETILMESSAGE}

#### NAME

IMPDC-3247

#### **SUMMARY**

Driver %s (cell %s) has different slew derate value %s = %.3f from receiver %s (cell %s) slew derate value %s = %.3f.

## **DESCRIPTION**

{DETILMESSAGE}

# **IMPDC-3248**

## **NAME**

**IMPDC-3248** 

## **SUMMARY**

This delay calculation is calculating IRMS data and may take longer run time than usual. If IRMS data is not needed, turn in off with setDelayCalMode -computeIrms false.

## **DESCRIPTION**

{DETILMESSAGE}

#### NAME

IMPDC-3249

#### **SUMMARY**

The delay calculation mode is AAE. In AAE mode, the delay is not calculated with effective capacitance and table lookup, option -delaytable will be ignored.

### **DESCRIPTION**

{DETILMESSAGE}

## **IMPDF-2**

### **NAME**

IMPDF-2

## **SUMMARY**

The errors found when reading the DEF file '%s' are too serious to continue. The rest of the DEF file will not be read. Refer to error messages above for details. Fix the errors, delete any partially read in data, and reread the corrected DEF file.

## **DESCRIPTION**

If you have DEF syntax errors, you can look at the DEF manual to find the correct syntax. It can be accessed from the Innovus Help->Help Library... menu. Look under the Languages section for the latest LEF/DEF Language Reference Manual.

If there are other errors, check if you have the correct DEF file, and if you have the correct LEF or

Error and Warning Messages

OpenAccess libraries. Read the earlier error messages in detail to see exactly what went wrong.

Note, some data may have been read from the DEF file before the error occurred. You may need to delete it first, before reading a corrected DEF file. See documents for details about which sections of DEF are read in incrementally versus replacing the existing data.

## IMPDF-30

#### NAME

IMPDF-30

#### SUMMARY

Line %ld: OffMGrid: %s (%d, %d) (%d, %d) %s %s is not on Manufacturing Grid.

### **DESCRIPTION**

This error reports that a wire's coordinate in the DEF file are not on the manufacturing grid which will result in DRC errors.

The coordinates in the error message are in database units per micron (dbuPerMicron). Look for the following line in the DEF file to determine how many dbu's is 1 micron:

UNITS DISTANCE MICRONS dbuPerMicron;

When reading DEF Innovus System will check that each edge and the center-line of wires is on the manufacturing grid defined in the technology LEF file (MANUFACTURINGGRID).

One possible scenario that could cause this issue is that the two edges of the wire are on manufacturing grid but the center line, which is what DEF syntax uses, may not be. To check if your dbu's have enough granularity, multiply dbuPerMicron \* manufaturingGrid. The result should be an

Error and Warning Messages

integer quantity that is evenly divisible by two to ensure the center-line is on grid.

For example, if MANUFACTURINGGRID is 0.005, this is only achievable with a DBU of 2000.

- (1000\*0.005)/2 = 2.5, (not evenly divisible by two), the result could be off manufacturing grid.
- (2000\*0.005)/2 = 5, (evenly divisible by two), the result will be on manufacturing grid.

#### Or to say it another way:

If dbuPerMicron \* manufacturingGrid is an odd number (e.g. 1000\*0.005 = 5), you cannot create a path (center-line based) that has a width that is an odd number of manufacturing grids wide.

## IMPDF-84

#### **NAME**

IMPDF-84

#### **SUMMARY**

The ROW '%s' is ignored because it references a site '%s' that has not been defined in the LEF/OpenAccess technology. Review the LEF files specified or the OA technology database, to see if the site is correctly defined.

### **DESCRIPTION**

This error reports that a row references a site that has not been defined. The sites must be defined before they can be referenced from a row. Review the LEF files specified in the init\_lef\_files variable, or the OA technology database, and make sure the sites are correctly defined.

To determine the list of legal site names, use 'get db head.sites.name'.

Error and Warning Messages

While the design can be read in without rows and used for parasitic extraction and analysis, the loss of the rows will mean that placement and optimization functions will not work.

## **IMPDF-1008**

#### NAME

IMPDF-1008

#### SUMMARY

The routing has wire-patches (that requires DEF 5.8 NETS RECT statements) in the signal routing that cannot be represented correctly in DEF 5.6 or 5.7. They will be converted to SPECIALNETS routing RECT shapes instead. This output is suitable for RC extraction tools, but this DEF should not be read back into Innovus as the routing data will not be correct. You should use DEF 5.8 to represent this routing data correctly by using "set\_db write\_def\_lef\_out\_version 5.8".

### **DESCRIPTION**

Wire-patches are a new DEF 5.8 concept that allows a rectangle to be added in the NETS symbolic routing section. They are commonly used to add a small amount of metal to fix minimum-area violations, or fill in notch violations, etc.

DEF 5.6 or 5.7 has no NETS syntax for these shapes, so they can only be written to the SPECIALNETS section using RECT syntax. If you read this DEF back into Innovus these shapes will be special-route shapes, and the signal router will not be able to rip up or repair them. You will need to remove them with a script.

# **IMPDF-1012**

Error and Warning Messages

#### NAME

IMPDF-1012

### **SUMMARY**

%s at (%d %d) on net '%s' has been found with unknown routing status so it is ignored.

#### DESCRIPTION

Routes or vias should have a route status (routed, fixed, cover, noshield) in order for write\_def to write them to DEF. Routes with the unknown status are normally created by earlyGlobalRoute, and the net is marked isEarlyGlobalRouted and they are silently ignored by write\_def unless you use the write\_def -early\_global\_route option.

In some cases optimization may add some routes with the unknown status on nets that are not marked is Early Global Routed that will be repaired by the router later in the flow. It is also possible the user has added some routes manually or through scripts with the unknown status. This warning is caused by these types of routes, and write def will not write them out by default.

You can avoid this warning by using the -early\_global\_route option to force the unknown status routes to be written as "routed" status in the DEF, or by not using the -routing option so NETS section routing is not written at all.

## **IMPDF-1018**

#### **NAME**

IMPDF-1018

#### **SUMMARY**

The routing has wire-patches (that require DEF 5.8 NETS RECT statements) in the signal routing that cannot be represented in DEF 5.5. They will be lost and the routing data will be incomplete with missing shapes, because there is no DEF 5.5 syntax that can correctly represent them. You should use DEF 5.8 to represent this routing data correctly by using "set\_db write\_def\_lef\_out\_version 5.8".

#### DESCRIPTION

Wire-patches are a new DEF 5.8 concept that allows a rectangle to be added in the NETS symbolic routing section. They are commonly used to add a small amount of metal to fix minimum-area violations, or fill in notch violations, etc.

DEF 5.5 has no NETS or SPECIALNETS syntax that can represent these shapes. If you read this DEF back into Innovus the missing shapes will cause DRC violations, and other problems. You will need to remove the signal routing and then run the router again or try to use ECO routing commands to repair them.

## **IMPECO-1**

#### NAME

**IMPECO-1** 

#### SUMMARY

Cannot %s the %s %s inside hierarchical instance %s. The hierarchical instance has a Verilog module %s that is used multiple times in the netlist, so directly modifying this hierarchical instance is not allowed. You must either use the -parent option to modify the Verilog module instead, or set init design uniquify before init design to force a unique module for each hierarchical instance.

### **DESCRIPTION**

Error and Warning Messages

This message is issued when an ECO operation is applied on hierarchical instance and module is referenced multiple times in verilog netlist. ECO operations which do not support multiple referenced cells including changing instance name, changing an instancei's cell, deleting a net, adding a net, switching two terms of a net, and adding an instance.

To fix the issue, either use the -moduleBased option to modify the verilog module instead, or uniquify the netlist by running command 'set init\_design\_uniquify 1' before init\_design to force a unique module for each hierarchical instance.

## **IMPECO-37**

#### NAME

IMPECO-37

### **SUMMARY**

Net term hterm link incorrect after add term. Correct it.

### **DESCRIPTION**

This message is issued when in the hierarchical design the link between instance and its immediate parent hierarchical instance is broken. Such link is set up during design load and needs to be fixed. Contact your Cadence Design System representative.

# **IMPECO-146**

### **NAME**

IMPECO-146

### **SUMMARY**

Instance and net name must be unique in a module. The name '%s' is already used by an instance or a net in module '%s'. Use an unique name to avoid the problem. .

Error and Warning Messages

#### DESCRIPTION

This message is issued while adding a new net or changing an instance, the given new name for the net or instance is not unique. The name of net and instance must not be an existing name.

## **IMPECO-154**

#### NAME

IMPECO-154

### **SUMMARY**

Can not connect the net '%s' to the physical instance '%s' term '%s'.

### **DESCRIPTION**

This message is issued because we don't allow connecting physical instance pins to logical net.

# **IMPECO-238**

#### NAME

IMPECO-238

### **SUMMARY**

Net (%s) term hterm link incorrect after attaching a term. Correct it.

#### **DESCRIPTION**

This message is issued when in the hierarchical design the link between instance and its immediate parent hierarchical instance is broken. Such link is set up during design loading and needs to be fixed. Contact your Cadence Design System representative.

# **IMPECO-521**

#### NAME

IMPECO-521

#### SUMMARY

Cannot attach hterm to net (%s) without adding new port: different hierarchy.

#### **DESCRIPTION**

The specified pin/hpin and net are in different hierarchy and cannot attach without creating a new port. To avoid this error, please try conncect\_pin/connect\_hpin without -no\_new\_port/- no new hpins.

# **IMPECO-560**

#### NAME

IMPECO-560

#### SUMMARY

The netlist is not unique, because the module '%s' is instantiated multiple times. Make the netlist unique by running 'set\_db init\_design\_uniquify true' before loading the design to avoid the problem.

### **DESCRIPTION**

This message is issued when the module is instantiated multiple times in a netlist. Current DB ECO commands need unique netlist. To make the netlist unique, run command 'set\_db init\_design\_uniquify true' before loading the design to avoid the problem.

# **IMPECO-570**

#### NAME

IMPECO-570

#### **SUMMARY**

Assign is created by %s %s and %s %s.

#### **DESCRIPTION**

By default, init\_no\_new\_assigns is set to 0, applications such as optimization can create Verilog assign statements during netlist ECOs. New assign creation is allowed by the tool. However, in this design, command "set init\_no\_new\_assigns 1" was issued, creating any new assign is not allowed. Please report this issue to Cadence Customer Support.

As a work around, at the end of your run, use command delete\_assigns to remove all assigns. Please note that this command removes all assigns including those assign statements contained in the incoming Verilog netlist except for the const tie (1'b1/1'b0) assigns.

# **IMPECO-620**

#### **NAME**

IMPECO-620

### **SUMMARY**

Cannot change the cell of instance '%s' to '%s' from '%s', because the pins of these two cells are not identical.

### **DESCRIPTION**

This message is issued while changing the cell for an instance if the old cell and new cell do not have identical pins. This could be due to mismatch in number or name of the pins.

#### NAME

**IMPESI-3086** 

### **SUMMARY**

The cell '%s' does not have characterized noise model(s) for '%s' lib(s). Missing noise information could compromise the accuracy of analysis.

#### **DESCRIPTION**

This message is aimed to highlight cells without CCSN/ECSMN/CDB models. check\_noise command can be used to exhaustively check all the instances with missing noise models.

## **IMPESI-3140**

### **NAME**

IMPESI-3140

#### **SUMMARY**

Bumpy transitions may exist in the design which may lead to inaccurate delay computation. To report/analyze the nets having bumpy transition, please enable delay report and use command 'report\_noise -bumpy\_waveform -threshold 0' after timing analysis. Delay report is enabled by setting 'set\_db si\_delay\_enable\_report true' before timing analysis.

### **DESCRIPTION**

The nets identified as having bumpy transitions are the nets which have a reverse swing of more than 30 percent of Vdd in their transitions. High crosstalk on such nets is the source of such bumpy transitions, and should be fixed to ensure accurate delay computation.

#### NAME

IMPESI-3188

#### SUMMARY

Unable to interpolate for instance '%s' (cell: %s) view '%s'. The libraries '%s' %s.

#### DESCRIPTION

The analysis will snap to the library specified in IMPESI-3199 message. For proper analysis, make sure that you provide at least two libraries in the libset with different parameter values.

## **IMPESI-3189**

#### NAME

**IMPESI-3189** 

### **SUMMARY**

Proper analysis will not take place since the cell, %s, is present in multiple noise library files (cdb): %s, %s and these files are bound to the same timing model file (.lib): %s. Make sure there is a one-to-one mapping between the noise and timing libraries. Check the ENCESI-3192 message for the names of the cdb files that are missing the timing library.

#### DESCRIPTION

For proper analysis, remove the extra noise library files or add the correct timing library files such that there is a one-to-one mapping between timing library and noise library files. The analysis tool can only bind one noise library to one timing library for proper analysis.

#### NAME

**IMPESI-3190** 

#### **SUMMARY**

Proper SI analysis cannot take place for net %s with driver instance %s and pin %s of reference cell %s beacuse there is no noise library data bound to the instance. Default parameters from the timing models will be used. Timing library mapped to this instance is %s at %s. Check that the proper noise libraries are being loaded in the design.

### DESCRIPTION

Use the report\_instance\_library command to check the timing library binding for the instance. Use the report\_instance\_cdb command to check the cdB binding for the instance. Check that there is a noise library that matches the timing library power connections for the cell.

## IMPESI-3191

#### NAME

**IMPESI-3191** 

#### **SUMMARY**

Proper SI analysis cannot take place for net %s with receiver instance %s and pin %s with reference cell %s because there is no noise library data bound to the instance. Default parameters from the timing models will be used. Timing library mapped to this instance is %s at %s. Check that the proper noise libraries are being loaded in the design.

#### DESCRIPTION

Use the report instance library command to check the timing library binding for the instance. Use

Error and Warning Messages

the report\_instance\_cdb command to check the cdB binding for the instance. Check that there is a noise library that matches the timing library power connections for the cell.

## **IMPESI-3192**

#### NAME

**IMPESI-3192** 

#### **SUMMARY**

Could not find exact match of the timing model file (.lib) for cell %s of noise library file %s, and timing model library %s will be used for binding.

### **DESCRIPTION**

For proper analysis, make sure there is a one-to-one mapping between timing library and noise library files.

# **IMPESI-3193**

### **NAME**

**IMPESI-3193** 

#### SUMMARY

Could not find exact match between the noise library file, cdB, and the timing library file .lib for the cell %s of cdB %s, and the noise model for this cell will be ignored.

### **DESCRIPTION**

For proper analysis, make sure there is a one-to-one mapping between timing library and noise library files.

#### NAME

IMPESI-3194

#### SUMMARY

Unable to interpolate for instance '%s' (cell: %s) view '%s'. The libraries '%s' %s. Examine your libset and provide libraries to enable interpolation.

### **DESCRIPTION**

The analysis will snap to the library specified in IMPESI-3199 message. For proper analysis, make sure that you provide at least two libraries in the libset with different parameter values.

# **IMPESI-3199**

#### NAME

IMPESI-3199

#### **SUMMARY**

Unable to find proper library binding because there was no exact match and interpolation could not find appropriate libraries for instance '%s' (cell: %s) view '%s'. Using library '%s' for analysis.

### **DESCRIPTION**

Use report\_analysis\_views, report\_power\_domain and report\_instance\_library commands to determine the design and library requirements. Also, check for IMPESI-3194 messages, if any, for interpolation related issues.

#### NAME

IMPESI-3352

### **SUMMARY**

Numerical instability detected on net %s during simulation of noisy transition. This may cause SI delay on this net to be more pessimistic than usual.

### **DESCRIPTION**

A likely reason is poorly characterized timing model.

# **IMPESO-301**

### **NAME**

IMPESO-301

### **SUMMARY**

The %s command requires design data to be loaded.

### **DESCRIPTION**

The command could not be run because design data is not loaded. Load a database or design data.

# **IMPESO-303**

#### NAME

IMPESO-303

#### **SUMMARY**

The Path Based Analysis (PBA) using retime %s is ignored %sbecause the AOCV analysis mode for timing analysis is not set. Configure the AOCV analysis mode by reading in the AOCV libraries, and set it using "set\_db timing\_analysis\_aocv true".

#### **DESCRIPTION**

AOCV based path based analysis (PBA) could not be done because AOCV analysis mode for timing analysis is not set. If you want to do AOCV based PBA analysis, then you need to configure the AOCV analysis mode by reading in AOCV libraries while loading the design, and set the AOCV mode using "set\_db timing\_analysis\_aocv true".

## **IMPESO-306**

#### NAME

IMPESO-306

### **SUMMARY**

Failed to open %s file %s for %s

### DESCRIPTION

A file system error occurred when attempting to open a file. Usually this is because you do not have permission to read or write a file in the current working directory, or have specified a file for read which does not exist.

Example:

Error and Warning Messages

Use the operating system 'Is -I' command to check file permissions. Use the operating system 'chmod' command to change permissions.

The operating system 'df' command can be used to check available space. For example:

innovus 2> df -H

Filesystem Size Used Avail Use% Mounted on

/disk/directory 2.2T 2.0T 271G 88% /mount/mountpoint

## **IMPESO-309**

### **NAME**

IMPESO-309

#### SUMMARY

Error reading/writing file '%s'.

#### **DESCRIPTION**

The command was not able to read or write data from a file. Check available disk space and file permissions.

# **IMPESO-314**

### **NAME**

IMPESO-314

#### **SUMMARY**

Buffer cell '%s' will not be used because timing information for this cell is not available.

#### DESCRIPTION

The reported buffer cell cannot be used because there is no timing information available for it. This is most probably due to missing liberty files (.lib) in the design configuration.

To solve this, you should verify that buffers are part of each active library set inside the viewDefinition.tcl file.

## **IMPESO-317**

#### NAME

IMPESO-317

### **SUMMARY**

The hierarchical instance name '%s' provided in the partition list file is not found in the design.

### **DESCRIPTION**

The partition list file should contain the names of all hierarchical module instances which should be treated as a partition. This error occurs when an entry in the partition list file could not be found in the design. Ensure the names in the file are correct.

# **IMPESO-320**

### **NAME**

IMPESO-320

#### SUMMARY

Cannot create directory '%s': %s.

### **DESCRIPTION**

The current session does not have the write access to create a directory. Check the filesystem permissions for the current directory.

## **IMPESO-338**

#### NAME

IMPESO-338

#### **SUMMARY**

Since number of unique setup and hold (active) views '%d' is greater than '%d', which is the amount of usable CPU set through %s command, some views will be timed sequentially and final summary report will be based on opt\_signoff internal estimated timing.

#### DESCRIPTION

When no ECO Timing DB are provided through the set\_db opt\_signoff\_read\_eco\_opt\_db option, the opt\_signoff command will generate those automatically using the distributed MMMC infrastructure.

In case number of active views is greater than number of available hosts, some views will be timed sequentially, which will result in more runtime but also the final summary report will be based on opt\_signoff internal estimated timing.

To avoid this situation, it is recommended to enable equal or more hosts than the number of active views when relying on opt\_signoff to generate the ECO Timing DB.

#### Example:

Here is an example to enable 6 remote hosts, each one using 4 threads, for timing analysis:

set\_multi\_cpu\_usage -remote\_host 6 -cpu\_per\_remote\_host 4

# **IMPESO-358**

#### NAME

IMPESO-358

### **SUMMARY**

Cell swapping transform requires multiple Vth libraries in the design.

#### **DESCRIPTION**

The tool was not able to detect multiple Vth libraries in this design which is a prerequesite to perform same size cell swapping.

Either you have provided only a single Vth library or all cells from other Vth libraries are set as dont\_touch.

## **IMPESO-366**

#### NAME

IMPESO-366

### **SUMMARY**

set\_opt\_dont\_use commands will be ignored by opt\_signoff.

### **DESCRIPTION**

The opt\_signoff does support set\_dont\_use command in order to enable/disable the usage of a given cell.

The set\_opt\_dont\_use command, is not supported by opt\_signoff.

To avoid this message, make sure that the set\_opt\_dont\_use commands being part of the Innovus DB being loaded, or from your script, are replaced by set\_dont\_use command.

### Example:

To disable usage of BUFX1 cell using set\_dont\_use command:

set\_dont\_use [get\_lib\_cells BUFX1] true

# **IMPESO-389**

#### NAME

IMPESO-389

#### **SUMMARY**

Failed to open %s file %s for %s

### **DESCRIPTION**

A file system error occurred when attempting to open a file. Usually this is because you do not have permission to read or write a file in the current working directory, or have specified a file for read which does not exist.

#### Example:

Use the operating system 'ls -l' command to check file permissions. Use the operating system 'chmod' command to change permissions.

The operating system 'df' command can be used to check available space. For example:

innovus 2> df -H

Filesystem Size Used Avail Use% Mounted on

/disk/directory 2.2T 2.0T 271G 88% /mount/mountpoint

# **IMPESO-396**

#### NAME

IMPFSO-396

Error and Warning Messages

#### **SUMMARY**

max\_tran/max\_cap data is not available for hold only views during timing analysis. This data is required for hold view DRV aware optimization (enabled with option opt\_signoff\_check\_drv\_from\_hold\_views) in TSO. View(s) needs to be specified as both active setup and active hold view during timing analysis to use this feature in TSO.

### DESCRIPTION

To use the feature of hold view aware DRV optimization (enabled with option opt\_signoff\_check\_drv\_from\_hold\_views), ECO Timing DB needs late slews data (max\_tran/max\_cap). This data will be available only when the view is available as setup view as well. You can either specify the view(s) in setup list in current flow or use DMMMC/SMSC flow for ECO Timing DB generation.

## **IMPEXT-1023**

#### NAME

IMPEXT-1023

### **SUMMARY**

Failed to %s file or directory '%s' to '%s'. The system message is '%s'.

### **DESCRIPTION**

This error occurs when a file system operation, such as copy or move, fails. This may be because of inadequate disk space or permission in the file system, such as the current directory or the TMPDIR, where the operation is being performed.

#### NAME

IMPEXT-1024

#### SUMMARY

File system operation %s(%s%s%s) failed. The system message is '%s'.

#### **DESCRIPTION**

This error occurs when a file system operation, such as mkdir or mkstemp, fails. This may be because of inadequate disk space or permission in the file system, such as the current directory or the TMPDIR, where the operation is being performed.

## **IMPEXT-1081**

#### NAME

IMPEXT-1081

#### SUMMARY

set\_db extract\_rc\_effort\_level %s is ignored for pre\_route extraction. This setting is only applicable for post\_route extraction.

#### **DESCRIPTION**

Extraction supports two engine modes, pre\_route and post\_route. These are specified using the engine parameter of the set\_db command. Effort-level selection is not supported in the pre\_route mode. For more information on setting the effort level, see the documentation for the set\_db command.

### NAME

IMPEXT-1197

#### SUMMARY

The '/tmp' directory has been specified for cache/temporary data storage. In distributed processing mode IQuantus expects cache/temporary data directory to be accessible on all hosts used for distributed processing. Therefore the current directory will be used instead of '/tmp'.

#### **DESCRIPTION**

This warning is issued when distributed processing is enabled for IQuantus and FE\_TMPDIR or TMPDIR is set to /tmp. Distributed processing requires that the temporary storage area should be accessible to all hosts. The software will use the current directory instead.

You can specify a directory for temporary storage in any of the following ways, depending on what is available:

\t

1. \t Save in the directory defined by the environment variable, FE TMPDIR.

\t

2. \t Save in the directory defined by the environment variable, TMPDIR.

\t

3. \t Save in the current directory, if it is writeable.

\t

4. \t Save in /tmp.

### NAME

IMPEXT-1221

#### **SUMMARY**

No poly layer found in the technology file '%s'.

### **DESCRIPTION**

No poly layer is found in the technology file. Check to ensure that the correct technology file is specified and check the technology file content.

## **IMPEXT-1222**

### **NAME**

IMPEXT-1222

### **SUMMARY**

No CUT layer defined between the poly LAYER and first routing metal LAYER in LEF technology file '%s'.

### **DESCRIPTION**

The CUT layer between the poly layer and the first routing metal layer is missing in the LEF technology file.

An example of a LEF outline showing CUT layer is as provided below:

\t

LAYER poly
\t\t\t\t
TYPE MASTERSLICE;
\t
END poly
\t
LAYER V0
\t\t\t
TYPE CUT;
\t
END V0
\t
LAYER M1
\t\t\t

# **IMPEXT-1241**

### **NAME**

END V1

\t

IMPEXT-1241

### **SUMMARY**

No poly layer found in the layermap file, '%s'.

### **DESCRIPTION**

Error and Warning Messages

The layer mapping information for the poly layer is missing in the layermap file. This information is required for running extraction. Check the layermap file and rerun extraction.

## **IMPEXT-1245**

#### NAME

IMPEXT-1245

#### SUMMARY

TCL array 'qxHiddenOption' is an internal variable that is provided only for developers.

#### DESCRIPTION

TCL array 'qxHiddenOption' is an internal variable that is provided only for developers. To avoid this message, remove the 'set qxHiddenOption' from your script.

## **IMPEXT-2773**

#### NAME

IMPEXT-2773

#### **SUMMARY**

The via resistance between layers %s and %s could not be determined from the LEF technology file because the via resistance specification is missing. A default of 4 Ohms will be used as via resistance between these layers.

#### **DESCRIPTION**

This warning message is displayed when the capacitance table file is not specified for RC corners during a multi-corner setup and the via resistance between the specified layers is missing in the technology LEF file. In this case, a default of 4 Ohms will be used as via resistance between these

Error and Warning Messages

layers. If capacitance table file is specified for all RC corners using the create\_rc\_corner or update\_rc\_corner command, the software uses RC data from this capacitance table file instead of accessing the LEF data.

# **IMPEXT-2776**

#### NAME

IMPEXT-2776

#### SUMMARY

The via resistance between layers %s and %s is not defined in the capacitance table file. The via resistance of %g Ohms defined in the LEF technology file will be used as via resistance between these layers.

#### DESCRIPTION

This warning message is displayed when the capacitance table file is not specified for RC corners during a multi-corner setup. In this case, the software uses RC data from the LEF file. If capacitance table file is specified for all RC corners using the create\_rc\_corner or update\_rc\_corner command, the software uses RC data from this capacitance table file instead of using the LEF data.

## **IMPEXT-2827**

### **NAME**

IMPEXT-2827

#### **SUMMARY**

Found NONDEFAULT RULE for layer %d having wire width (%d), which is less than the minimum wire width (%d)" "for this layer. This may cause inaccuracy in the extraction results. Check the design for correctness.

Error and Warning Messages

### **DESCRIPTION**

An example of where this error will be reported is shown below. In the default layer definition for M2, the width is 0.07um (1400 db units,) but in the non-default rule the width is 0.06um (1200 db units):

| # Default M2 definition     |
|-----------------------------|
| LAYER M2                    |
| TYPE ROUTING ;              |
| DIRECTION VERTICAL;         |
| WIDTH 0.07 ;                |
|                             |
| END M2                      |
|                             |
| # Non-default rule test_ndr |
| NONDEFAULTRULE test_ndr     |
|                             |
| LAYER M2                    |

Error and Warning Messages

| WIDTH 0.06;  |  |
|--------------|--|
| SPACING 0.7; |  |
| END M2       |  |
|              |  |
| END test_ndr |  |

In this case the non-default rule needs to be corrected so the width is greater than or equal to the default width of 0.07um.

## **IMPEXT-2884**

### **NAME**

IMPEXT-2884

#### **SUMMARY**

An unconnected wire is found at terminal %s of net %s. The wire connectivity of this net is broken because of which the parasitic data for this net may be incomplete.

### **DESCRIPTION**

During RC extraction (extract\_rc) this message indicates the extractor found that the net is not properly connected to this terminal. If check\_connectivity -include\_nets\_file <net\_name> or check\_route reports an open net during RC extraction (extract\_rc), it means that the net is not properly connected. Connect this net, so that extraction is completed.

#### NAME

IMPEXT-2900

#### **SUMMARY**

Unable to find the rc-corner name '%s' in the active rc-corner list specified below. It could be due to an error in syntax, or because the corner is not an active one. To fix this, make sure the correct RC corner is bound to an active delay corner and analysis view.

#### **DESCRIPTION**

The RC corners considered active by the tool would be those which are referenced in at least one active analysis view. Defining an RC corner alone is not enough to activate that RC corner. You may follow the example below on defining an activate an RC corner.

The RC corners considered active are those that are referenced in at least one active analysis view. Defining an RC corner alone is not enough to activate that RC corner. See the example below on how to activate an RC corner.

create rc corner-name rc typ-qx tech file rc typ/qrcTechFile

create constraint mode -name dummyConstraint -sdc files /dev/null

create\_delay\_corner -name dummyDelayCorner -library\_set [lindex [all\_library\_sets] 0] -rc\_corner rc\_typ

create\_analysis\_view -name dummyAnalysisView -constraint\_mode dummyConstraint - delay\_corner dummyDelayCorner

set\_analysis\_view -setup {dummyAnalysisView} -hold {dummyAnalysisView}

#### NAME

IMPEXT-2989

#### SUMMARY

SPEF file reading will not be completed. This is because even though the option to read corner-specific SPEF file(s) has been specified, multi-corner RC extraction is not defined. Please ensure that the MMMC environment is set up and initialized correctly.

### **DESCRIPTION**

The following example creates single-mode two-corner analysis in MMMC setup:

```
create_library_set -name lib_ff \\
\t \t
-timing \\
\t \t
[list /lib/ecsm/std_ff_ecsm.lib \\
\t \t
/lib/essm/macro_ff_ecsm.lib]

create_library_set -name lib_ss \\
\t \t
-timing \\
\t \t
[list /lib/ecsm/std_ss_ecsm.lib \\
\t \t
/lib/essm/macro_ss_ecsm.lib]
```

```
create_rc_corner -name rcworst \/
\t \t
-cap_table rcworst.capTbl
create_rc_corner -name rcbest \\
t \ t
-cap_table rcbest.capTbl
create_delay_corner -name setup_delay \\
t \ t
-library_set lib_ss \\
\t \t
-rc corner rcworst
create_delay_corner -name hold_delay \\
t \ t
-library set lib ff \\
\t \t
-rc corner rcbest
create_constraint_mode -name func \\
t \ t
-sdc files \\
t \ t
[list /lib/SDC/func.tcl]
create_analysis_view -name func_setup -constraint_mode func -delay_corner delay_setup
```

Error and Warning Messages

create\_analysis\_view -name func\_hold -constraint\_mode func -delay\_corner delay\_hold

set\_analysis\_view -setup [list func\_setup] -hold [list func\_hold]

## **IMPEXT-3297**

#### NAME

IMPEXT-3297

#### SUMMARY

The validation check on parasitic database '%s' has failed and cannot be restored. To continue the flow, choose one of the following options: extract the design, load the SPEF file(s), or load a compatible parasitic database.

### **DESCRIPTION**

The validation check on the parasitic database has failed and, therefore, it cannot be restored. The most likely cause of validation failure is an unsupported parasitic database version. The parasitic database generated by the software generally holds good only for one base release and its ISR releases. A compatible parasitic database can be generated using the current version of the software by either extracting the design or loading the SPEF file(s).

## **IMPEXT-3423**

#### **NAME**

IMPEXT-3423

#### SUMMARY

Detected %d nets with incomplete RC network. Low-value resistances have been added by the software to complete the RC network of these nets. Review the list of affected nets in the '%s' file to ensure they are not along the critical path because results of timing analysis performed on nets with incomplete RC network can be inaccurate.

#### **DESCRIPTION**

This warning is displayed when the SPEF file contains incomplete RC network connectivity for some nets. This can also happen if a net occurring before a given net in the SPEF file has a coupling capacitance to a node that is not referenced in the resistance section of the given net. While computing the delay of a net, if the RC network in the SPEF file is incomplete, there will be no resistance path from the driver to the receiver of the net. As a result, the receiver will never switch in simulation and this will result in incorrect delay computation. Therefore, the software adds a low-value resistance to establish a resistance path from the driver to the receiver of the net so that the delay of the net can be computed correctly. To avoid this warning, ensure that the SPEF file has the complete RC network for all the nets.

# **IMPEXT-3493**

#### NAME

IMPFXT-3493

#### SUMMARY

The design extraction status has been reset by set\_analysis\_view/update\_rc\_corner or set\_db command. The parasitic data can be regenerated either by extracting the design using the extract\_rc command or by loading the SPEF or RCDB file(s). To prevent resetting of the extraction status, avoid changing extraction modes.

#### DESCRIPTION

This message is printed when design extraction status is reset because of changes in the extraction mode settings. The parasitic data generated in the previous extraction run is no longer usable. However, the parasitic data will not be deleted if the previous extraction was done using the

Error and Warning Messages

IQuantus extraction engine. In this case, the tool might use the previously extracted database to perform incremental extraction to save on the runtime or it might perform full-chip extraction.

## IMPEXT-3496

#### NAME

IMPEXT-3496

#### **SUMMARY**

The specified options -best, -worst, -typical in 'rda\_Input(ui\_captbl\_file)' of the configuration file for readCapTable are obsolete. For single-mode two-corner analysis and optimization, use MMMC setup instead of reading multiple captables through the readCapTable command. To ensure compatibility with future releases, update the script to use a MMMC viewDefinition.tcl file.

#### DESCRIPTION

The following example creates single-mode two-corner analysis in MMMC setup:

```
create_library_set -name lib_ff \\
\t \t
-timing \\
\t \t
[list /lib/ecsm/std_ff_ecsm.lib \\
\t \t
/lib/essm/macro_ff_ecsm.lib]

create_library_set -name lib_ss \\
\t \t
-timing \\
\t \t
```

```
[list /lib/ecsm/std_ss_ecsm.lib \\
\t \t
/lib/essm/macro ss ecsm.lib]
create_rc_corner -name rcworst \\
\t \t
-cap_table rcworst.capTbl
create_rc_corner -name rcbest \\
\t \t
-cap_table rcbest.capTbl
create_delay_corner -name setup_delay \\
t \ t
-library_set lib_ss \\
\t \t
-rc corner rcworst
create_delay_corner -name hold_delay \\
\t \t
-library_set lib_ff \\
\t \t
-rc_corner rcbest
create_constraint_mode -name func \\
\t
-sdc_files \\
\t \t
```

[list /lib/SDC/func.tcl]

create\_analysis\_view -name func\_setup -constraint\_mode func -delay\_corner delay\_setup

create\_analysis\_view -name func\_hold -constraint\_mode func -delay\_corner delay\_hold

set\_analysis\_view -setup [list func\_setup] -hold [list func\_hold]

## **IMPEXT-3497**

### NAME

IMPEXT-3497

### **SUMMARY**

The options -best or -worst or -typical for readCapTable are obsolete. For single-mode two-corner analysis and optimization, use the MMMC setup instead of reading multiple captables through the readCapTable command. To ensure compatibility with future releases, update the script to use an MMMC viewDefinition.tcl file.

### **DESCRIPTION**

The following example creates a single-mode two-corner analysis in the MMMC setup:

```
create_library_set -name lib_ff \\
\t \t
-timing \\
\t \t
[list /lib/ecsm/std_ff_ecsm.lib \\
\t \t
```

```
/lib/essm/macro_ff_ecsm.lib]
create library set -name lib ss \\
\t \t
-timing \\
\t \t
[list /lib/ecsm/std ss ecsm.lib \\
\t \t
/lib/essm/macro_ss_ecsm.lib]
create_rc_corner -name rcworst \\
t \ t
-cap_table rcworst.capTbl
create_rc_corner -name rcbest \/
t \ t
-cap table rcbest.capTbl
create_delay_corner -name setup_delay \\
\t \t
-library set lib ss \\
\t \t
-rc_corner rcworst
create_delay_corner -name hold_delay \\
\t \t
-library_set lib_ff \\
\t \t
```

Error and Warning Messages

```
-rc_corner rcbest

create_constraint_mode -name func \\
\t\t\
-sdc_files \\
\t\t\
[list /lib/SDC/func.tcl]

create_analysis_view -name func_setup -constraint_mode func -delay_corner delay_setup

create_analysis_view -name func_hold -constraint_mode func -delay_corner delay_hold

set_analysis_view -setup [list func_setup] -hold [list func_hold]
```

## **IMPEXT-3530**

#### NAME

IMPEXT-3530

### **SUMMARY**

The process node is not set. Use the command set\_design\_mode -process cess node> prior to extraction for maximum accuracy and optimal automatic threshold setting.

### DESCRIPTION

Cadence recommends always using set\_design\_mode to specify the process technology. It controls many default settings that are used by implementation and analysis engines within Innovus System. For analysis purposes, the best results depend on using different RC extraction thresholds going from 130nm to 90nm, or from 65nm to 45nm. set\_design\_mode -process recognizes nodes from 10 to 250 (nm), with 90 as the default. Use get\_design\_mode to query the current settings.

The -process setting will influence, for example, set\_db extract\_rc\_engine and extract\_rc\_effort\_level defaults.

## **IMPEXT-3534**

#### NAME

IMPEXT-3534

### **SUMMARY**

A multi-CPU setup has been provided in the tool to use '%d' CPUs, but licenses are only available for '%d' CPUs. Therefore, '%d' CPUs will be used for '%s'. Adjust the option with set multi cpu usage.

### **DESCRIPTION**

To adjust the number of CPUs you want to use in your session:

set \_multi\_cpu\_usage -localCpu 8

Or run the following command for more detail:

innovus > set\_multi\_cpu\_usage -help

## **IMPEXT-3550**

### NAME

IMPEXT-3550

### **SUMMARY**

The command setRCFactor is obsolete because the latest version of the software is using the Multi-Mode Multi-Corner (MMMC) architecture for design import. To ensure compatibility migrate to an MMMC environment and set RC factors using the create\_rc\_corner and update\_rc\_corner commands. For more information on creating MMMC configurations, refer to the "Configuring the Setup for Multi-Mode Multi-Corner Analysis" section in the "Importing and Exporting Designs" chapter in the Innovus System User Guide.

### DESCRIPTION

The following command creates an RC corner called rc-cbest that uses the capacitance table rcbest.capTbl and derates the resistance values based on the temperature of 50 degree Celsius, and sets various factors for pre route and post route:

create\_rc\_corner -name rc-cbest -cap\_table rcbest.capTbl -T 50 \\
-postRoute\_cap 1.06 \\
-postRoute\_clkcap 0.96 \\
-postroute\_clkres 0.95 \\
-postRoute\_res 1.02 \\
-postRoute\_xcap 1.04 \\
-preRoute\_cap 1.03 \\
-preRoute\_clkcap 0.99 \\

Error and Warning Messages

-preRoute clkres 0.97 \\

-preRoute\_res 1.05

The following command changes the capacitance table used by the RC corner rc-cbest to rcbest\_2.capTbl and the temperature by which resistance values are derated to 25 celsius:

update rc corner -name rc-cbest -cap table rcbest 2.capTbl -T 25

## **IMPEXT-3551**

#### NAME

IMPEXT-3551

### **SUMMARY**

The command readCapTable is obsolete because the latest version of the software is using the Multi-Mode/Multi-Corner (MMMC) architecture for design import. To ensure compatibility, migrate to an MMMC environment and set Cap tables using the -cap\_table option of the MMMC commands: create\_rc\_corner and update\_rc\_corner. For more information on creating MMMC configurations, refer to the "Configuring the Setup for Multi-Mode Multi-Corner Analysis" section in the "Importing and Exporting Designs" chapter in Innovus System User Guide.

### **DESCRIPTION**

Some examples of the MMMC commands are provided below:

The following command creates an RC corner called rc-cbest that uses the capacitance table rcbest.capTbl and derates the resistance values based on the temperature of 50 degree Celsius:

create rc corner -name rc-cbest -cap table rcbest.capTbl -T 50

Error and Warning Messages

The following example changes the capacitance table used by the RC corner rc-cbest to rcbest\_2.capTbl and the temperature by which resistance values are derated to 25 degree Celsius:

update\_rc\_corner -name rc-cbest -cap\_table rcbest\_2.capTbl -T 25

## IMPEXT-5036

### **NAME**

IMPEXT-5036

### **SUMMARY**

The '%s' file '%s' is not readable. Either Quantus QRC failed to generate it, or Innovus failed to read it. See Innovus Text Command Reference for set\_db extract\_rc\_qrc\_cmd\_type, correct the command file, and retry extraction.

### DESCRIPTION

The most common cause for this error is: the -directory\_name being specified in the output\_setup section of the command file. Remove the -directory\_name option from the command file.

## **IMPEXT-5064**

### **NAME**

IMPEXT-5064

### **SUMMARY**

Extraction could not be completed. This is because the syntax in the layermap file '%s' is incorrect since it does not use CCL syntax to define the layer mapping (using the extract\_rc\_lef\_tech\_file\_map option). Correct the layermap file to use CCL syntax and run extraction again.

Error and Warning Messages

The format required for extract\_rc\_lef\_tech\_file\_map has changed. The old format was just a list of

## **DESCRIPTION**

| layers like:                                                                                   |
|------------------------------------------------------------------------------------------------|
| PO poly \\                                                                                     |
| CO odcont \\                                                                                   |
| The new format should be in Quantus QRC CCL format and have the following general syntax:      |
| extraction_setup -technology_layer_map \\                                                      |
| <design_layer_name1> <technology_layer_name1> \\</technology_layer_name1></design_layer_name1> |
| <design_layer_name2> <technology_layer_name2></technology_layer_name2></design_layer_name2>    |
| etc                                                                                            |
| Following is an example of the new format:                                                     |
| extraction_setup -technology_layer_map \\                                                      |
| PO poly \\                                                                                     |
| CO odcont \\                                                                                   |
| M1 metal1 \\                                                                                   |

# Innovus Stylus Common UI Error Message Reference Error and Warning Messages

| VIA1 via1 \\ |  |  |
|--------------|--|--|
| M2 metal2 \\ |  |  |
| VIA2 via2 \\ |  |  |
| M3 metal3 \\ |  |  |
| VIA3 via3 \\ |  |  |
| M4 metal4 \\ |  |  |
| VIA4 via4 \\ |  |  |
| M5 metal5 \\ |  |  |
| VIA5 via5 \\ |  |  |
| M6 metal6 \\ |  |  |
| VIA6 via6 \\ |  |  |
| M7 metal7 \\ |  |  |
| VIA7 via7 \\ |  |  |
| M8 metal8    |  |  |

Use the extract\_rc\_lef\_tech\_file\_map option to point to the file.

## **IMPEXT-6013**

### NAME

IMPEXT-6013

### **SUMMARY**

There is a gap or overlap between layer '%s' (h=%g t=%g) and layer '%s' (h=%g t=%g) in the ICT file.

### **DESCRIPTION**

The following example shows properly defined ICT file.

```
dielectric "dielectric_0" {
\t
conformal FALSE
\t
height 0.000000
\t
thickness 0.500000
\t
dielectric_constant 3.900000
}

dielectric "dielectric_1" {
\t
```

Error and Warning Messages

```
conformal FALSE
\t
height 0.500000
thickness 0.600000
dielectric_constant 4.200000
}
dielectric "dielectric_2" {
\t
conformal FALSE
\t
height 1.100000
\t
thickness 0.050000
\t
dielectric_constant 8.100000
}
Notice above that:
height + thickness of dielectric_0 = height of dielectric_1
And:
```

Error and Warning Messages

height + thickness of dielectric 1 = height of dielectric 2

If the dielectric layer height and thicknesses do not meet this requirement, then there is an overlap or gap between the layers and this error is reported.

## **IMPEXT-6089**

### NAME

IMPEXT-6089

### **SUMMARY**

The processing layer '%s': delta\_layer '%s' has not been defined. The ICT file needs to be modified. Ensure that the ICT files are ordered so that the lowest layers are defined first, followed by higher layers. For example, POLY is defined before MET1. Call write\_cap\_table again.

### DESCRIPTION

For example, the write\_cap\_table command would give a syntax error when processing the following ICT file containing the delta layer construct:

```
conductor "MET1" {

min_spacing 0.30

min_width 0.30

delta_layer POLY <== Not Yet Defined

delta_height 0.30
```

```
conductor "POLY" {

min_spacing 0.25

min_width 0.16

height 0.35

upto 0.55

resistivity 8.6

gate_forming_layer true

}
```

## **IMPEXT-6159**

### NAME

IMPEXT-6159

### **SUMMARY**

The annotated parasitics can not be reported because the command report\_annotated\_parasitics is issued before the design is loaded. Load the design before issuing report\_annotated\_parasitics.

### **DESCRIPTION**

Error and Warning Messages

Load the design with either read\_db (or read\_design in Tempus) or init\_design and the parasitic data with one of the following: extract\_rc (or extract\_rc in tempus), read\_spef (or read\_spef in Tempus), and read\_parasitics, before issuing report\_annotated\_parasitics.

The following example loads a design from the test.imp.dat directory and reads the parasitic data into the Innovus session:

read\_db test.imp.dat TOP

read\_parasitics -rc\_corner C1 TOP\_C1ef.gz -rc\_corner C2 TOP\_C2ef

report\_annotated\_parasitics -list\_annotated -list\_not\_annotated -list\_real\_net -list\_float\_net - list\_nodriver\_net -list\_noload\_net -max\_missing 3

## **IMPEXT-6166**

#### NAME

IMPEXT-6166

### **SUMMARY**

Capacitance table file(s) without the EXTENDED section is being used for RC extraction. This is not recommended because it results in lower accuracy for clock nets in pre\_route extraction and for all nets in post\_route extraction using extract\_rc\_effort\_level low. Regenerate capacitance table file(s) using the write\_cap\_table command.

#### DESCRIPTION

To run the write cap table command with Multi-CPU, specify the following commands:

set\_distribute\_host -local

Error and Warning Messages

set multi cpu usage -localCpu 4

write\_cap\_table -ict sample.ict -output sample.capTbl

## **IMPEXT-6189**

#### NAME

IMPEXT-6189

### SUMMARY

Initialization for preRoute extraction mode using the technology file is being terminated since the technology file '%s' could not be read. This is because it is either an invalid file or an error occurred in importing it. Check the file and read it in again using create\_rc\_corner or update\_rc\_corner - qx\_tech\_file.

### DESCRIPTION

The technology file (.tch) is generated by TechGen, a built-in functionality of Quantus. Users get it either directly from foundries, or can generate it themselves from an ICT file (an ASCII-format Interconnect Technology input file) using TechGen.

## **IMPEXT-6191**

### **NAME**

IMPEXT-6191

### SUMMARY

Using a captable file is not recommended for process nodes less than or equal to %d nm due to parasitic accuracy concerns. The Quantus QRC technology file should be specified for all RC corners using the command create\_rc\_corner or update\_rc\_corner, which will then be used for pre\_route and post\_route(effort level medium or high or signoff) extraction engines.

Error and Warning Messages

### DESCRIPTION

For more information, see the "RC Extraction > PreRoute Extraction Flow without Capacitance Table data" User Guide.

## **IMPEXT-6195**

#### NAME

IMPEXT-6195

### SUMMARY

The low effort level for post\_route extraction mode will be ignored because it is not allowed for the current multi-corner setup. This is because either flow is without a cap table, or the design process node is less than or equal to 32 nm and cap tables are not specified for all the active RC corners. To avoid this, switch to extract\_rc\_effort\_level medium or high or signoff, if Quantus QRC techfile(s) are available.

### DESCRIPTION

For more information, see the "RC Extraction > PreRoute Extraction Flow without Capacitance Table data" User Guide.

## **IMPEXT-6197**

#### NAME

IMPEXT-6197

#### SUMMARY

The Cap table file is not specified. This will result in lower parasitic accuracy when using pre\_route extraction or post\_route extraction with effort level 'low'. It is recommended to generate the Cap table file using the 'write\_cap\_table' command and specify it before extraction using 'create rc corner/update rc corner -cap table'.

Error and Warning Messages

### DESCRIPTION

If Cap table file is not available, user can generate it using 'write\_cap\_table –ict [-lef]'. For pre\_route extraction on 32nm and below designs, or post\_route extraction under 65nm, Quantus QRC technology files are more accurate than the Cap table. User can specify them with 'create\_rc\_corner or update\_rc\_corner -qx\_tech\_file' if Quantus QRC technology files are available. For post\_route extraction with available Quantus QRC tech files the 'set\_db extract\_rc\_effort\_level' should then be updated to 'medium or high or signoff'.

## **IMPEXT-6198**

#### NAME

IMPEXT-6198

### **SUMMARY**

Extraction will not take place because the technology file is not specified for all RC corners. Technology files are needed for pre\_route extraction and effort level medium or high or signoff of post\_route extraction when the process node set using set set\_design\_mode -process is less than or equal to %d nm. Use the commands create\_rc\_corner or update\_rc\_corner to specify the technology file for all corners and run the extraction again.

### **DESCRIPTION**

In MMMC based flow, the qrcTechFile is strongly recommended for pre\_route and post\_route RC extraction in process nodes of 32nm and lower, because of the increased accuracy that is necessary at these nodes.

For further detail, see Innovus Digital Implementation System User Guide: "RC Extraction" > "PreRoute Extraction Flow without Capacitance Table Data.

## **IMPEXT-6202**

### NAME

IMPEXT-6202

#### **SUMMARY**

In addition to the technology file, the capacitance table file is specified for all the RC corners. If the technology file is already specified for all the RC corners, the capacitance table file is not required for pre\_route and post\_route extraction. In a new session, the capacitance table files can be removed from the create\_rc\_corner command to enable the technology file to be used for pre\_route and post\_route (effort level medium/high/signoff) extraction engines.

### DESCRIPTION

This warning message is displayed when the process node set using set\_design\_mode is greater than 32nm and both technology and captable files are specified for all the RC corners. Using this setup, the captable file would be used for pre\_route extraction. However, to enable pre\_route extraction using the technology file, remove the captable file specification from create\_rc\_corner in a new session. This would change the default value of the effort level for post\_route extraction to medium, and the low effort level would not be allowed.

## **IMPEXT-7036**

### NAME

IMPEXT-7036

### **SUMMARY**

The system call %s failed because of %s. Rerun the command or contact the Cadence support team for information.

### **DESCRIPTION**

This is a system error for which some possible reasons could be; too many processes running on the system, insufficient memory available to create a child process, or the system call interrupted by a signal.

## **IMPFM-205**

#### NAME

IMPFM-205

### **SUMMARY**

Model %s does not exist.

### **DESCRIPTION**

The specified model name does not exist in the current loaded design. Model name should be a logical module name in the netlist or an instance group name in the design. Double check the model name and re-specify it again.

#### Example:

<CMD> set proto mode -identify exclude module {tdsp coore}

\*\*WARN: (IMPFM-205): Module tdsp\_coore does not exist.

<CMD> set\_proto\_mode -idenitfy\_exclude\_module {tdsp\_core}

## **IMPFM-206**

### **NAME**

IMPFM-206

### **SUMMARY**

Module %s and module %s are exclusive. Both cannot be specified as flexmodels and/or black boxes.

### DESCRIPTION

Currently Innovus cannot support nested FlexModels. If a module is already being specified as FlexModel, its parent or children module cannot be specified as FlexModel again. Innovus issued the ERROR message IMPFM-206 for the specified modules where only one of them can be specified as FlexModel.

## **IMPFM-226**

### NAME

IMPFM-226

### SUMMARY

Module %s cannot be a partition, In Innovus FlexModel technology you cannot have a flexmodel as a partition.

### DESCRIPTION

In Innovus FlexModel technology you cannot have a flexmodel as a partition, the above message is indicating that.

Innovus will not have any errors during creation of %s as a flexmodel even though its declared as a partition in the original netlist.

However, if you load the design back after creating the flex models this errors appears.

Now, below is solution that you can trick Innovus to have a flex model as a partition:

SOLUTION after you hit this error:

#Save out a current floorplan for future use:

<CMD> write floorplan current Floopplan.fp

#Delete all existing Partitions.

<CMD> delete partitions -all

## Restore the protomodels again

<CMD> source DBS/\$DESIGN/\$Name.protomodels

Error and Warning Messages

## Read the previously saved floorplan to restore partitions

<CMD> read\_floorplan current\_Floopplan.fp

Now you should not see the above error.

## **IMPFM-235**

### NAME

IMPFM-235

### **SUMMARY**

This design has less than 1M instances. It is recommend to use FlexModel for a design that has more than 1M instances since netlist reduction ratio may not be good for small FlexModels.

### **DESCRIPTION**

It is recommended to use FlexModel for a large design that has more than 1 million instances to see the real benefit of it. Since the design size is small, netlist reduction ratio may not be good for this design.

## **IMPFM-318**

### NAME

IMPFM-318

### **SUMMARY**

Model '%s' does not exist.

### **DESCRIPTION**

Specified model does not exist in the current loaded design. Model can be a module or an instance

Error and Warning Messages

group in the design. Double check the model name and re-run the command again.

## **IMPFM-333**

### **NAME**

IMPFM-333

### **SUMMARY**

Option %s for command %s is obsolete and will be removed in future releases. Use %s instead.

### DESCRIPTION

Specified option of the given command is obsolete and will be removed in future release. Use the new replaced command and/or update your run script to avoid warning message.

## **IMPFM-334**

### **NAME**

IMPFM-334

### **SUMMARY**

Option %s of the command %s is obsolete and will be removed in future releases.

### **DESCRIPTION**

Specified option of the given command is obsolete and will no longer be available in future release. Do not use this option and/or remove it from your run script to avoid this warning message.

## **IMPFM-353**

### NAME

IMPFM-353

### **SUMMARY**

Model %s's standard cells and macros have a combined area of %7.2f, which is greater than specified value %7.2f for -create total area.

### **DESCRIPTION**

Total area of standard cells and macros in the current netlist of the model is greater than specified value of the -create\_total\_area option. Innovus will use the user-specified value instead. If this is not the intention, re-specify the total area for the model with create\_proto\_model -create\_total\_area.

#### Example:

<CMD> set\_proto\_model -model tdsp\_core -create\_total\_area 10

\*\*WARN: (IMPFM-353): Model tdsp\_core's standard cells and macros have a combined area of 7753.67, which is greater than specified value 10.00 for -create\_total\_area.

<CMD> set\_proto\_model -model tdsp\_core -create\_total\_are 9000.0

## **IMPFM-706**

### **NAME**

IMPFM-706

### **SUMMARY**

Model %s has been generated.

### **DESCRIPTION**

Error and Warning Messages

create\_proto\_model outputs this warning message if the specified model already had been generated from previous run and was saved in the prototyping model directory specified by the -create\_dir option of the set\_proto\_mode command. Innovus will reuse this model and will not regenerate it to save time. If model needs to be re-generated, either following choice can be used:

- 1. Remove existing prototyping model directory and rerun create\_proto\_model again.
- 2. Overwrite existing model by running create proto model with -overwrite and -model options.

## **IMPFM-709**

### NAME

IMPFM-709

### SUMMARY

Model %s is incomplete. Re-generate the model.

#### DESCRIPTION

create\_proto\_model outputs this warning message if the specified model had been generated but not incomplete from previous run. The command will re-generate this model again. This is for information only.

## **IMPFM-725**

### **NAME**

IMPFM-725

#### SUMMARY

Command %s is obsolete and will be removed in future releases. Please use %s instead.

### DESCRIPTION

Specified command is obsolete in the current release and will not be available in future release. Use the new replaced command and update your run script if needed to avoid warning message.

## **IMPFM-730**

#### NAME

**IMPFM-730** 

### SUMMARY

Model %s already has physical constraint so it cannot be converted to soft guide. Unplace the model and rerun the command again.

#### DESCRIPTION

Specified FlexModel currently already has guide/fence/region boundary. In order to convert this FlexModel to a soft guide which does not have any physical constraint, unplace the model by manually moving it outside the core area or using the unplaceGuide command. Once the model is unplaced, rerun the set\_proto\_model\_physical\_constraint command again.

#### Example:

set\_proto\_model\_physical\_constraint -model spi -type soft\_guide

\*\*WARN: (IMPFM-730): Model SPI\_INST already has physical constraint so it cannot be converted to soft guide. Unplace the model and rerun the command again.

unplaceGuide SPI\_INST

set\_proto\_model\_physical\_constraint -model spi -type soft\_guide

## **IMPFM-735**

### NAME

IMPFM-735

### SUMMARY

Model %s does not have physical constraint so it cannot be converted to %s. Place the model and rerun the command again.

### DESCRIPTION

Specified model cannot be converted to guide/fence/region since the model does not have any physical constraint. Move the model inside the core area and rerun the set proto model physical constraint command again.

#### Example:

set\_floorplan\_rects Module cORE/test\_wrapper 12554.1900 15037.5500 13499.3250 15659.8000 set\_proto\_model\_physical\_constraint -model test\_wrp -type fence

## **IMPFM-759**

### NAME

IMPFM-759

### **SUMMARY**

create\_proto\_model currently cannot handle a design that has both module and instance group based FlexModels. Only module based models will be created with this run.

### **DESCRIPTION**

Innovus supports both module and instance group based FlexModels. However create\_proto\_model currently does not create models for both modules and instance groups within one run. create\_proto\_model will only create module based FlexModels for this run. To work around this limitation, do two create\_proto\_model runs:

- 1. Specify instance group based models first and run create\_proto\_model for instance groups.
- 2. Specify module based FlexModels and then run second create\_proto\_model to generate models for modules.

## **IMPFM-760**

### NAME

IMPFM-760

#### **SUMMARY**

The design has no flexmodel, please specify plan\_design seeds in a constraint file and do proto\_design -constraint\_file.

### DESCRIPTION

Example:

<CMD> proto design -constraints constraint file name

## **IMPFM-761**

### **NAME**

IMPFM-761

### SUMMARY

Routing blockage characterization currently does not support a design that has both module and instance group based FlexModels. FlexFiller routing blockages will only be created for module based FlexModels.

### **DESCRIPTION**

FlexFiller routing blockage characterization cannot handle a design that has both module and instance group based FlexModels. To work around this limitation use following flow:

- 1. Specify instance group based FlexModels only.
- 2. Run create\_proto\_model to create models for specified instance groups.

Error and Warning Messages

- 3. Run routing blockage characterization for these instance group based FlexModels. Only run this step if ART based model generation is used.
- 4. Specify module based Flexmodels
- 5. Run create proto model to crete models for the modules
- 6. Run routing blockage characterization for these module based FlexModels. Only run this step if ART based model generation is used.

## **IMPFM-790**

### **NAME**

IMPFM-790

#### SUMMARY

Cannot load FlexFiller route blockage since FlexFiller routing layers specified in file %s is '%d' which is not consistent with the current available routing layer number '%d'.

### DESCRIPTION

routeBlkg.model file is created by the command create\_flexfiller\_route\_blockage. The most likely reason for the error is that you set different routing layer when doing create\_flexfiller\_route\_blockage and restoring FlexModel design. you can run mib::getMinNumMaxRouteLayerWireLayer to get available routing layer number. The solution is that you need redo create\_flexfiller\_route\_blockage. If you do not want to model Flexfiller route blockage, you can safely ignore the error.

## **IMPFM-1206**

### NAME

IMPFM-1206

Error and Warning Messages

### SUMMARY

Design has net(s) without routing. Best\_layer\_no\_detour will be used for calculating delay for unrouted net(s).

### **DESCRIPTION**

Current design contains nets that have partial or no routing. Prototyping timing analysis tool(time\_design -prototype) will calculate net delays for these net using Manhattan route with best routing layers. To obtain net delays for all nets in the design based on routing information, re-route the design and timing the design again.

## IMPFM-1304

### NAME

IMPFM-1304

### SUMMARY

The design is not portable and power intent will not be updated.

### **DESCRIPTION**

If you really want to update power intent data, please save the design as a portable design, and do createLogicHierarchy on the design.

## IMPFP-40

#### NAME

IMPFP-40

Error and Warning Messages

### **SUMMARY**

Cannot support data '%s' for '%s'. The data may be generated from new version of software which is not compatible with current version. Check the data or change the software version.

### **DESCRIPTION**

Cannot support data '%s' for '%s'. The data may be generated from new version of software which is not compatible with current version. Check the data or change the software version.

## **IMPFP-104**

### NAME

IMPFP-104

### **SUMMARY**

Cannot open %s. You may not have permission read a file or the file simply does not exist. Check the file name or contact administrator.

### **DESCRIPTION**

The message occurs because you may not have permission read a file or the file simply does not exist.

## **IMPFP-172**

### **NAME**

IMPFP-172

### **SUMMARY**

Row '%s' cannot accommodate all pad cells, needs %d sites > %d row sites. The create\_floorplan needs to be enlarged to place the pads legally in the IO rows.set\_io\_flow\_flag 0 to disable the IO row flow and avoid this message.

### DESCRIPTION

If set\_io\_flow\_flag is 1 when loading a design, a check is run to verify the IO rows can accommodate the pads in the design. This warning indicates there are more pad cells than the IO rows can accommodate so the create\_floorplan needs to be enlarged. Run check\_place to report overlapping pads and look for pads placed outside the IO rows. If you want to avoid this message disable the IO row flow by setting set\_io\_flow\_flag 0 prior to loading the design.

## **IMPFP-175**

### NAME

IMPFP-175

### SUMMARY

No IO rows in design. Use command "get\_io\_flow\_flag" to get the current IO flow(with or without row). To avoid this error message, Use command "set\_io\_flow\_flag" to change the IO flow.

### DESCRIPTION

Innovus issues above error message on restoring the saved design. Though, I have no IO cells defined in my Verilog netlist and I am not reading in any IO cells in my libraries. Why does Innovus issue this error message? init\_design or read\_def issues this error message if IO rows are not defined in the design and below option is set to 1 in the globals file: set conf\_use\_io\_row\_flow 1 This variable is set to 1 for IO Row Flow in Innovus.

## **IMPFP-247**

### NAME

IMPFP-247

### **SUMMARY**

Cannot create non-integral multiple height row. There is no site to generate rows inside the power domain. Check it has a SITE that is common to all the cells in the power domain.

### **DESCRIPTION**

This warning is issued by create\_row command when user tries to create standard cell row which is non-integral height of existing row's or default row. Highly recommend user to use a?? initCoreRowa?? for power domain/whole chip row creating, which fetch row setting from CPF. User even dona??t need specify tech site, just one command without option.

### **IMPFP-298**

### **NAME**

IMPFP-298

### **SUMMARY**

Floorplan cannot be resized due to insufficient X spacing or illegal resize line. Edit create\_floorplan to make room in X direction or re-specify resize line and re-run.

### **DESCRIPTION**

Floorplan cannot be resized due to insufficient X spacing or illegal resize line. Edit create\_floorplan to make room in X direction or re-specify resize line and re-run. This error is likely to occur, if user has not specified the "set\_db & set\_resize\_line" options correctly.

Example:

Error and Warning Messages

Floorplan cannot be resized due to insufficient X spacing or illegal resize line. Edit create\_floorplan to make room in X direction or re-specify resize line and re-run. This error is likely to occur, if user has not specified the "set\_db & set\_resize\_line" options correctly. For example to increase create\_floorplan in vertical direction, resizeLine must have the same x coordinate. For eg set\_resize\_line -direction V (-63 798) (-63 3878)

## **IMPFP-316**

#### **NAME**

IMPFP-316

#### SUMMARY

Not enough space for create\_floorplan resize. No change for create\_floorplan.

### **DESCRIPTION**

One of the possible reason for this warning could be that the Fplan\_box and the Fplan\_corebox areas are same. Try maintaining some difference among two will resolve the warning.

## **IMPFP-320**

### **NAME**

IMPFP-320

### **SUMMARY**

The resize value needs at least bigger than one micron.

Error and Warning Messages

### DESCRIPTION

The message is reported by resize\_floorplan when user tried to resize create\_floorplan with less than one micron.

Example:

resize floorplan -xSize -0.9 -ySize -0.9

## **IMPFP-701**

### NAME

IMPFP-701

### **SUMMARY**

The Design Boundary's lower left corner not on manufacture grid. The boundary must be on manufacture grid. Check the definition of manufacture grid. Check the definition of manufacture grid in the tech LEF/OA or re-specify create floorplan.

### **DESCRIPTION**

The Design Boundary's lower left corner not on manufacture grid. The boundary must be on manufacture grid. Check the definition of manufacture grid. Check the definition of manufacture grid in the tech LEF/OA or re-specify create\_floorplan.

## **IMPFP-704**

### **NAME**

IMPFP-704

### **SUMMARY**

IO box's upper right corner not on manufacture grid. IO box must be on manufacture grid. Check the definition of manufacture grid or re-specify create floorplan.

### DESCRIPTION

IO box's upper right corner not on manufacture grid. IO box must be on manufacture grid. Check the definition of manufacture grid or re-specify create floorplan.

## **IMPFP-788**

#### NAME

IMPFP-788

### SUMMARY

Cell '%s' for IO '%s' has LEF/OA CLASS other than PAD or sub class Areal0.

### **DESCRIPTION**

If a customer is using OA libraries instead of LEF, they are confused by the wording of the ERROR message. The message should automatically change to say OA instead of LEF if Innovus was started with OA libraries. If this is not possible at this time, then the ERROR message should say LEF/OA libraries and not just LEF.

### Example:

Cell '%s' for IO '%s' has LEF CLASS other than PAD or sub class Areal0.

or when starting Innovus with OA libraries:

Cell '%s' for IO '%s' has OA CLASS other than PAD or sub class Areal0.

or

Cell '%s' for IO '%s' has LEF/OA CLASS other than PAD or sub class Areal0.

## **IMPFP-793**

#### NAME

IMPFP-793

## **SUMMARY**

IO cell '%s' doesn't overlap any IO row to snap to. When use IO row flow, tool will automatically check that if IO pads and IO rows are matching. Recreate IO rows and then try to snap IO cell on the row.

### **DESCRIPTION**

This warning message will be generated if you choose the IO row flow for pad placement (set\_io\_flow\_flag 1). When you use the IO row flow, tool will automatically check that if IO pads and IO rows are matching. These messages just warn you that there is some mismatches in the IO row flow. If you want to make the warning message disappear, please recreate IO rows and use write\_def then read\_def to check. Else, you can ignore them or you can go with normal flow without IO rows.set\_io\_flow\_flag 0 #this will prompt to use the normal IO flow. Also, check for "setUserDataValue conf\_use\_io\_row\_flow 1" in the .globals file. If the value of this variable is set to 1, then change this to 0 to avoid these warnings.

# **IMPFP-903**

## **NAME**

IMPFP-903

## **SUMMARY**

Bump %s is assigned to net %s. Not deleted.

## **DESCRIPTION**

The specified bump cannot be deleted because a top level net is assigned to it. The net assignment must first be removed in order to delete the bump. The net assignment can be removed using either the unassign\_bumps or unassign\_bumps -byBumpName commands.

## Example:

The following commands will select a bump named "98", unassign its net and

delete it.

select bumps -bumps {98}

unassign\_bumps -selected delete bumps -selected

# **IMPFP-905**

## NAME

IMPFP-905

## **SUMMARY**

Constraints of HInst %s is out of die. Cannot output it to create\_floorplan file.

## **DESCRIPTION**

This message occurs when write\_floorplan or write\_db tries to save floorplan file but instance are placed outside of die area.

# **IMPFP-1594**

### NAME

IMPFP-1594

## **SUMMARY**

No site specified. Check the LEF/OA file to make sure a site is specified for core cell.

## **DESCRIPTION**

All designs require at least one core site to create rows with even if the design only contain hard blocks. So the user needs to load the tech LEF/OA which has SITE defined in it even if the blocks don't use the SITE

Example:

Error and Warning Messages

| For example :       |
|---------------------|
| SITE site1          |
| SYMMETRY y ;        |
| CLASS core;         |
| SIZE 0.660 BY 5.040 |
| END site1           |

# **IMPFP-1871**

## **NAME**

IMPFP-1871

## **SUMMARY**

Failed to run the command because it attempts to change the top cell bounding box. Use the 'create floorplan' command to modify top cell bounding box first before calling this command.

## **DESCRIPTION**

When a user creates a floorplan let's say 100 by 100 and snapping to grid is enabled, the tool will automatically snap the FP to the grid and the FP will end up to be 99.987 by 99.95. Next, when the user wants to run a command like set\_floorplan\_rects (or several other command) with the original Fplan coordinates, the toll will complain that this is an attempts to change the top cell bounding box. This is true, because 100 is basically outside of the post-snapping bounding box (which is let's say 99.987). Either the user can turn off the auto-snap when creating the FP, do the operations he wants, then use snap\_floorplan to snap the FP to grid, or he must use the coordinates stored in the DB after autosnap of the FP.

# **IMPFP-2101**

## **NAME**

IMPFP-2101

## SUMMARY

Shifter for %s to %s is not defined in shifter table.

## **DESCRIPTION**

Shifter for %s to %s is not defined.

It may be due to no shifter defined in CPF file or no standard cell found in the power domain.

### Example:

\*\*WARN: (IMPFP-2101): Shifter for \_internal\_VDD\_SOC\_VSS\_ to PD\_PD\_AVE\_CCH is not defined in shifter table.

\_internal\_VDD\_SOC\_VSS\_ is an empty power domain created automatically by default. There is no shifter defined for this internal power domain.

# **IMPFP-3101**

## **NAME**

IMPFP-3101

## SUMMARY

Skip don't touch net '%s'. When insert shifter for floating net & undriven net, the don't touch net should be ignored.

## DESCRIPTION

In the design there were many ports that had been assigned as set\_dont\_touch. These ports were assigned to nets of the same name in the design. Based on the fact that these are dont\_touch nets in the design, Innovus System will not insert logic onto those nets, even if they are suggested as necessary by the CPF for the design. With the SDC and CPF in conflict, Innovus System honors the SDC that the net should not be changed and gave the above warning.

## Example:

The user should confirm that the ports/nets labeled as dont touch should indeed

need to be dont\_touch. And if it is necessary to create buffering, level shifting, or isolation on those ports/nets, then the setting the port/net as dont\_touch in SDC should be removed.

# **IMPFP-3302**

### NAME

IMPFP-3302

## SUMMARY

Rows for site '%s' cannot be created. The height of this site is non-integer multiple of default row type. Non-integer multiple-height rows and single height rows cannot overlap. Edit the library set to modify the default row type or remove the library.

## **DESCRIPTION**

This message reports the error situation about Non-integer multiple-height rows. Edit the library set to modify the default row type or remove the library to resolve this issue.

# **IMPFP-3356**

## NAME

IMPFP-3356

## **SUMMARY**

IO Inst %s is outside of design boundary. All placed IO instances must be located inside the design boundary. Move IO instance to a location within the design boundary.

## **DESCRIPTION**

Error and Warning Messages

The above error is reported when restoring the design. Why is this error reported and how can I avoid it?

This error indicates there are instances placed outside the design boundary. All instances with placement status of placed, fixed or cover need to be placed within the design boundary. To resolve this:

Place all cells currently placed outside the design boundary within the boundary. If these cells are physical only cells (i.e. filler cells, decap cells, etc.) you can delete them from the database.

### Example:

The following script can be used to delete and report all cells outside the design boundary.

```
redirect { puts "" } > CellOutsideBoundary.txt
set x1 [lindex [lindex [get db current design .bbox] 0] 0]
set y1 [lindex [lindex [get db current design .bbox] 0] 1]
set x2 [lindex [lindex [get db current design .bbox] 0] 2]
set y2 [lindex [lindex [get db current design .bbox] 0] 3]
set num 0
deselect all
select inst *
foreach inst [get db selected] {
set box [get db $inst.box]
set lx [lindex [lindex $box 0] 0]
set ly [lindex [lindex $box 0] 1]
set ux [lindex [lindex $box 0] 2]
set uy [lindex [lindex $box 0] 3]
if { [expr $lx < $x1] || [expr $ly < $y1] || [expr $ux > $x2] || \
[expr $uy > $y2]  {
redirect { puts [get_db $inst.name] } >> CellOutsideBoundary.txt
delete inst [get db $inst.name]
```

Error and Warning Messages

Please note that after Innovus 13.1 is is OK to have a COVER type macro which is partially outside the prBoundary.

# **IMPFP-3361**

## NAME

IMPFP-3361

## **SUMMARY**

The Cell %s has already set padding %d. Specify it again will overlap the original padding. Use report\_cell\_padding command to query and check.

## **DESCRIPTION**

This warning message is issued when the user tries to add cell padding again to a library cell which already has a cell padding defined. User can run reportCellPad command to report out previously defined cell padding to confirm.

# **IMPFP-3388**

### NAME

IMPFP-3388

## SUMMARY

Block instance %s not found.

## DESCRIPTION

This message is issued when loadFPlan could not find the corresponding Block instance accroding to the block name.

# **IMPFP-3761**

### NAME

**IMPFP-3761** 

## SUMMARY

The resolveSdpOverlap command is obsolete.

## **DESCRIPTION**

The command 'resolvSdpOverlap' is no longer supported. Please update your scripts to use 'set\_db' and 'place\_sdp\_groups' instead.

### Example:

The following command disables extension of the core boundary if the boundary cannot accommodate all SDP placements:

set\_db -place\_sdp\_disable\_extend\_core true

The following commands place elements or instances of all defined SDP

groups and generate a detailed SDP placement report named

dtmf\_chip.sdp.rpt:

set db place sdp place report dtmf chip.sdp.rpt

place sdp groups

### NAME

IMPFP-3780

## **SUMMARY**

Only orthogonal edges are allowed in blockage polygons. One or more edges is an odd-angle edge, including this one: {x1 y1} {x2 y2}. You must fix the polygon to only use orthogonal edges.

### **DESCRIPTION**

Creates a routing blockage object that can be moved even outside the core area. The object area prevents routing of specified metal layers, signal routes, and hierarchical instances in this area. Currently only orthogonal edges are supported by this command. You must use DEF directly if you need to create a blockage with 45-degree edges. Use this command during partition floorplanning.

# **IMPFP-3803**

## **NAME**

IMPFP-3803

## **SUMMARY**

Command "%s" is obsolete and has been replaced by "%s". The obsolete command still works in this release, but to avoid this warning and to ensure compatibility with future releases, update your script to use "%s".

## **DESCRIPTION**

There is a change from Innovus '%s' release onwards. "%s" command is obsolete and has been replaced by "%s" command.

## Example:

\*\*WARN: (IMPFP-3803): Command "createObstruct" is obsolete and has been replaced by "create place blockage".

Use below 2 commands for this purpose:

set\_db a??selectiveBlockage true

create place blockage a??type soft {-box {x1 y1 x2 y2 } | -polygon {{x1 y1 } {x2

y2 }...} | -boxList {{llx1 lly1 urx1 ury1} {llx2 lly2 ...}}

However, this option allows not only all buffers and inverters but also

isolation cells and level shifters. If user wants to limit the size, type of

cells or even instances that are allowed in the area, one more command can be

used:

reset\_selective\_blockage\_gate

[-help]

[-cells cellName]

[-insts instName]

In addition, other types of cells or instances can be allowed through the

following command:

set selective blockage gate

[-help]

[-cells cellName]

[-insts instName]

This last 2 commands work when set db place detail selective blockage is set to true.

# **IMPFP-3823**

### NAME

IMPFP-3823

## **SUMMARY**

Cannot find routing blockage with name: %s.

## DESCRIPTION

You have this message because the routing blockage with the specified name does not exist. Please check your naming in your command options.

# **IMPFP-3824**

## NAME

IMPFP-3824

## **SUMMARY**

Cannot find place blockage with name: %s.

## DESCRIPTION

You have this message because the placement blockage with the specified name does not exist. Please check your naming in your command options.

# **IMPFP-3825**

## NAME

IMPFP-3825

## SUMMARY

Cannot find place blockage with name: %s and type: %s. Check your naming in the command options and make sure a valid blockage type(hard, soft, or partial) is given.

## DESCRIPTION

You have this message because the placement blockage with the specified name and type does not exist. Please check your naming in your command options and make sure a valid blockage type(hard, soft, or partial) is given.

# **IMPFP-3881**

## NAME

IMPFP-3881

## **SUMMARY**

IO box is not equal to die box, which is not allowed in a block design.

## **DESCRIPTION**

This message is issued when the IO box is not equal to the die box in a block design. Modify the boxes to be the same to resolve this issue.

Related commands: floorPlan

# **IMPFP-3929**

### NAME

IMPFP-3929

## **SUMMARY**

The symmetry of instance '%s' does not allow the rotation or flipping as requested. symmetryX must be true to allow flipping about the X-axis, symmetryY must be true to flip about the Y-axis, and symmetryR90 to allow rotation. Check current cell symmetry with 'get\_db base\_cells <cellName>.\*'.

Error and Warning Messages

## DESCRIPTION

{The symmetry is wrong and you need to update the library cell data to fix it permanently (LEF SYMMETRY statement). You can also change it with db\_set in the current session if you want to continue without reloading the libraries and design.}

# **IMPFP-3941**

### NAME

IMPFP-3941

## **SUMMARY**

PreRoute (%f %f) (%f %f) not on manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## DESCRIPTION

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid.

# **IMPFP-3957**

## **NAME**

IMPFP-3957

## **SUMMARY**

Multi-Layer pin %s has metals not exactly stacking. Multi-Layer pin needs at least 2 metal shapes.

## DESCRIPTION

This message is issued about multi-layer pins. They needs at least 2 metal shapes.

# **IMPFP-3960**

## NAME

IMPFP-3960

## **SUMMARY**

The cell '%s' and cell '%s' are using same tech site %s, but they have different VDDonbotom attributes. Need to align VDD/GND pins of single height row/double height row when creating rows. Check and correct the LEF file or OA abstract view.

## DESCRIPTION

If the customer is using OA libraries, this message should automatically switch to say OA abstract view instead of LEF. If Innovus does not have a mechanism to allow this type of dynamic response to the ERROR message, then the message should be changed to say OA abstract view or LEF file Example:

The cell '%s' and cell '%s' are using same tech site %s, but they have different VDDonbotom attributes. Need to align VDD/GND pins of single height row/double height row when creating rows. Check and correct the LEF file. or if starting Innovus with OA libraries:

The cell '%s' and cell '%s' are using same tech site %s, but they have different VDDonbotom attributes. Need to align VDD/GND pins of single height row/double height row when creating rows. Check and correct the OA abstract view.

or

The cell '%s' and cell '%s' are using same tech site %s, but they have

Error and Warning Messages

different VDDonbotom attributes. Need to align VDD/GND pins of single height row/double height row when creating rows. Check and correct the LEF file or OA abstract view.

# **IMPFP-3961**

### NAME

IMPFP-3961

## **SUMMARY**

The techSite '%s' has no related standard cells in LEF/OA library. Cannot make calculations for this site type unless standard cell models of this type exist in the LEF/OA library. If the SITE is not used by the library you can ignore this warning or remove the SITE definition from the LEF/OA to avoid this message.

## DESCRIPTION

This warning occurs when a site is defined without being referenced by any cell in LEF/OA library. The tool uses the SITE definition along with the library cells which use the SITE to validate the power and ground pins are defined consistently so followpin routing will be successful.

## Example:

**CLASS CORE**;

| Example.                                                                        |
|---------------------------------------------------------------------------------|
| * The following example shows a predefined SITE 'core' which is referenced by a |
| cell 'AND0':                                                                    |
| SITE core                                                                       |
| SITE 0.180 BY 1.114;                                                            |
| SYMMETRY Y;                                                                     |
| CLASS CORE;                                                                     |
| END core                                                                        |
| MACRO ANDO                                                                      |

Error and Warning Messages

| SIZE 0.360 BY 2.228; |
|----------------------|
| SITE core;           |
|                      |
|                      |
| FND AND0             |

# **IMPFP-3966**

### NAME

IMPFP-3966

## **SUMMARY**

%s is not on manufacturing grid (LL-%.4f %.4f). The object must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## **DESCRIPTION**

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so that it is on the manufacturing grid.

# **IMPFP-3967**

### NAME

IMPFP-3967

## **SUMMARY**

%s is not on manufacturing grid (UR-%.4f %.4f). The object must be on manufacturing grid in order

to be manufactured. Move the object so it is on the manufacturing grid.

### DESCRIPTION

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so that it is on the manufacturing grid.

# **IMPFP-3968**

## NAME

**IMPFP-3968** 

## **SUMMARY**

Horizontal Track is off manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## **DESCRIPTION**

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so that it is on the manufacturing grid.

# **IMPFP-3969**

## **NAME**

IMPFP-3969

## SUMMARY

Vertical Track is off manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

### **DESCRIPTION**

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so that it is on the manufacturing grid.

# **IMPFP-3970**

### NAME

IMPFP-3970

## SUMMARY

Placement grid is not on manufacturing grid.

## **DESCRIPTION**

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so that it is on the manufacturing grid.

## NAME

IMPFP-3971

## **SUMMARY**

The GCell Grid (%g %g) is not on manufacturing grid.

## **DESCRIPTION**

{ This message reports that an object is off the manufacturing grid. The manufacturing grid is defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid. }

# **IMPFP-3972**

### NAME

IMPFP-3972

## **SUMMARY**

Routing blockage((%f,%f),(%f,%f))is not on manufacturing grid. Check the routing blockage and move it on the manufacturing grid.

## **DESCRIPTION**

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually

Error and Warning Messages

manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid.

# **IMPFP-3973**

### NAME

IMPFP-3973

## SUMMARY

Routing blockage not on manufacturing grid.

## DESCRIPTION

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid.

# **IMPFP-3974**

## NAME

IMPFP-3974

## **SUMMARY**

The object %p (name: %s) is off the manufacturing grid. The object must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## **DESCRIPTION**

{ This message reports that an object is off the manufacturing grid. The manufacturing grid is

Error and Warning Messages

defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid. }

# **IMPFP-3975**

### NAME

**IMPFP-3975** 

### SUMMARY

Instance %s not on manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## DESCRIPTION

{ This message reports that an object is off the manufacturing grid. The manufacturing grid is defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid. }

# **IMPFP-3976**

## **NAME**

**IMPFP-3976** 

## **SUMMARY**

IO Pin %s, %s layer shape is not on the manufacturing grid. It must be on the manufacturing grid for it to be manufactured. Move the object so it is on the manufacturing grid.

## DESCRIPTION

This message reports that an object is off the manufacturing grid. The manufacturing grid is defined under the MANUFACTURINGGRID section in the technology LEF file. An object must be on this grid for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid.

# **IMPFP-3977**

### NAME

**IMPFP-3977** 

### SUMMARY

Multi-Layer pin %s has via %s not on manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## **DESCRIPTION**

{ This message reports that an object is off the manufacturing grid. The manufacturing grid is defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid. }

# **IMPFP-3978**

## **NAME**

**IMPFP-3978** 

Error and Warning Messages

## **SUMMARY**

Ptn %s Pin %s is not on manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

### DESCRIPTION

{ This message reports that an object is off the manufacturing grid. The manufacturing grid is defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid. }

# **IMPFP-3980**

## NAME

IMPFP-3980

## SUMMARY

Polygon pre-route is not on manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## DESCRIPTION

{ This message reports that an object is off the manufacturing grid. The manufacturing grid is defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid. }

## NAME

IMPFP-3981

### **SUMMARY**

PreRoute Via %s (%f,%f) is not on manufacturing grid. It must be on manufacturing grid in order to be manufactured. Move the object so it is on the manufacturing grid.

## **DESCRIPTION**

{ This message reports that an object is off the manufacturing grid. The manufacturing grid is defined in the technology LEF file. Look for MANUFACTURINGGRID in the LEF. An object must be on this grid in order for it to be manufactured. Some objects like partition boundaries or GCell Grids are not actually manufactured so this error may not be as serious as a via or other physical object being off grid. Overall, you should investigate the object and move it so it is on the manufacturing grid. }

# **IMPFP-4008**

## NAME

IMPFP-4008

## **SUMMARY**

The ring number '%d' is specified at sides '%s', so all IO pads defined in this ring honor margins for these sides to calculate the location.

## DESCRIPTION

The ring number '%d' is specified at sides '%s', so all IO pads defined in this ring honor margins for these sides to calculate the location.

```
Example:
(top
(io_row ring_number = 1 margin = 0)
)
(bottom
(io_row ring_number = 1 margin = 90)
)
(left
(io_row ring_number = 1 margin = 180)
```

## **NAME**

IMPFP-4009

## **SUMMARY**

The specified ring\_number '%d' exceeds the allowed max number 1000. Input correct ring\_number or reduce the number of rings.

## **DESCRIPTION**

The specified ring\_number '%d' exceeds the allowed max number 1000. Input correct ring\_number or reduce the number of rings.

```
Example:
```

```
( top
  (io_row ring_number = 1001 margin = 0)
)
```

## NAME

IMPFP-4010

## **SUMMARY**

The io\_order '%s' defined for ring\_number '%d' in local is different from the global setting '%s' . Tool will use the local setting for it.

## **DESCRIPTION**

The io\_order '%s' defined for ring\_number '%d' in local is different from the global setting '%s' . Tool will use the local setting for it.

```
Example:
( globals
version=3
io_order = counterclockwise
)
( left
( locals
ring_number=1
io_order=clockwise
)
```

## NAME

IMPFP-4011

## **SUMMARY**

There are more than one of space, offset, skip and endcap as constraints for IO instance '%s'. Use only one of them as the constraint.

## **DESCRIPTION**

There are more than one of space, offset, skip and endcap as constraints for IO instance '%s'. Use only one of them as the constraint.

## Example:

(inst name="ins 7" space = 0 offset = 1000)

# **IMPFP-7006**

## **NAME**

IMPFP-7006

## **SUMMARY**

Follow pin (Pin Box:%s) routed over hard macro (%s) should be cut at macro boundary.

## **DESCRIPTION**

{Follow pin cannot be routed over hard macros. So it should be cut at macro boundary.}

## NAME

IMPFP-7007

## **SUMMARY**

Power / Ground [rail | via | followpin] %s on layer %d does not match expected track color at box %s.

## **DESCRIPTION**

{The color of power/ground [rail | via | followpin] should be the same as layer track.}

# **IMPFP-7008**

## **NAME**

IMPFP-7008

## **SUMMARY**

Follow pin for net %s should horizontally align with the row boundary and vertically align with row end. The follow pin's box is : %s.

## **DESCRIPTION**

{Horizontal followpin should align with the row boundary. Vertical followpin should align with row end.}

## NAME

IMPFP-7009

## **SUMMARY**

Follow pin for net %s should align with power pin of rows (cells) if the cell will be placed in same orientation as row orientation. The follow pin's box is: %s

## **DESCRIPTION**

{The cell's followpin should align with power pin of rows if the cell is placed in the same orientation with row orientation.}

# **IMPFP-7012**

## NAME

IMPFP-7012

## **SUMMARY**

%s has been chosen to fit to track. But it's pin(%s) on layer %d is not on track.

# **DESCRIPTION**

{Pins should be on layer track.}

## NAME

IMPFP-7013

## **SUMMARY**

%s has a pin(%s) on layer %d. Its shape is on track, but color is not the same. According our rule NON-FAT pin shape should have same color with track.

## **DESCRIPTION**

{NON-FAT pin shape should have the same color with track.}

# **IMPFP-7014**

## **NAME**

IMPFP-7014

## **SUMMARY**

%s has a pin(%s) on layer %d. Its shape is on track, but color is not the same. According our rule FAT pin shape should have same color with track.

## **DESCRIPTION**

{FAT pin shape should have the same color with track.}

## NAME

IMPFP-7015

## **SUMMARY**

%s has a pin(%s) on layer %d. Its shape is on track, but color is the same. According our rule FAT pin shape should have different color with track.

## **DESCRIPTION**

{FAT pin shape should have the different color with track.}

# **IMPFP-7016**

## **NAME**

IMPFP-7016

## **SUMMARY**

Instance %s of macro cell %s is not fixed. Please update the place\_status to fixed prior to running placement.

## **DESCRIPTION**

{Instance of macro cell should be fixed status before running placement.}

## NAME

IMPFP-9998

### **SUMMARY**

The symmetry of instance '%s' does not allow the rotation or flipping as requested. x must be true to allow flipping about the X-axis, y must be true to flip about the Y-axis, xy must be true to flip about X or Y axis, and any must be true to allow rotation. Check current cell symmetry with 'get\_db [get\_db insts <cellName>].base\_cell.symmetry'.

## DESCRIPTION

{The symmetry is wrong and you need to update the library cell data to fix it permanently (LEF SYMMETRY statement). You can also change it with set\_db in the current session if you want to continue without reloading the libraries and design.}

# IMPILM-194

### NAME

IMPILM-194

## **SUMMARY**

Cannot flatten ILM modules due to preceding reported messages. All ILM modules will remain unflattening.

## **DESCRIPTION**

All ILM modules cannot be flattened due to the preceding reported messages. Problem is detected during reading an ILM netlist. The ILM netlist may have mismatched ports, or have duplicate module definition. Check the preceding error messages, fix the reported problem, and rerun the command

Error and Warning Messages

| again.               |
|----------------------|
| Example:             |
| innovus> flatten_ilm |
|                      |

\*\*ERROR: (IMPILM-193): There's problem reading ilm netlist (tdsp\_core.v). If the ILM netlist has mismatched port(s), you can either define an empty module definition for 'tdsp\_core' based on the one in ILM netlist upfront in the top level design netlist, or modify the instantiation/module for the mismatched port(s) in the top netlist to be consistent. Then re-run the flow for using ILM. If ILM netlist has duplicate module, try to re-run write\_ilm to recreate the ILM model or modify the duplicate modules to have unique name.

\*\*ERROR: (IMPILM-194): Cannot flatten ILM modules due to preceding reported messages. All ILM modules will remain unflattening

# IMPILM-203

## **NAME**

IMPILM-203

## **SUMMARY**

There is no ILM specified in the design. Nothing will be switched to ILM view.

## **DESCRIPTION**

flatten\_ilm command will not do anything because the design does not have any specified ILM. An ILM should be specified first before running flatten\_ilm command. Users can specify an ILM using the read\_ilm command and rerun flatten\_ilm again. Otherwise, flatten\_ilm will not run for a design that does not have any specified ILM.

Example:

read\_db . dtmf\_recvr\_core
set\_db ilm\_keep\_flatten true

Error and Warning Messages

read\_ilm -cell tdsp\_core -dir ../../PTM/tdsp\_core/ilm
read\_ilm -cell ram\_256x16\_test -dir ../../PTM/ram\_256x16\_test/ilm
update\_constraint\_mode -name setup\_func -ilm\_sdc\_files design/mmmc/dtmf\_recvr\_core\_func.sdc
flatten ilm

# IMPILM-281

## **NAME**

IMPILM-281

### **SUMMARY**

There is no netlist associated with the intended ILM specification for cell: %s

## **DESCRIPTION**

This ERROR usually occurs during flatten\_ilm. The netlist of the specified ILM cell is not available for loading. Run report\_ilm\_status to find out the data location of the specified ILM block and check if the netlist is available.

# IMPILM-298

## **NAME**

IMPILM-298

## SUMMARY

The cell of %s is not specified for ILM. Nothing to do with reset\_ilm.

## **DESCRIPTION**

Error and Warning Messages

reset\_ilm command outputs the warning message ECNILM-298 due to the specified cell is not an ILM. This command should only be used for unspecifying an existing ILM cell.

# IMPILM-334

### NAME

IMPILM-334

## SUMMARY

Specified ILM %s has non-empty module definition; no ILM created for it.

## DESCRIPTION

This error simply means that there is still a module for the ILM in the verilog netlist, which is not empty. There may be gates, or at least assign statements in it.Currently, in the ILM flow, we don't allow the ILM as non-empty module definitions during design import phase. Only empty module definitions are supported. To fix this error, user can remove the module definitions in the top level netlist to proceed. In other words modify the design data such that there is no non-empty ILM module in the top netlist.

# IMPILM-349

## NAME

IMPILM-349

### SUMMARY

\*Info: set\_db ilm\_keep\_async false conflicts with set\_db timing\_analysis\_async\_checks async setting. set\_db ilm\_keep\_async false will be used in the ILM flow.

## **DESCRIPTION**

Error and Warning Messages

set\_db ilm\_keep\_async setting will override the set\_db timing\_analysis\_async\_checks setting if there is a conflict. The ilm\_keep\_async option of set\_db is set to false while the design already has the setAnalysisMode timing\_analysis\_async\_checks async setting so the ilm\_keep\_async false setting will be used in the ILM flow instead. Set the ilm\_keep\_async option of setIlmMode to true if you want setAnalysisMode timing\_analysis\_async checks async to be honored.

### Example:

When there is si\_ilm\_data, if you run flatten\_ilm, it will issue this ERROR message.

# IMPILM-350

## NAME

IMPILM-350

## **SUMMARY**

set\_db ilm\_keep\_async true conflicts with set\_db timing\_analysis\_async\_checks noAsync setting. set\_db ilm\_keep\_async true will be used in the ILM flow.

## **DESCRIPTION**

set\_db ilm\_keep\_async setting will override the set\_db timing\_analysis\_async\_checks setting if there is a conflict. The ilm\_keep\_async option of set\_db is set to true while the design already has the set\_db timing\_analysis\_async\_checks noAsync setting so the ilm\_keep\_async true setting will be used in the ILM flow instead. Set the ilm\_keep\_asyncc option of set\_db to false if you want set\_db timing\_analysis\_async\_checks noAsync to be honored.

# IMPILM-365

## **NAME**

IMPILM-365

#### **SUMMARY**

SI data will not be generated in this run since extraction needs to be done in postRoute mode. To enable SI data creation, invoke SI aware optimization and then rerun write\_ilm.

#### DESCRIPTION

write\_ilm will not generate SI data since extraction needs to be done in postRoute mode . You need to firstly enable SI aware delay calculation by "set\_db delaycal\_enable\_si true", secondly make sure coupling is present and perform postroute timing analysis with "time\_design -post\_route", then SI data could be generated by write\_ilm.

## IMPILM-380

#### NAME

IMPILM-380

#### SUMMARY

Command '%s' is not supported in unflattened state. Use the 'flatten\_ilm' command to put the design in flattened state before calling this command.

#### **DESCRIPTION**

This error message is seen while using ILMs in toplevel without flattening ILMs and any timing and/or optimization commands are executed.

eg., \*\*ERROR: (IMPILM-380): Command 'createClockTreeSpec' is not supported in unflattened state. Please use the 'flatten\_ilm' command to put the design in flattened state, before calling this command.

Here, the the user tried to execute the command "create\_clock\_tree\_spec" before flattening the ILMs. All super commands such as opt\_design, time\_design, ccopt\_design etc., automatically take care of flattening and upon completion, leave the design in an unflattened state.

All other timing/optimization commands require you to run flatten\_ilm first so that the nets and instances internal to ILM are exposed to the timing engine.

You can refer to the ILM usage details in Innovus System User Guide.

## IMPILM-402

### **NAME**

IMPILM-402

#### SUMMARY

Interactive constraint is allowed only in flattened state of design. Specified interactive constraint '%s' would be lost.

#### DESCRIPTION

Why does Innovus System issue the above error message when I enter interactive constraints such as set\_timing\_derate?

How can one avoid this error?

In general, for ILMs constraints are supported through create\_constraint\_mode / update\_constraint\_mode specified in your mmmc setup. You may refer to our Foundation Flow scripts for detailed information. If specified interactively, they could only be done so in flattened mode and would be discarded in unflattened mode. However, the best way to specify your constraints is upfront through the above MMMC constructs and binded to -ilm\_sdc\_file argument, and they would thus be read automatically in the flow. If there are constraints that you need to specify which could not be done in an SDC file (e.g. setTimingDerate, group\_path), then you need to provide them through set\_ilm\_non\_sdc\_constraint\_file <fileName>.

You cannot specify the interactive constraints when ILMs are not flattened (unflatten\_ilm). In the flatten mode (flatten\_ilm), you can specify both interactive and modeless constraints and these constraints are used during various cycles of unflatten\_ilm to flatten\_ilm. During write\_db, these constraints are honored.

To specify additional constraints while running unflatten ilm, set the following:

set global timing defer mmmc obj updates true

set interactive constraint modes [all constraint modes -active|or your own list of modes]

foreach mode {list\_of\_modes\_to\_be\_updated} {update\_constraint\_modes -name \$mode - ilm\_sdc\_files

Error and Warning Messages

[concat get\_constraint\_modes -name \$mode -ilm\_sdc\_files] additional.sdc]
}

Include all modeless constraints such as timing\_derates and group\_path in a separate file, and run: set\_ilm\_non\_sdc\_constraint\_file <fileName>

# **IMPILM-537**

#### **NAME**

IMPILM-537

### **SUMMARY**

The command %s has become obsolete. It will be removed in the next release and replaced by create\_ilm\_from\_files.

### **DESCRIPTION**

To support MMMC analysis, create\_ilm\_from\_files command is added to replace the existing createILMDataDir command. The createILMDataDir command will be removed in the next release so the create\_ilm\_from\_files command should be used instead.

#### Example:

innovus> create\_ilm\_from\_files -cell blk1 -out\_dir A -model\_type timing -verilog\_file V1.v -spef\_file 1ef -rc\_corner corner1 -sdc\_file sdcfiles -timing\_view view1

# **IMPILM-548**

#### NAME

IMPILM-548

#### **SUMMARY**

'%s' is not supported in flattened ILM state. Internally Innovus will unflatten the ILMs in the design and will flatten them back before exiting the command. To improve run time, unflatten\_ilm command should be called explicitly for a group of commands that do not work in flattened state.

#### DESCRIPTION

When ilm\_keep\_flatten option of set\_db is set to true, for non-related timing commands Innovus will automatically unflatten the design, run the command, and flatten the design back. However it may take more run time if Innovus run unflatten\_ilm/flatten\_ilm for each non-related timing command. It is recommended that the user explicitly runs unflatten\_ilm for a group of commands that do not work in flattened mode to improve run time.

#### Example:

```
At top-level design, verify the design after the design has been optimized ...
...
time_design -sign_off -report_only -report_dir RPT
time_design -sign_off -report_only -hold -report_dir RPT
unflatten_ilm
report_summary -outDir RPT
check_connectivity -noAntenna
check_drc
check_metal_density
check_process_antenna
```

## **IMPIMEX-1**

### **NAME**

**IMPIMEX-1** 

#### **SUMMARY**

Failed to find target of link '%s' in given library directory '%s'.

#### DESCRIPTION

Check and correct the library path specified with \'-lib dir\' option.

# **IMPIMEX-3**

### NAME

**IMPIMEX-3** 

#### SUMMARY

There is no verilog netlist found in init\_netlist\_files. The variable is either not specified or specified incorrectly. Check the location of Verilog file in the global file.

### **DESCRIPTION**

This issue can be resolved as one of the following scenarios:

- 1. Check the location of Verilog file; if you had created soft links, it might have been deleted.
- 2. When restoring a design, an error might have occurred in sourcing the design.globals file, check the log for this error:

This error indicates certain variables in the global file no longer exist or have been replaced with newer ones; this error prevents the rest of the globals file from being read, and hence the Verilog netlist cannot be accessed.

Update to a new EDI System version OR make sure you maintain a version consistency in saving and restoring designs.

# **IMPIO-1**

### NAME

IMPIO-1

### **SUMMARY**

No active selection. Select one cell to shift up.

### **DESCRIPTION**

{DETAIL\_MESSAGE}

# **IMPIO-2**

### **NAME**

IMPIO-2

### **SUMMARY**

Too many selections. Shift one cell at a time.

### **DESCRIPTION**

{DETAIL\_MESSAGE}

# **IMPIO-3**

#### NAME

IMPIO-3

### **SUMMARY**

Reached end of table. No more cell to swap.

### **DESCRIPTION**

{DETAIL\_MESSAGE}

# IMPIO-4

#### NAME

IMPIO-4

### **SUMMARY**

Cannot swap io cells from side to corner, or vice versa.

### **DESCRIPTION**

{DETAIL\_MESSAGE}

# **IMPLF-3**

### **NAME**

**IMPLF-3** 

### **SUMMARY**

Error found when processing LEF file '%s'. The subsequent file content is ignored. Refer to error messages above for details. Fix the errors, and restart '%s' again.

### **DESCRIPTION**

Error and Warning Messages

If you have LEF syntax errors, you can look at the LEF manual to find the correct syntax. It can be accessed from the Innovus Help->Help Library... menu. Look under the Languages section for the latest LEF/DEF Language Reference Manual.

If there are semantic errors, check if you have the correct LEF technology file (the first file listed in the init\_lef\_files variable), or that you are not mistakenly including a LEF file with macros from some other technology node. You can also look at the manual for more information about specific statements.

## IMPLF-27

#### NAME

IMPLF-27

#### **SUMMARY**

TAPERRULE '%s' referenced in pin '%s' in macro '%s' is not found in the database, and will be ignored. The rule must be defined in the LEF NONDEFAULTRULE section before it can be referenced from a macro. Review the LEF files to see if the rule does not exist or is specified after the one that defines the macro.

#### DESCRIPTION

TAPERRULE must be defined in the LEF NONDEFAULTRULE section before it can be referenced from a macro. The rule is either missing from the LEF files that were read or it was defined in a LEF that was specified after the one that contained the macro. Review the LEF files to see if the rule is defined and, if so, reorder the LEF files so that the LEF file that contains the rule is read before the one that contains the macro.

# IMPLF-40

#### NAME

IMPLF-40

#### **SUMMARY**

Macro '%s' references a site '%s' that has not been defined. The sites must be defined before they can be referenced from a macro. Review the LEF files specified in the init\_lef\_files variable to see if the site does not exist or is specified after the one that defines the macro.

### **DESCRIPTION**

This error reports that a macro references a site that has not been defined. The sites must be defined before they can be referenced from a macro. The site is either missing from the LEF files that were read or it was defined in a LEF that was specified after the one that contained the macro. Review the LEF files specified in the init\_lef\_files variable to see if the site is defined and, if so, reorder the LEF files in the init\_lef\_files variable so that the LEF file that contains the site is read before the one that contains the macro.

The following example shows the SITE CORE0 and CORE2 are defined but CORE1 is not defined and referenced by the MACRO PLL which will lead to this error message:

| SITE CORE0          |
|---------------------|
| SYMMETRYY;          |
| CLASS CORE ;        |
| SIZE 0.045 BY 1.200 |
| END CORE0           |
|                     |
| SITE CORE2          |
| SYMMETRY X Y ;      |
| CLASS CORE ·        |

Error and Warning Messages

| SIZE 0.045 BY 2.400; |
|----------------------|
| END CORE2            |
|                      |
| MACRO PLL            |
| SITE CORE1;          |
| SYMMETRY X Y ;       |
|                      |

# IMPLF-53

#### NAME

IMPLF-53

### **SUMMARY**

The layer '%s' referenced %s is not found in the database. A layer must be defined in the LEF technology LAYER section before it can be referenced from a macro. Review the LEF files specified in the init\_lef\_files variable to see if the layer does not exist or is specified after the one that defines the macro.

#### DESCRIPTION

This error reports that a macro PIN references a layer that has not been defined. The layer must be defined before they can be referenced from a macro. The layer is either missing from the LEF files that were read or it was defined in a LEF that was specified after the one that contained the macro. Review the LEF files specified in the init\_lef\_files variable to see if the layer is defined and, if so, reorder the LEF files in the init\_lef\_files variable so that the LEF file that contains the layer is read before the one that contains the macro.

# **IMPLF-58**

#### NAME

**IMPLF-58** 

#### **SUMMARY**

MACRO '%s' has been found in the database. Its content except DENSITY and PIN ANTENNA\* data, and certain properties, will be ignored." "Review the LEF files specified in the init\_lef\_files variable and remove redundant definitions.

### **DESCRIPTION**

This message reports that a MACRO has already been defined in another LEF file, or earlier in this LEF file. All MACROs must be defined only once in LEF files. The only exception is the DENSITY and PIN ANTENNA\* data, and certain properties, which may be defined subsequently. If the data in both MACRO definitions is needed, manually merge the data into one definition.

Review the LEF files specified in the init\_lef\_files variable to see if a MACRO has been defined more than once, or if a LEF file has been mistakenly included more than once.

# **IMPLF-61**

#### NAME

IMPLF-61

#### SUMMARY

%d duplicated MACRO definitions have been found in the LEF file(s). Their content except DENSITY and PIN ANTENNA\* data, and certain properties, have been ignored." "Review the LEF files specified in the init\_lef\_files variable and remove redundant definitions.

Error and Warning Messages

#### DESCRIPTION

This message reports duplicated LEF MACRO definitions in the LEF file(s). If more than the default display limit of 20 has been reported, increase the display limit of warning message ENCLF-58 to see complete list of names.

All MACROs must be defined only once in LEF files. The only exception is the DENSITY and PIN ANTENNA\* data, and certain properties, which may be defined subsequently. If the data in all MACRO definitions is needed, manually merge the data into one definition.

Review the LEF files specified in the init\_lef\_files variable to see if a MACRO has been defined more than once, or if a LEF file has been mistakenly included more than once.

# **IMPLF-63**

### **NAME**

IMPLF-63

#### SUMMARY

The layer '%s' referenced %s is not found in the database. The obstruction geometries specified on the layer are being ignored. A layer must be defined in the LEF technology LAYER section before it can be referenced from a macro. Review the LEF files specified in the init\_lef\_files variable to see if the layer does not exist or is specified after the one that defines the macro.

### **DESCRIPTION**

This error reports that a macro OBS references a layer that has not been defined. The layer must be defined before they can be referenced from a macro. The layer is either missing from the LEF files that were read or it was defined in a LEF that was specified after the one that contained the macro. Review the LEF files specified in the init\_lef\_files variable to see if the layer is defined and, if so, reorder the LEF files in the init\_lef\_files variable so that the LEF file that contains the layer is read before the one that contains the macro.

# **IMPLF-80**

#### NAME

IMPLF-80

### **SUMMARY**

%s is not an even number of manufacturing grids which will result in DRC errors. Check the manufacturing grid definition in the technology LEF file and make sure the value is an even multiple of the grid.

### **DESCRIPTION**

When reading LEF Innovus System will check that WIDTH value on routing layer is an even number of manufacturing grids defined in the technology LEF file (MANUFACTURINGGRID). This will ensure that both the edge and the center-line of the wires will stay on the manufacturing grid.

Look for the following line in the LEF file to determine how many database units is 1 micron (dbuPerMicron):

UNITS DATABASE MICRONS dbuPerMicron;

To check if your dbu's have enough granularity, multiply dbuPerMicron \* manufaturingGrid. The result should be an integer quantity that is evenly divisible by two to ensure the center-line is on grid.

For example, if MANUFACTURINGGRID is 0.005, this is only achievable with a DBU of 2000.

- (1000\*0.005)/2 = 2.5, (not evenly divisible by two), the result could be off manufacturing grid.
- (2000\*0.005)/2 = 5, (evenly divisible by two), the result will be on manufacturing grid.

Error and Warning Messages

Or to say it another way:

If dbuPerMicron \* manufacturingGrid is an odd number (e.g. 1000\*0.005 = 5), you cannot create a path (center-line based) that has a width that is an odd number of manufacturing grids wide.

## **IMPLF-119**

#### NAME

IMPLF-119

### **SUMMARY**

LAYER '%s' has been found in the database. Its content%s will be ignored." "Review the LEF files specified in the init lef files variable and remove redundant definitions.

### **DESCRIPTION**

This message reports that a LAYER has already been defined in another LEF file, or earlier in this LEF file. All LAYERs must be defined only once in the technology LEF file (the first LEF file defined in the init\_lef\_files variable). The only exception is the ANTENNA\* data which may be defined in subsequent LEF files.

Review the LEF files specified in the init\_lef\_files variable to see if a LAYER has been defined more than once, or if a LEF file has been mistakenly included more than once.

If the data in both LAYER definitions is needed, manually merge the data into one definition.

# IMPLF-200

### NAME

IMPLF-200

#### **SUMMARY**

Pin '%s' in macro '%s' has no ANTENNAGATEAREA value defined. The library data is incomplete and some process antenna rules will not be checked correctly.

### **DESCRIPTION**

This warning is triggered when the technology data has process antenna rules, and a signal pin is missing process antenna data needed to check the rules. In this case, a signal pin that is either an input or inout pin is missing the gate-area data.

In CMOS, every signal pin that is an input or inout pin connects to a transistor gate. If there is no gate-area associated with this pin, then the library data is incomplete and process antenna rules cannot be checked for this pin correctly. The router and verification commands will assume this pin has no transistor gate attached, and therefore does not need to be protected from process antenna violations, which may result in real violations that are not fixed by the router or seen by the verification commands.

The best way to avoid this warning is to add the correct antenna gate-area data to the library data.

You can also use the suppressMessage command to turn off this warning message. This might be appropriate if you know the only library cells without antenna data are already protected by internal diode cells (e.g. some blocks might be built this way). In that case, you would lose the possible benefit of those internal diode cells for any nets connected to the block input, which might cause the router to add some unnecessary diode cells to protect other inputs attached to the same net. This is somewhat dangerous, because you might suppress messages for pins that are not protected.

You can also turn off the warning if you believe antenna errors are rare for these pins in practice, and you will depend on final sign-off physical verification tools to find any errors, and repair them

Error and Warning Messages

manually.

The following example shows the definition of antenna gate area in a LEF PIN statement:

```
MACRO AND2
CLASS CORE;
SIZE 0.90 BY 1.114;
SYMETRY X Y;
SITE CORE;
PIN A1
DIRECTION INPUT;
ANTENNAGATEAREA 0.002320; #antenna gate area in um^2
PORT
LAYER M1;
RECT 0.188 0.196 0.234 0.426;
END
END A1
...
```

**END AND2** 

# **IMPLF-201**

### **NAME**

IMPLF-201

Error and Warning Messages

#### **SUMMARY**

Pin '%s' in macro '%s' has no ANTENNADIFFAREA value defined. The library data is incomplete and some process antenna rules will not be checked correctly.

#### **DESCRIPTION**

This warning is triggered when the technology data has process antenna rules, and a signal pin is missing process antenna data needed to check the rules. In this case, a signal pin that is either an output or inout pin is missing the diffusion-area data.

In CMOS, every signal pin that is an output or inout pin connects to a transistor diffusion. If there is no diffusion-area associated with this pin, then the library data is incomplete and process antenna rules cannot be checked for this pin correctly. In that case, the router may try to protect other input pins connected to the same net with extra routing and vias ('layer-hopping'), or add extra diode cells to avoid 'false' antenna violations. The verification commands may flag false violations also.

The best way to avoid this warning is to add the correct antenna diffusion-area data to the library data.

You can also use the suppressMessage command to turn off this warning message. This might be appropriate if you know that antenna violations are rare in this technology, and you are willing to tolerate some extra layer-hopping, or extra diode cells that are not really necessary.

The following example shows the definition of antenna gate area in a LEF PIN statement:

MACRO AND2
CLASS CORE;
SIZE 0.90 BY 1.114;
SYMETRY X Y;
SITE CORE;

Error and Warning Messages

**DIRECTION INPUT;** 

ANTENNADIFFAREA 0.008320; #antenna diff area in um^2

**PORT** 

LAYER M1:

RECT 0.188 0.196 0.234 0.426;

**END** 

END A1

...

**END AND2** 

# IMPLF-223

### NAME

IMPLF-223

#### **SUMMARY**

The LEF via '%s' has been defined and found in the database. The current definition will be ignored. Review the LEF files to ensure that you have not specified duplicate LEF files, or LEF files with duplicate VIA definitions.

#### **DESCRIPTION**

This error reports that a LEF via is defined with the same name as a LEF via that has been previously defined and read into the database. The new definition is therefore ignored. The via name can not be the same if the via geometry is different. Make sure different via definitions have different via names. Otherwise, it may cause incorrect and undesired result. Review the LEF files to ensure that you have not specified duplicate LEF files, or LEF files with duplicate VIA definitions.

# IMPLF-345

#### NAME

IMPLF-345

#### **SUMMARY**

The EXACTWIDTH attribute is specified in ENDOFLINE" "phrase in SPACING statement in layer '%s'. This attribute is intended to" "be used with WIDTHTABLE or SPANLENGTHTABLE but there is no WIDTHTABLE nor" "SPANLENGTHTABLE statement defined in this layer. Make sure this rule is" "specified as intended.

#### DESCRIPTION

This is to specify that this end-of-line spacing rule only applies if the edge width/length is exactly equal to eolWidth. This construct would typically make sense only if WIDTHTABLE or SPANLENGTHTABLE is also defined on the layer, and the end-of-line spacing rule will only be triggered for one of the discrete widths.

Example:

```
PROPERTY LEF58_WIDTHTABLE

"WIDTHTABLE 0.05 0.10 0.15;";

SPACING 0.09 ENDOFLINE 0.051 WITHIN 0.02;

PROPERTY LEF58_SPACING

"SPACING 0.07 ENDOFLINE 0.10 EXACTWIDTH WITHIN 0.04;";
```

# **IMPMP-1001**

#### NAME

IMPMP-1001

#### SUMMARY

Invalid factor value '%s' for module '%s', and will be ignored during placement. Usage: place global module padding <modulename> <factor>

### **DESCRIPTION**

This warning message is issued while running place\_design command if there are some issues with 'place global module padding' attribute of set db command.

Example:

-----

Module padding is a means of reducing localized congestion (hotspots) by spreading out cell instances in the specified modules. The correct usage of the command is as below

set\_db place\_global\_module\_padding <modulename> <factor>

set\_db place\_global\_module\_padding <modulename> <factor>

A factor of 1.2 means the placer will increases the area of module A factor of 1.2 means the placer will increases the area of module and default value is 1.0.

# **IMPMSMV-1006**

### **NAME**

IMPMSMV-1006

#### **SUMMARY**

The number of areas exceed %d.

Error and Warning Messages

#### DESCRIPTION

he error message usually happens when setNanoRouteMode -routeHonorPowerDomain is true while the # of power domains and minGap areas exceed 64. Nanoroute will not honor some of the domains. Since the above mode is a soft constraint, you can ignore it if your design has more than 64 domains and mingaps.

Example:

-----

\*\*ERROR: (IMPMSMV-1006): Number of areas exceed 64

## IMPMSMV-1007

### **NAME**

IMPMSMV-1007

## **SUMMARY**

The default power domain is not defined. Check the CPF file and make sure default power domain is created with -default option.

### **DESCRIPTION**

Default power domain must be defined in the power intent file. When restoring an old DB saved without CPF by previous Innovus release, please prepare a CPF file correctly describing your power intent. Then use read\_power\_intent -cpf and commit\_power\_intent to load it into Innovus.

# **IMPMSMV-1015**

#### NAME

IMPMSMV-1015

### **SUMMARY**

The cell %s is defined in power intent file but is not defined in library or lef. Check the LEF and timing library files to make sure the cell's library is loaded.

#### DESCRIPTION

Cells defined in power intent file by 'define\_\*\_cell' command must have their LEF and timing library loaded into Innovus.

Example:

\*\*WARN: (IMPMSMV-1015): The cell SRDFFX1 is defined in power intent

file but is not defined in library or lef.

# IMPMSMV-1051

#### NAME

IMPMSMV-1051

#### **SUMMARY**

AOB cell type different along the signal path instance %s(cell:%s) drives instance %s(cell:%).

### **DESCRIPTION**

Both AOB and its driver cell should have same number of bia pin and connected to same bias net.

# IMPMSMV-1052

#### NAME

IMPMSMV-1052

#### SUMMARY

AOB instance %s(cell:%s) has bias pin while its driver %s(cell:%s) has not.

### **DESCRIPTION**

The AOB instance has bia pin connection, so its driver should have bias pin connected to same net or driver's location domain should have PMOS/NMOS bias pin specified.

# IMPMSMV-1053

### **NAME**

IMPMSMV-1053

#### **SUMMARY**

AO inst %s has cell type %s, doesn't match the best type (%s) for Domain %s.

#### DESCRIPTION

With share well AO buffering, each domain has its best fit AO type according to user defined power intent.

This message states that a non-best fit AO type is found in the netlist.

# IMPMSMV-1054

### **NAME**

IMPMSMV-1054

#### **SUMMARY**

Error and Warning Messages

inst %s is AO type %s, because its AO power net %s is no covered by domain nwell net %s.

#### DESCRIPTION

It is found that this AO instance fails on power net coverage requirement.

Location domain's nwell net must cover (more on) instance AO power net.

# IMPMSMV-1116

#### **NAME**

IMPMSMV-1116

#### SUMMARY

Failed to create powerDomain '%s', because the powerDomain name conflicts with the hinst name.

#### DESCRIPTION

The name of the power domain cannot be the same as its member hinst.

For example, this is wrong:

create\_power\_domain -name TDSP\_CORE\_INST -instances TDSP\_CORE\_INST and this is fine:

create\_power\_domain -name TDSPCore -instances TDSP\_CORE\_INST Example:

-----

\*\*ERROR: (IMPMSMV-1116): Failed to create powerDomain 'TDSP\_CORE\_INST',

because the powerDomain name conflicts with the hinst name.

#### NAME

IMPMSMV-1123

#### SUMMARY

(H)Inst '%s' belongs to instGroups '%s', it cannot be assigned to any power domain.

#### **DESCRIPTION**

Any domain's direct member cannot be a member of any other inst group.

If you have list this (H)Inst in power intent domain element list, it is a direct member.

User needs to resolve this before read/commit power intent by deleting such inst group.

# IMPMSMV-1211

#### NAME

IMPMSMV-1211

#### SUMMARY

The pg term %s of inst %s is not connected to any net. Use report\_power\_domain -inst to check its driver and receiver and pg connection information.

#### DESCRIPTION

The pg terms of instances are connected according to the power intent file: CPF or IEEE1801. There are implicit connection and explicit connection. Most of the pg connections are done implicitly. Such as connecting the primary power/ground pin of a standard cell to its power domain's primary power/ground net. Or connecting always-on buffer's secondary power pin to its driving instance's power pin. Or connecting level shifter's input and output power pin according to its

Error and Warning Messages

driving and receiving power domain. As long as the power domain, primary pg net and iso/shifter rules are properly defined in the power intent file,Innovus can derive the pg connection automatically. Explicit pg connection are necessary when there is no way for the tool to derive connection from the power intent file. For example, the pg pins of an analog block. In this case,user needs to add explicit pg connection, such as 'create global connection'command.

#### Example:

\*\*WARN: (IMPMSMV-1211): The pg term BIASNW of inst UPF\_ISO\_\_0\_out is not connected to any net.

## IMPMSMV-1212

#### **NAME**

IMPMSMV-1212

#### SUMMARY

The gnd term %s of inst %s is connected to WRONG net - %s. According to the instance power domain PG connection specification defined in CPF or IEEE1801, it should be connected to net - %s.

### **DESCRIPTION**

In CPF or IEEE1801 flow, most of the PG connection specification is automatically derived from instance's relationship with power domain and rules.

## IMPMSMV-1213

### **NAME**

IMPMSMV-1213

#### SUMMARY

The pwr term %s of inst %s is connected to WRONG net - %s. According to the instance power domain PG connection specification defined in CPF or IEEE1801, it should be connected to net - %s.

#### DESCRIPTION

In CPF or IEEE1801 flow, most of the PG connection specification is automatically derived from instance's relationship with power domain and rules.

# IMPMSMV-1215

#### NAME

IMPMSMV-1215

### **SUMMARY**

The tielo term %s of inst %s is connected to WRONG net - %s. Check the inst's PG connection and the term's related PG pin using report\_power\_domain -inst command.

### **DESCRIPTION**

Basically an instance's tie-off term should be connected based on the term's related PG pin and the net this PG pin is connected to.

For example:

For example:

For regular cell, tie-off term should be connected to its primary PG net.

For example:

For always-on cell, tie-off term should be connected its secondary PG net.

For example:

For level shifer cell, tie-off term should be connected to its input power net.

Error and Warning Messages

For example:

For hard macro, check the term's related pg attribute in \*.lib to decide.

# IMPMSMV-1219

### NAME

IMPMSMV-1219

#### **SUMMARY**

The AOB inst %s in domain %s has its P/G terms connected to P/G nets (pwr:%s, gnd:%s) of disabled domain %s.

### **DESCRIPTION**

The AOB instance is in a domain which has attribute 'disbale\_secondary\_domain' to disallow AOB in it to connect 2nd P/G pins to primary P/G nets of disbaled domains.

# IMPMSMV-1226

### **NAME**

IMPMSMV-1226

#### **SUMMARY**

AO inst (%s) is used in domain %s by shorting primary and secondary power term.

#### **DESCRIPTION**

The message exists after CMD check\_power\_domains means that there is always on buffer used in the design and its primary and secondary power is connected to the same supply power net.

Error and Warning Messages

The issue maybe caused by wrong behavior of Innovus if the buffer is added by GPS, always on buffer is used as regular buffer. Or the AON buffer is added for some design purpose by designer.

User can replace the AOB by a regular buffer to save area, and file a CCR against this issue if it is not added for any particular purpose.

#### Example:

<CMD> check\_power\_domains -bind -isoNetPD ./RPT/prects.isonets.rpt -xNetPD
./RPT/prects.xnets.rpt -gconn

Verifying P/G connection of power domain - 'PD AON LOGIC'.

Verifying P/G connection of power domain - 'PD\_ON\_OFF'.

\*\*WARN: (IMPMSMV-1226): AO inst (usb30\_core/u\_onoff\_top/u\_pib\_top/prects\_i\_FE\_OFC9162\_partial\_rst\_no) is used in domain PD\_ON\_OFF by shorting primary and secondary power term.

## IMPMSMV-1243

#### NAME

IMPMSMV-1243

### **SUMMARY**

Default powerDomain doesn't need minGap, option -minGaps is ignored.

#### **DESCRIPTION**

Unlike non default power domains, the default power domain does not need a fence constraint specified for it. The default power domain covers all the remaining core area except th non-default domain fences.

#### NAME

IMPMSMV-1245

#### SUMMARY

Default powerDomain doesn't need routeSearchExtension, option -power\_extend\_sides is ignored in update power domain command.

### **DESCRIPTION**

The default power domain doesn't have a fence constraint specified for it, hence routeSearchExtension is meaningless in this case.

# **IMPMSMV-1246**

#### NAME

IMPMSMV-1246

#### SUMMARY

Cannot modify default power domain rowFlip, option -row\_flip is ignored in update\_power\_domain command.

#### **DESCRIPTION**

The default power domain doesn't have a fence constraint specified for it, please use 'create\_floorplan' or 'create\_row' commands to change default domain row attributes.

### NAME

IMPMSMV-1247

#### SUMMARY

Cannot modify default power domain rowSpaceType, -row\_space\_type option is ignored in update\_power\_domain.

#### DESCRIPTION

Unlike non default power domains, the default power domain cannot have a fence constraint specified for it; please use 'set\_floorplan\_row\_spacing\_and\_type' or'create\_row' commands to change default domain row spacing attributes.

# IMPMSMV-1248

### **NAME**

IMPMSMV-1248

#### SUMMARY

Cannot modify default power domain rowSpacing, -row\_spacing option is ignored in update\_power\_domain.

### **DESCRIPTION**

Unlike non default power domains, the default power domain cannot have a fence constraint with dedicated rows specified for it; please use 'set\_floorplan\_row\_spacing\_and\_type' or 'create\_row' commands to change default domain row spacing attributes.

#### NAME

IMPMSMV-1249

#### SUMMARY

Cannot modify default power domain bbox, ignores -box option.

### **DESCRIPTION**

This message happens when 'update\_power\_domain -box' is used on a default power domain. Only non-default power domain is allowed to change the bounding box by -box option.

Example:

-----

<CMD> update\_power\_domain PD1 -box 0 0 100 100

\*\*WARN: (IMPMSMV-1249): Cannot modify default power domain bbox, ignores -box option.

# IMPMSMV-1264

### NAME

IMPMSMV-1264

## **SUMMARY**

minGap 0 set for powerDomain '%s' edge %d.

#### DESCRIPTION

Be cautious setting min gap zero for power domain, which might cause power shortage in the flow. Designer must make sure power separation is done correctly.

# **IMPMSMV-1267**

#### NAME

IMPMSMV-1267

#### **SUMMARY**

Option '%s' needs %d values in {...} and match domain's number of edges.

### **DESCRIPTION**

The problem could be that user is not putting all edge values in {}, or the number of values doesn't match number of edge of the domain. Please check option -help for command synatx.

# IMPMSMV-1314

#### NAME

IMPMSMV-1314

## **SUMMARY**

Cannot find cell '%s'. Check the LEF and timing library files to make sure the cell's library is loaded.

### **DESCRIPTION**

Error and Warning Messages

Cells defined in the CPF by 'define\_\*\_cell' command must have its LEF and timing library loaded into Innovus.

Example:

\*\*WARN: (IMPMSMV-1314): Cannot find cell 'SRDFFX1'.

## IMPMSMV-1315

### NAME

IMPMSMV-1315

### **SUMMARY**

Cell %s is a standard cell. The cell for ioPin (-boundary port) cannot be a standard cell.

#### **DESCRIPTION**

IMPMSMV-1315 is issued when users try to assign standard cell's IO pins' power domain through CPF create\_power\_domain -boundary\_ports.

Please check if the cell is defined as standard cell (CLASS CORE) in LEF.

Example:

```
-----
```

```
Pad cell for A_1/IO1 is defined as following:

cell(PAD_CELL) {

sec_external_voltage_type : voltage_07001800 ;

dont_use : true;

dont_touch : true;

sec_class : pad;

sec_cell_type : ringcell;

"sec_class : pad;" is not standard pad cell declaration.
```

Liberty Guide uses pad cell: true;

March 2020 394 Product Version 20.10

#### NAME

IMPMSMV-1501

#### SUMMARY

No connection specification for shifter '%s' in power domain '%s'. \Power/Ground terms are not connected.

#### **DESCRIPTION**

During commit\_power\_intent the above message is reported because it can not connection the shifter PG pins. One of the reason is that the shifter is float and commit\_power\_intent can not make its non-follow-pin PG connection.

### Example:

To specify the power and ground connections for the power domain add something like the following to the CPF:

create power nets -nets VDD -voltage 1.080

create ground nets -nets VSS -voltage 0.000

update power domain -name AO -primary power net VDD -primary ground net VSS

## IMPMSMV-1504

#### **NAME**

IMPMSMV-1504

#### SUMMARY

Failed to get pin '%s' for cell '%s'.

Error and Warning Messages

#### DESCRIPTION

Please check if the pin is defined in LEF file for the cell.

A possible reason is the cell pin is defined in timing library but not defined in LEF file.

# IMPMSMV-1531

#### NAME

IMPMSMV-1531

#### SUMMARY

Failed to get power and ground connection specification for powerDomain '%s' instance '%s' (Cell:%s, Pwr:%s, Gnd:%s). Use report\_power\_domain -inst to check if its PG connection information is implicitly or explicitly defined in CPF or IEEE1801.

### **DESCRIPTION**

The message normally happens on the Nwell/Pwell pin connections. Those Nwell/Pwell connections should be defined in CPF or IEEE1801.

# IMPMSMV-1592

#### NAME

IMPMSMV-1592

#### SUMMARY

No default tech site found for power domain '%s'. Power domain must be empty (no standard cells, and I/O cells).

### DESCRIPTION

This warning is issued when a virtual power domain is defined in the CPF i.e a power domain is created without -instances and -default options (create\_power\_domain -name VDDAR\_virtual)

Example:

-----

Below example shows a Power domain created without -instances and -default options in CPF. Innovus issues this warning when CPF contains below definition.

create\_power\_domain -name VDDAR\_virtual

\*\*WARN: (IMPMSMV-1592): No default tech site found for power domain 'VDDAR\_virtual'. Power domain must be empty (no standard cells, and I/O cells).

Check if PowerDomain contains any stdcells:

> llength [ dbget -e [dbget -e top.insts.pd.name VDDAR\_virtual -p2 ].cell.subClass core ]

If the powerdomain is not empty make sure visually that it's fence is placed inside the DIE area and rows are cut inside its fence for the site to which its stdcells belong to .

# IMPMSMV-1595

# **NAME**

IMPMSMV-1595

#### SUMMARY

Failed to find spare instance for cell:%s from spare list in PostMask ECO mode.

Error and Warning Messages

### DESCRIPTION

This error indicates that the command tried to find a spare component to use, but failed to find a proper one.

This happens if there is no more spare one, or the applicable ones are not specified with eco\_design command.

Please check eco\_design command -spareCell option to make sure spare cell are provided correctly.

# IMPMSMV-1636

### **NAME**

IMPMSMV-1636

# **SUMMARY**

No library found for level shifter cell '%s' with input '%f' and output '%f' volts, placed in power domain '%s'. The first available library cell of the same name will be used, irrespective of input and output voltages.

# **DESCRIPTION**

Why is this message issued during timing analysis?

Following are excerpts from the library showing a level shifter and associated pins and their voltage. If a level shifter with the appropriate voltages is not found the error above will be issued.

At the top of the file the voltage levels are defined using voltage\_map

statements:

```
voltage_map (VDD, 1.08);
voltage_map (ExtVDD, 0.9);
voltage_map (VSS, 0);
```

Error and Warning Messages

```
voltage_map (GND, 0);
voltage_map (ExtVSS, 0);
Example:
Within the cell definition define power pins and respective voltage names
within a pg pin statement:
cell (LSHLX1 FROM) {
is_level_shifter:"true";
level_shifter_type : "HL";
area:0;
pg_pin (VSS) {
pg_type: primary_ground;
voltage_name: "VSS";
}
pg_pin (VDD) {
pg_type:primary_power;
std cell main rail: true;
voltage name: "VDD";
pg_pin (ExtVDD) {
pg_type:backup_power;
voltage_name : "ExtVDD";
Lastly, define the signal level and related power and ground pins for the input
and output pins:
pin (Y) {
output_signal_level : ExtVDD;
direction: output;
```

Error and Warning Messages

```
function : "A";
related_ground_pin : VSS;
related_power_pin : ExtVDD;
pin (A) {
input_signal_level : VDD;
direction : input;
related_ground_pin : VSS;
related_power_pin : VDD;
```

# IMPMSMV-1780

# **NAME**

IMPMSMV-1780

# **SUMMARY**

Power net '%s' is not specified in command line.

# **DESCRIPTION**

This message is issued when the power net present in the design but not specified with command "set\_lib\_binding\_by\_voltage -power\_net\_voltages". To fix the issue, all power nets present in the design must be specified with command "set lib binding by voltage".

# IMPMSMV-1781

## **NAME**

Cannot find net '%s' in design, skip it.

### DESCRIPTION

This message is issued when power net specified in the command "set\_lib\_binding\_by\_voltage - power\_net\_voltages" is not present in the design. The net will be ignored. To fix the issue, specify the correct power net.

# **IMPMSMV-1783**

## NAME

IMPMSMV-1783

# **SUMMARY**

Cannot find a matching library for inst %s (cell %s), use library %s.

### **DESCRIPTION**

This message is issued when session does not have any library with the pg pin voltage that matches with the power net voltage specified in command "set\_lib\_binding\_by\_voltage - power\_net\_voltages". In such case, software binds the instance to available library. This may impact analysis accuracy. To fix the issue, load the libraies with matching power net voltages.

# IMPMSMV-1792

#### NAME

Power domain is not created for pg net %s because it is not connected to any standard cell's primary/backup/internal pg\_pin The voltage might not be assigned correctly because it is not associated with a power domain.

### DESCRIPTION

This message is issued when there is an unconnected pg net in design. There will not be any power domain creation corresponding to such pg net. The voltage might not be assigned correctly because it is not associated with a power domain. To fix the issue, specify the voltage for such pg net(s) explicitly in set\_lib\_binding\_by\_voltage command.

# IMPMSMV-1798

### NAME

IMPMSMV-1798

### **SUMMARY**

Power net '%s' is not specified in -pg net voltages of create delay corner or update delay corner.

### **DESCRIPTION**

This message is issued when the power net present in the design but not specified with - power\_net\_voltages option of create\_delay\_corner or update\_delay\_corner. To fix the issue, all power nets used in the design must be specified.

# IMPMSMV-1800

#### NAME

Pin '%s' of multi-supply cell '%s' (%s) does not have related\_power\_pin attribute.

## **DESCRIPTION**

Signal pin in multi-supply cell should have related\_power\_pin attribute so correct power supply can be determined.

# IMPMSMV-1801

## NAME

IMPMSMV-1801

# **SUMMARY**

The power or ground pin, '%s' (pg\_type '%s') of cell '%s' (instance '%s') is not connected to power or ground net. Please fix the Verilog file by connecting this pin to a power or ground net.

# **DESCRIPTION**

pg\_pin should be connected to have correct voltage.

# IMPMSMV-1802

# **NAME**

IMPMSMV-1802

## **SUMMARY**

Voltage of term '%s', %gv, does not match the voltage of multi-driver net '%s', %gv.

### DESCRIPTION

Please check all the inputs of multi-dirver net to make sure they have the same related power supply and voltage.

# IMPMSMV-1804

### NAME

IMPMSMV-1804

### **SUMMARY**

Cell '%s' does not have timing library defined in default library set of analysis view '%s'.

# **DESCRIPTION**

This message is issued when the cell is used in the design but its corresponding timing library is not present. To fix the issue, timing library corresponding to each cell must be loaded.

If the cell is physical only, the message can be ignored.

If timing is needed, please add a library containing the missing cell and restart the run, or update the library set using update\_library\_set.

# IMPMSMV-1805

#### NAME

IMPMSMV-1805

### **SUMMARY**

Pin '%s' of inst '%s' (cell %s) does not have related power pin attribute, voltage %g is assigned.

# **DESCRIPTION**

Error and Warning Messages

Signal pin in multi-supply cell should have related\_power\_pin attribute so correct power supply can be determined.

# IMPMSMV-1806

### NAME

IMPMSMV-1806

# **SUMMARY**

Pin '%s' of inst '%s' (cell %s) is related to internal\_power\_pin %s which does not have pg\_function attribute, voltage %g is assigned.

# **DESCRIPTION**

Signal pin in multi-supply cell should have related\_power\_pin attribute so correct power supply can be determined.

# IMPMSMV-1820

# **NAME**

IMPMSMV-1820

#### SUMMARY

Detected design has ILM(s) and is in unflattened state, read/commit power intent must run after flettenlim.

### DESCRIPTION

The correct flow for design with ILM is to flatten all ILMs then read/commit power intent, this chip level

Error and Warning Messages

power intent contains information covering inside ILM netlist. Fail to follow the recommended flow might

induce down stream design issue.

# IMPMSMV-3101

#### NAME

IMPMSMV-3101

#### SUMMARY

replaceWithAlwaysOnBuffer: No always-on buffer specified in CPF. Make sure always-on buffers are defined properly in the CPF and they are not set dont\_use. Use 'get\_db' comamnd to check and 'set opt dont use' to change setting.

### **DESCRIPTION**

In assign scenario, after commit\_power\_intent, regular feed though assign buffer in off domain will be replaced by always on buffer(when turn on do assign in case). But if there is no always on buffer defined by define\_always\_on\_cell in CPF file, or the always on cell has dont\_use attribute in lib or in tcl file, above ERROR will exist.

#### Example:

(1) In below CPF file, all define\_always\_on\_cell attribute is commented and "setMsvMode - useLibraryLowPowerCell false", WARN(IMPMSMV-3101) will exist after commit\_power\_intent.

#define\_always\_on\_cell -cells { GPGBUF\_X8M\_A9TH } -power\_switchable VDD -power VDDG - ground\_switchable VSS -ground VSSG

(2) In below case tcl, if only one always on buffer exist in design, after "set\_opt\_dont\_use GPGBUF\_X8M\_A9TH true", WARN(IMPMSMV-3101) will exist after commit\_power\_intent.

set\_opt\_dont\_use GPGBUF\_X8M\_A9TH true

read\_power\_intent -cpf top.cpf

commit\_power\_intent -verbose

### NAME

IMPMSMV-3502

#### SUMMARY

Power net %s is not associated with any power domain. It is probably because this power net is not specified as any domain's primary power net. You need to modify CPF to create a virtual power domain using 'create\_power\_domain' without -instances and -default options then specify this power net as its primary power net using 'update\_power\_domain'.

# DESCRIPTION

This warning is issued when a power net is defined in CPF by "create\_power\_nets -nets < >" and is not associated with any power domain by "update\_power\_domain -primary\_power\_net".

When you see this warning, Please check CPF file to see if all of power nets are associated with power domain.

### Example:

User need to modify CPF file to create a virtual power domain using "create\_power\_domain" without -instances and -default options then specify this power net as its primary power net using "update\_power\_domain".

create power nets -nets vddar2 -voltage 1.2

update\_power\_domain -name VDDAR\_virthttp -primary\_power\_net vddar2

# IMPMSMV-3700

# **NAME**

IMPMSMV-3700

# **SUMMARY**

Isolation instance %s input is tied to power/ground.

### DESCRIPTION

The message exist after CMD check\_power\_domains and means that there input of some isolation instance ties to power/ground.

This kind of isolation always added by other tool not Innovus for particular purpose. (Cross domain tie high/low)

User should get to know the usage of this kind of isolation and check if its power connection is right.

#### Example:

<CMD> check\_power\_domains -isoNetPD

... ..

- \*\*WARN: (IMPMSMV-3700): Isolation instance CPF\_ISO\_out1 input is tied to power/ground.
- \*\*WARN: (IMPMSMV-3700): Isolation instance CPF\_ISO\_out1 input is tied to power/ground.

In the design, CPF\_ISO\_out1's input is connected directly to power.

# IMPMSMV-3701

### NAME

IMPMSMV-3701

### **SUMMARY**

Isolation instance %s input and output are of the same power domain %s. Please make sure that the isolation driver and receivers are in different domains. Use report\_power\_domain -inst to check its driver and receiver connections.

### **DESCRIPTION**

Effective power domain of input and output of the specified isolation instance is the same.

Most Likely Cause:

(1) Redundant isolation is added

Error and Warning Messages

- (2) Isolation cell's power connection changed
- (3) In IEEE1801 flow, it may caused by not detailed isolation strategy (no -source/-sink)

What to Do Next:

- (1) If the isolation is redundant, user can eco delete the isolation as workaround and file CCR against the issue
- (2) Use connect\_global\_net to change the connection as workaround and file CCR against the issue
- (3) Complete isolation strategy in 1801 file

# IMPMSMV-3910

#### NAME

IMPMSMV-3910

# **SUMMARY**

Creating new supply port %s for module %s to connect supply net %s, this will cause inconsistency on physical netlist and power intent. check message help for detail.

## DESCRIPTION

A new P/G port is added for a supply net to go into a module. This is most likely to connect new buffers added by application.

This will cause inconsistency of physical netlist and power intent which defines all P/G connection of a design.

Do either of following steps will prevent new port being created during the design process.

For hierarchical power intent, user should define supply ports for all connecting nets of a scope, and connect all of them

with connect\_supply\_net -ports.

To prevent a P/G net being used to connect into a scope, user should utilize extra\_supplies option to control P/G connection.

### NAME

IMPMSMV-3920

#### SUMMARY

Failed to connect net %s into instance in ILM module %s, because no existing PG port to connect.

# **DESCRIPTION**

The connection cannot be done, because ILM moduel cannot be modified.

User needs to check netlist of ILM instance, or P/G connection spec. in power intent.

# IMPMSMV-4001

# **NAME**

IMPMSMV-4001

### SUMMARY

The '-fromPowerDomain' option is obsolete. Please use '-from' instead.

### **DESCRIPTION**

The option '-fromPowerDomain' of report\_isolation and report\_shifters is obsolete and has been replaced by '-from'. The obsolete option still works in this release but to avoid this warning and to ensure compatibility with future releases, update your script to use '-from'

#### Example:

<CMD> report isolation -fromPowerDomain PDtdsp

\*\*WARN: (IMPMSMV-4001): The '-fromPowerDomain' option is obsolete. Please use '-from'

Error and Warning Messages

instead.

INFO: Isolation instances will be reported to file dtmf chip.isolation.rpt.

INFO: 102 isolation instances reported.

# IMPMSMV-4002

#### NAME

IMPMSMV-4002

### SUMMARY

The '-toPowerDomain' option is obsolete. Please use '-to' instead.

# **DESCRIPTION**

The option '-toPowerDomain' of report\_isolation and report\_shifters is obsolete and has been replaced by '-to'. The obsolete option still works in this release but to avoid this warning and to ensure compatibility with future releases, update your script to use '-to'

#### Example:

<CMD> report\_isolation -toPowerDomain PDtdsp

\*\*WARN: (IMPMSMV-4002): The '-toPowerDomain' option is obsolete. Please use '-to' instead.

INFO: Isolation instances will be reported to file dtmf chip.isolation.rpt.

INFO: 32 isolation instances reported.

# IMPMSMV-4100

#### NAME

Domain member (%s -> %s) is not inside specified domain %s

# **DESCRIPTION**

The named domain member is not inside logical hierarchy of any member of specified parent domain.

This feature requires all domains and its members must be under same logical hierarchy of the specified parent domain.

# IMPMSMV-4110

### NAME

IMPMSMV-4110

# **SUMMARY**

P/G nets are different, physical Domain %s has P/G nets (%s, %s), but domain %s has (%s, %s)

## **DESCRIPTION**

All logical domains must have same P/G nets as its parent physical domain.

Please reset marking with mark physical power domains commands.

# IMPMSMV-4111

## **NAME**

Error and Warning Messages

### SUMMARY

N/Pwell nets are different, physical Domain %s has N/Pwell nets (%s, %s), but domain %s has (%s, %s)

# **DESCRIPTION**

All logical domains must have same Pwell/Nwell nets as its parent physical domain.

Please reset marking with mark\_physical\_power\_domains commands.

# IMPMSMV-4112

### NAME

IMPMSMV-4112

### SUMMARY

Failed to find domain to share fence for domain %s, power (%s), ground (%s)

### **DESCRIPTION**

User should check if mamrked physical domain cover all logical domains.

Innovus will search higher hierarchy for physical domain from logical domain level.

# IMPMSMV-4113

### NAME

IMPMSMV-4113

### **SUMMARY**

Error and Warning Messages

Available supplies are different, physical PD %s, logical PD %s

### DESCRIPTION

All domains share same fence must have same available supplies.

Check input power intent, or report of power domains.

# IMPMSMV-4115

# **NAME**

IMPMSMV-4115

#### SUMMARY

Found domain (%s) has P/G nets (%s,%s) which are different from previous set (%s,%s).

#### DESCRIPTION

There are at least one domain has different P/G nets with others in the input domain list. it is required that all domains to share fence or to be merged have same P/G nets defined.

# IMPMSMV-4120

# **NAME**

IMPMSMV-4120

# **SUMMARY**

Domain::Hinst (%s::%s) and (%s::%s) violates paren/child restriction.

# **DESCRIPTION**

Error and Warning Messages

To merge physical power domains, all domains must not in parent/child logical hierarchy from its members.

Review and update domains list in command line.

Use -domains for domains which have parent/child hierarchy members.

# IMPMSMV-4200

# **NAME**

IMPMSMV-4200

## **SUMMARY**

Power Domain (%s) is virtual, set a fence for it has no effect and will not be saved.

## **DESCRIPTION**

A virtual domain has no member, the fence will not be saved.

# IMPMSMV-4201

# **NAME**

IMPMSMV-4201

### **SUMMARY**

Power Domain (%s) is logical, should not have fence.

# **DESCRIPTION**

Setting boundary for logical will be deleted later if this domain is set to share fence of a physical domain.

## NAME

IMPMSMV-6600

### SUMMARY

Command '%s' is not allowed after '%s'

# **DESCRIPTION**

There are commands that are not allowed to run after a certain stage in the design flow. This is one of them.

# IMPMSMV-7101

## **NAME**

IMPMSMV-7101

## **SUMMARY**

error parsing IEEE1801 power intent file.

# **DESCRIPTION**

This error is a general message issued when parsing of IEEE1801 fails.

This is typically due to syntax errors in the file. When you receive this message, review the log file for warning and error messages which precede the ENC1801-201 message. You should see messages which report

Error and Warning Messages

the specific lines in IEEE1801 which Innovus System is complaining about.

Correct the IEEE1801 and then try loading it in again.

# IMPMSMV-7510

## **NAME**

IMPMSMV-7510

### **SUMMARY**

Power Switch rule %s for domain %s specifies input supply net %s, but no connecting net found on ptn %s.

# **DESCRIPTION**

Partition will only create such port if the net connects to partition boundary.

Check power intent for such connection being specified or if power plan has been done correctly.

# IMPMSMV-7511

# **NAME**

IMPMSMV-7511

### SUMMARY

Per power intent, Power Switch rule %s output supply net %s will connect to outside, but no port found on ptn instance %s.

### DESCRIPTION

Partition will only create such port if the net connects to partition boundary.

Error and Warning Messages

Check power intent for such connection being specified or if power plan has been done correctly.

# IMPMSMV-7512

### **NAME**

IMPMSMV-7512

### **SUMMARY**

Partition %s has PG pin %s, but it is not connected, it might need to be connected to net %s.

## **DESCRIPTION**

Partition is not connected to the net. However, partition cell has same name port exists.

It is highly possible that the net should be connected to this port. Need to check why connection is missing.

# IMPMSMV-7515

### NAME

IMPMSMV-7515

# **SUMMARY**

Partition %s rule %s has specified net %s, but has no such port found.

### DESCRIPTION

Partition has power intent rule where a net is specified, but cannot find such net connecting into partition.

User might need to update power intent to connect it or use power plan or power route to connect it.

#### NAME

IMPMSMV-7520

#### SUMMARY

Partition %s Domain %s has power switch rule %s, control signal %s is not connected to partition.

# **DESCRIPTION**

This message warns that power switch rule control signal is not connected to partition, this is probably

because there is no power switch added, if power switch is to be added in partition, then this signal should be manually connected to partition.

# **IMPMSMV-8003**

# NAME

IMPMSMV-8003

#### SUMMARY

skip element %s because it is not at the domain interface

#### DESCRIPTION

For the IEEE1801 isolation and level shifter insertion, the element listed in the IEEE1801 set\_isolation and set\_level\_shifter should be either domain boundary ports or IO port or domain member. Please check the specified element in the IEEE1801 file.

#### NAME

IMPMSMV-8304

### SUMMARY

rule %s: isolation inst %s has wrong isolation\_signal; the ISO's enable pin is driven by a source which doesn't match the isolation signal specified in the IEEE1801 rule.

#### **DESCRIPTION**

```
please check if the ISO's source matches to the one specified in
-isolation_signal option in the IEEE1801 set_isolation command.

For example,
set_isolation rule1 -domain PD1 -isolation_signal I1/isoCtrl \
-isolation_sense low -location self

Example:
------

From Innovus, you can trace the connection of the instance's enable pin by:
innovus 1> report_power_domain -inst U_TOP_IO/U_PD_IO/UPF_ISO_1

Analyzing U_TOP_IO/U_PD_IO/UPF_ISO_1 (Cell: ISO_CELL) power domain: PD_IO
------ from side -------

Pin sdn33 (related power pin vdd33) => Net n6

U_TOP_IO/U_PD_IO/pdft_51/z in power domain PD_IO
innovus 4> all_fanin -to n6

A/z A/i iso/z33 iso/i U_TOP_ANALOG/U_TA_ANA/U37/z U_TOP_ANALOG/U_TA_ANA/U37/i
...
```

March 2020 420 Product Version 20.10

Error and Warning Messages

all\_fanin returns pin chain, the last pin of which name contains

U TOP ANALOGISU TOP ANALOG/U TA ANA/U37/z.

innovus 7> get\_nets -of U\_TOP\_ANALOG/U\_TA\_ANA/U37/z

n3

# without -leaf, the following command returns the highest level HTerm on the net

innovus 8> get\_pins -of n3

U\_TOP\_ANALOG/sul\_iso\_core2ana U\_TOP\_IO/iso

So the fanin is U\_TOP\_ANALOG/sul\_iso\_core2ana not

U TOP ANALOG/sul iso core2io specified in the UPF rule.

It means the connectivity in the Verilog doesn't match the rule in the UPF.

# IMPMSMV-8401

### NAME

IMPMSMV-8401

#### SUMMARY

Internal power domain %s is created for supply nets %s %s. Users need to define its PVT using MMMC command 'update delay corner -power domain'.

#### DESCRIPTION

In IEEE1801 flow, there are more supply sets than power domains. Innovus will create an "internal power domain" for the supply set which is not primary PG nets for a domain.

- commit power intent will issue a WARN when it creates "internal" domain.
- Signal pin can be assigned to an internal domain if the signal pin is related the supply set without any associated domain in IEEE1801

Users need to define the internal domain's PVT so that a signal pin can be assigned to the correct voltage.

Voltage assignment flow:

Error and Warning Messages

Signal pin -> related pg pin -> supply set -> domain -> domain's PVT definition in each view

To define the PVT, use MMMC command:

update delay corner-name <delay corner>

-power domain <internal domain name> -opcond <op cond you defined>

# IMPMSMV-8600

### **NAME**

IMPMSMV-8600

## **SUMMARY**

Power Intent is Not committed yet.

### **DESCRIPTION**

Power Intent has been read, but has not been committed according to db.

User should run command - commit power intent to commit it before checking it.

# IMPMSMV-8610

# **NAME**

IMPMSMV-8610

### **SUMMARY**

Power domain (%s) has no %s net defined.

### DESCRIPTION

Power Domain has no power or ground net defined, and no supply set associated with it.

Error and Warning Messages

Check input power intent and correct it, then redo read\_power\_intent and commit\_power\_intent before proceeding.

# **IMPMSMV-8620**

## NAME

IMPMSMV-8620

### **SUMMARY**

Power domain (%s) has not given a legal fence.

# **DESCRIPTION**

All physical power domain must have fence defined and inside design boundary.

Use floorplan command or GUI to define power domain boundary.

# **IMPMSMV-8623**

# NAME

IMPMSMV-8623

### SUMMARY

Primary PG term %s of Instance %s is connected to net %s which conflicts with primary power net %s of the domain %s specified in UPF. This can impact the run time and quality of results.

# **DESCRIPTION**

This error might lead to power shortage, and need to be fixed.

Use reportPowerDomain -inst <inst\_name> -verbose to see connection details.

## NAME

IMPMSMV-8630

# **SUMMARY**

Power domain (%s) in view (%s) has no user defined operating condition.

# **DESCRIPTION**

To achieve the best QoR of design, it is recommended that user to define complete operating condition in MMMC definition file.

# IMPMSMV-8631

#### NAME

IMPMSMV-8631

### **SUMMARY**

Power domain (%s) in view (%s) is using op. cond from timing library set.

#### DESCRIPTION

Every power domain should have user defined operating condition or a valid definition from its timing library.

The check shows user has not defined operating condition, and using the setting from domain's timing library.

User can modify view definition file to define operating condition.

### NAME

IMPMSMV-8632

#### SUMMARY

Power domain (%s) in view (%s) has no default op. cond.

# **DESCRIPTION**

No user defined or default op. cond. can be found from power intent for this power domain.

This could lead to incorrect timing evaluation of the design.

It is recommended that user to modify view definition file and define complete operating condiditon for each domain.

# IMPMSMV-8640

## NAME

IMPMSMV-8640

### SUMMARY

No timing library set found for domain %s in view %s.

### **DESCRIPTION**

Check MMMC configuration file for timing library definition for power domains and views.

It is recommended to define power domain specific library set in all views.

### NAME

IMPMSMV-8650

# **SUMMARY**

Cell (%s) Pin (%s) has no related power/ground pin defined in timing library.

# **DESCRIPTION**

Reported pin of cell has no related power/ground pin defined in timing library.

# **IMPMSMV-8656**

# **NAME**

IMPMSMV-8656

# **SUMMARY**

Domain (%s) do not allow feedthrough being added in it.

# **DESCRIPTION**

All modules inside this domain are not allowed to add new port, so no feedthrough can go thru it.

This is to warn user that no feedthru can be added to reported domain, as this might affect timing result.

### NAME

IMPMSMV-8660

#### SUMMARY

No available AO buffer for power domain (%s) in view (%s).

# **DESCRIPTION**

There is no AO buffer found for the reported domain and view, either no buffer found in domain's library set

or some buffers might be marked as don't use. If AO buffer is expected to be used in this domain, user must

correct this issue before proceed in the design flow.

# **IMPMSMV-8670**

#### **NAME**

IMPMSMV-8670

# **SUMMARY**

Instance (%s) of power domain (%s) is placed inside fence of power domain (%s).

### DESCRIPTION

Reported instance is fixed and placed in other domain's fence, this is placement violation that needs to be corrected.

User can manually move or unplace the reported instances, and redo placement to correct the issues.

# **IMPOAX-124**

#### NAME

IMPOAX-124

### **SUMMARY**

OpenAccess (OA) shared library installation is older than the one that was used to build this %s version. For using the OA installation built and tested with this %s version, unset the shell variable OA\_HOME. For using '%s' or higher version of OA, reset OA\_HOME to point to that installation.

# **DESCRIPTION**

These errors are only reported when you point to an OpenAccess (OA) installation which is older than the tool version was built with. By default, tool will use the OA version in the tool installation unless the environment variable OA\_HOME is set to point to another OA installation. To resolve this issue, the recommendation is to use 'unsetenv OA\_HOME' so tool will use the local OA installation. Alternatively, set OA\_HOME to a compatible OA installation.

OA versions are signified using three sets of numbers separated by a period (i.e. XX.YY.ZZZ) or sometimes the third number is separated with a dash (i.e. XX.YY-ZZZ). OA versions are compatible if the first two sets of numbers are the same.

To determine what OA version an IC610 or tool installation was compiled with by going to http://downloads.cadence.com and clicking on the README or README.OA file. This is listed next to each release.

Error and Warning Messages

Overall, Cadence recommends you run your application with the version of OA that it was built, tested and shipped with. Otherwise, unforeseen compatibility issues may arise.

For example, any 22.04.abc version is compatible with any other 22.04.xyz version.

# **IMPOAX-148**

# **NAME**

IMPOAX-148

# **SUMMARY**

Error in getting path for %s/%s/%s. OA Exception : %s.

# **DESCRIPTION**

Check if you have permission to access the OpenAccess database.

# **IMPOAX-252**

### NAME

IMPOAX-252

Found busBit terminals of bus '%s' of cell '%s' without bus ordering information in OpenAccess library '%s'. There could be more such terminals without bus order information. This may lead to problems during write\_db. It is recommended to run verilogAnnotate on the library for annotating bus ordering information to such terminals.

## DESCRIPTION

The issue occurs because the bus ordering information for cell's busBit terminals is not present.

The OpenAccess (OA) libraries were created using lef2oa. LEF file contains no information about bus order of busBit terminals. When using this tool with OA, the bus ordering information must be annotated into the abstract using the verilogAnnotate utility.

To run verilogAnnotate for the cell to update the existing OA data with terminal ordering information from a Verilog file.

verilogAnnotate -refLibs libraryList -verilog fileList [Optional Arguments]

For example:

read db -oa lib cell view {lib cell view}

# If you only have the top level design netlist but no this cell's netlist, you need to generate leafOnly.v.

write netlist leafOnly.v -only leaf cells

# Make sure you have write permission to update the OA file

verilogAnnotate -refLibs library 1 -verilog leafOnly.v

exit

Error and Warning Messages

restart tool

read\_db -oa\_lib\_cell\_view {lib cell view}

connect\_pin ...

write db ...

The saved design will have the changes saved.

# **IMPOAX-332**

### NAME

IMPOAX-332

#### SUMMARY

Failed to initialize OpenAccess (OA) database. OA related commands cannot be run in this session. Confirm that the OA shared library is installed and OA\_HOME is set correctly. Typically the OA\_HOME environment variable should not be set.

# **DESCRIPTION**

The environment variable OA\_HOME should not typically be set as the correct OpenAccess shared library should be automatically loaded. If the OA\_HOME environment variable is set, confirm that it is set intentionally and unset it if not. If the requirement is to load a newer shared library, then confirm that the path name specified in OA\_HOME is correct.

Error and Warning Messages

Example:

Manual override of default shared library location:

setenv OA HOME /xx/xx/<tool name>/toolxxx/xx.xx/lnx86/oa vxx.4x

# **IMPOAX-335**

### NAME

IMPOAX-335

#### SUMMARY

Could not open technology data. Refer to any earlier error messages.

# **DESCRIPTION**

It is a common and generic error message that comes during init\_design or read\_db steps and may have numerous specific causes due to which the technology data is not being read. Check the warnings and errors above it in logfile to troubleshoot this error further.

# **IMPOAX-392**

# **NAME**

IMPOAX-392

# **SUMMARY**

Destination library '%s' already exists and is in correct state as it would be if created with the given command. If a new library is desired, then a different library name must be specified, otherwise use

the library that already exists.

#### DESCRIPTION

The library creation only works if a library with the specified name does not already exist in the cds.lib. So, if create\_oa\_lib indicates that the library already exists, then rerun the command with a different library name or remove the existing library from the cds.lib and disk before running the create\_oa\_lib command.

# **IMPOAX-433**

#### NAME

IMPOAX-433

#### SUMMARY

Saving design to (%s/%s/%s) which is using technology from lib '%s', doesn't contain any valid LEFDefaultRouteSpec. Aborting write db.

### **DESCRIPTION**

LEFDefaultRouteSpec could not be found, either by definition or by name in the technology. Please create an interoperable PDK before proceeding, test test.

if starting point is LEF file do:

1.Load the design into the tool

2.write\_oa\_techfile <filename>.tf

Error and Warning Messages

3.create OpenAccess lib using techLoadDump <filename>.tf

4.add place and route data to the lib from <filename>.lef using lef20a -pnrLibDataOnly.

if virtuoso PDK is already there do only step 4 mentioned above to create interoperable PDK.

# **IMPOAX-503**

#### NAME

IMPOAX-503

#### **SUMMARY**

Cannot open OpenAccess library '%s'. Make sure the library exists on disk and its entry is present correctly in the library definition file.

### **DESCRIPTION**

Why do I receive the error above when importing my design into tool?

This error indicates tool is unable to find an OpenAccess (OA) library.

For example, if your .globals file defines:

set init\_oa\_ref\_libs {oaLib1 oaLib2}

But your cds.lib (or lib.defs) file only defines oaLib1:

DEFINE oaLib1 ./oaLib1

Error and Warning Messages

Correct this by removing the reference for oaLib2 or specifying the path to oaLib2 in your cds.lib file:

DEFINE oaLib1 ./oaLib1

DEFINE oaLib2 ./oaLib2

Also, make sure you are not confusing the syntax for the cds.lib file and the lib.defs file. We recommend using a cds.lib file. Its syntax is:

**DEFINE libName libPath** 

If the error is preceded by the following warning then there is not a cds.lib file in the run directory to define the location of the libraries:

\*\*WARN: (IMPOAX-791): Error reading library definition file: No default library definition file found.

### **IMPOAX-571**

#### NAME

IMPOAX-571

#### **SUMMARY**

Property '%s' on %s %s is a hierarchical property which is not supported in %s. This property is not translated and it will be lost in round trip unless update\_mode is enabled.

### **DESCRIPTION**

Error and Warning Messages

Virtuoso and OpenAccess (OA) allow creation of hierarchical properties. For instance, value of a hierarchical property can itself be another hierarchical property. So there can be a multi-level tree of properties on a object in OA. "Multi-level tree like properties" are not supported and hence not read.

#### Example:

If the following setting is used, these properties are preserved on the original object, so when the design is saved, these properties are not lost:

set\_db -oa\_update\_mode true

If you want to preserve these properties, please use this setting.

### **IMPOAX-606**

#### NAME

IMPOAX-606

#### **SUMMARY**

Failed to add edge %s/%s - %s/%s to scan chain '%s'. The design being read from OpenAccess during read\_oa is out of sync with the design in memory. This scan chain contains logical instances which are not present in current design. So, some of the scan chain edges are not being created. Please read\_oa consistent desgin with current design.

#### **DESCRIPTION**

This message is issued when any logical instance in scan chain being read from OpenAccess during read oa is not present in current design. Adding additional logical instances may cause LVS

Error and Warning Messages

problem, scan chain edges with unknown logical instances will be dropped. Possibly, the design being read\_oa is out of sync with the restored DB. Please update the designs to be consistent with current design and read\_oa again.

### **IMPOAX-618**

#### NAME

**IMPOAX-618** 

#### SUMMARY

Custom via definition for via '%s' cannot be created in the technology database, because the technology database associated with library '%s' is readonly.

### DESCRIPTION

In the tool's Flow new vias may be created during

power routing. These are typically via arrays created from VIARULE GENERATE statements in the technology LEF. When saving the design to OpenAccess (write\_db or write\_oa) via definitions of these vias need to be added to the technology library if they cannot be defined in a parameterized form using standard vias from the OpenAccess technology file. To see if the via is defined in parameterized form, use write\_def to create a DEF file and look for vias in the VIAS section that are defined using the + RECT syntax instead of + VIARULE syntax.

If the vias cannot be represented by standard vias then a new custom via must be created which requires writing to a technology file. Therefore, you must have write permissions or allowed to do an incremental update of the technology library.

Error and Warning Messages

Since the technology database needs to be incrementally updated, the recommended method is to create

local technology database in design library either using 'create\_oa\_lib -oa\_reference\_tech\_libs' or 'set\_db

-oa lib create mode reference' option. For example:

create\_oa\_lib myLib -oa\_reference\_tech\_libs myRefLib

set init oa design lib myLib

Or

set db -oa lib create mode reference

Then define the place and route technology rules in myRefLib by importing a technology LEF. This creates a local technology database in the design library that can be modified incrementally. Overall, when setting up your mixed-signal design environment we recommend using a Base PDK which contains the base technology file and an incremental technology database (ITDB) which references the Base PDK. The ITDB contains the information for physical design and can be updated, while the Base PDK can remain read-only.

# **IMPOAX-683**

### **NAME**

IMPOAX-683

#### **SUMMARY**

Unable to find module terminal '%s' for module '%s' in '%s/%s/%s'. Connectivity cannot be maintained if the terminal does not exist for module.

#### **DESCRIPTION**

One of the possible reason can be - If the design is re-mastered from abstract views that were used by tool and layout views that can be used by verification tools, the re-mastered view does not have any terminals. The write\_oa -no\_connectivity option must be specified to be able to save the database. As the database will not have connectivity information it will not be able to be reloaded if no connectivity exists in the cellview that was written. A cellview created using the -no\_connectivity option is designed to be used with verification tools that do not need the OpenAccess database to contain connectivity information.

# **IMPOAX-684**

#### NAME

IMPOAX-684

#### SUMMARY

Cannot find definition of BUS Terminal '%s' of Cell '%s' in reference library. This could lead to further errors while saving the OpenAccess (OA) database. Possible reasons could be that verilogAnnotate was not run on the OA reference library that has the definition for this cell. Either run verilogAnnotate on the reference library to fix this problem or use command 'set\_db - oa\_allow\_bit\_connection true' before saving design to make bitwise connection of terminals.

### **DESCRIPTION**

The message is issued when saving a design to OpenAccess (OA) by running

**Error and Warning Messages** 

write\_db. The OA libraries were created using lef2oa.

When using tool with OA, the bus pin order must be annotated into the abstract using the verilogAnnotate utility. This step is done after importing the LEF macro data and prior to running write\_db.

Failure to complete this step on macros with the bus pins causes tool to

#### Example:

To prevent this warning, a Verilog stub file is needed for each macro with bus pins. This might be derived from the symbol view using the 'Create-Cellview-From' in Cellview menu command. Once you have a stub file for each macro which has bus pins run verilogAnnotate at the Linux command line using the following steps:

\$CDSHOME/share/oa/bin/verilogAnnotate \

-refLibs reference\_library\_name \

display this warning message.

-verilog stub.v

where, stub.v contains the module definitions with only port list, input/output direction and bus definitions of the referenced blocks.

Alternatively, you can set "set\_db -oa\_allow\_bit\_connection true" prior to write\_db in place of running verilogAnnotate.

# **IMPOAX-720**

#### NAME

IMPOAX-720

#### SUMMARY

The layer '%s' has inconsistent preferred routing direction. Check the layer information in OpenAccess technology database.

#### DESCRIPTION

This message is issued when the Open Access (OA) technology is read in and consecutive layers have the same preferred direction. In some technologies Metal1 and Metal2 will both be horizontal to allow for power rails on both layers.

Example:

Example OpenAccess technology file where Metal1 and Metal2 are both horizontal:

```
routingDirections(
;( layer direction )
;( ----- )
( Metal1 "horizontal" )
( Metal2 "horizontal" )
( Metal3 "vertical" )
( Metal4 "horizontal" )
( Metal5 "vertical" )
```

Error and Warning Messages

```
( Metal6 "horizontal" )
( Metal7 "vertical" )
( Metal8 "horizontal" )
( Metal9 "vertical" )
) ;routingDirections
```

# **IMPOAX-745**

#### NAME

IMPOAX-745

#### **SUMMARY**

Cell '%s' from cellview '%s' has already been read in from '%s'. The cell can only be read once, so the second version will be ignored. Review the value of the init\_oa\_ref\_libs variable and update to remove the library that has the copy of the cell that should not be read.

#### DESCRIPTION

Each library cell can only be read once. In the case where the same cell is found in multiple libraries, the first one read being will be the one that is used to create the cell data within software. The library cells are read based on the settings of the init\_oa\_ref\_libs and init\_oa\_abstract\_views variables. Anytime a library cell is found in multiple libraries, that is likely not intended and the values variables should be updated to prevent the duplicate cell from being found.

# **IMPOAX-750**

#### NAME

IMPOAX-750

#### SUMMARY

Tech site '%s' used in macro '%s' is not found. Check if this macro in OpenAccess (OA) database has correct site information, and if the site is defined in OA technology database.

#### **DESCRIPTION**

Standard cells (CLASS CORE) require sites to be placed properly. If no site definition is found then the cell cannot be legally placed. Either the site definition is missing from the library that contains the standard cells or another library that contains the site definition was not included in the init\_oa\_ref\_libs variable's reference library list.

If the site was missing from the library that contains the standard cells, modify the <technology file>.tf (ASCII technology file) file used in Virtuoso and compile again your technology library in Virtuoso.

Please follow these steps:

- Look for the following "SITEDEFS" and modify like this:

Error and Warning Messages

| ;SITEDEFS                                                                                      |
|------------------------------------------------------------------------------------------------|
| .*************************************                                                         |
| siteDefs(                                                                                      |
| scalarSiteDefs(                                                                                |
| ;( siteDefName type width height symInX symInY symInR90)                                       |
| ;()                                                                                            |
| ( CoreSite core 0.512 5.12 t nil nil)                                                          |
| ) ;scalarSiteDefs                                                                              |
|                                                                                                |
| ) ;siteDefs                                                                                    |
| - If you modified the technology file, please re-compile the technology file to OpenAccess DB. |

# **IMPOAX-755**

### **NAME**

**IMPOAX-755** 

Error and Warning Messages

#### **SUMMARY**

Macro '%s' has no SITE statement and it is a class CORE macro that requires a SITE statement. The SITE %s is chosen because it is a core site with height %.4f that matches the macro SIZE height.

#### DESCRIPTION

This message indicates this cell is defined with CLASS CORE which means it is a standard cell. Standard cells require a SITE to be defined for them. In a floorplan, rows are created which are made of SITES which define the placement grid for standard cells. The placer must know what SITE each standard cell is allowed to use. If a SITE is not defined for a standard cell,tool will try to find a SITE with the same height and use that. To specify the correct SITE, open the Abstract view in Virtuoso and display the cells properties. At the bottom of the Attributes it will have Site Definition where you can select the cor- rect site. If you created your Open Access (OA) library from LEF you can add the SITE name to the MACRO definition and re-import the LEF into OpenAccess.

This message indicates this cell is defined with CLASS CORE which means it is a standard cell. Standard cells require a SITE to be defined for them.

```
MACRO FILL8
CLASS CORE;
FOREIGN FILL8 0 0;
ORIGIN 0.0000 0.0000;
SIZE 1.2 BY 1.71;
SYMMETRY X Y;
SITE CoreSite;
```

# **IMPOAX-757**

### **NAME**

IMPOAX-757

### **SUMMARY**

Can not find sitePattern '%s' for macro '%s' in %s database. Check if the site is defined correctly in OpenAccess technology database.

### **DESCRIPTION**

This message indicates that a cell (typically an abstract view) for example, 'DEL1' has SITE coreABC specified but that the site is not defined in the technology file. An equivalent LEF representation would be:

| MACRO DEL1   |  |  |
|--------------|--|--|
|              |  |  |
|              |  |  |
| SITE coreABC |  |  |
|              |  |  |
|              |  |  |

March 2020 446 Product Version 20.10

Error and Warning Messages

Verify if the SITE name is correct, then verify its definition. This can be verified by dumping out the technology file by Virtuoso. The SITE information is defined in the scalarSiteDefs section of the technology file, or export a LEF file using oa2lef and search for the site with the given name. Below are examples of site definitions in the open access technology file and in LEF file.

| In OpenAccess technology File                           |
|---------------------------------------------------------|
| scalarSiteDefs(                                         |
| ( siteDefName type width height symInX symInY symInR90) |
| ;()                                                     |
| (coreABC core 0.5 5.0 nil nil nil)                      |
| ) ;scalarSiteDefs                                       |
| In LEF file                                             |
| SITE coreABC                                            |
| CLASS CORE                                              |
| SIZE 0.5 BY 5.0                                         |
| FND coreABC                                             |

March 2020 447 Product Version 20.10

# **IMPOAX-773**

#### NAME

IMPOAX-773

#### SUMMARY

Pin '%s' in macro '%s' has no ANTENNAGATEAREA value defined. The library data is incomplete and some process antenna rules will not be checked correctly.

#### **DESCRIPTION**

This warning is triggered when the technology data has process antenna rules, and a signal pin is missing process antenna data needed to check the rules. In this case, a signal pin that is either an input or inout pin is missing the gate-area data.

In CMOS, every signal pin that is an input or inout pin connects to a transistor gate. If there is no gate-area associated with this pin, then the library data is incomplete and process antenna rules cannot be checked for this pin correctly. The router and verification commands will assume this pin has no transistor gate attached, and therefore does not need to be protected from process antenna violations, which may result in real violations that are not fixed by the router or seen by the verification commands.

The best way to avoid this warning is to add the correct antenna gate- area data to the library data.

Error and Warning Messages

You can also use the set message -suppress command to turn off this warning message.

This might be appropriate if you know the only library cells without antenna data are already protected by internal diode cells (e.g. some blocks might be built this way). In that case, you would lose the possible benefit of those internal diode cells for any nets connected to the block input, which might cause the router to add some unnecessary diode cells to protect other inputs attached to the same net. This is somewhat dangerous, because you might suppress messages for pins that are not protected.

You can also turn off the warning if you believe antenna errors are rare for these pins in practice, and you will depend on final sign-off physical verification tools to find any errors, and repair them manually.

### **IMPOAX-774**

#### NAME

IMPOAX-774

#### SUMMARY

Pin '%s' in macro '%s' has no ANTENNADIFFAREA value defined. The library data is incomplete and some process antenna rules will not be checked correctly.

#### DESCRIPTION

This warning is triggered when the technology data has process antenna rules, and a signal pin is missing process antenna data needed to check the rules. In this case, a signal pin that is either an output or inout pin is missing the diffusion-area data.

In CMOS, every signal pin that is an output or inout pin connects to a transistor diffusion. If there is no diffusion-area associated with this pin, then the library data is incomplete and process antenna

Error and Warning Messages

rules cannot be checked for this pin correctly. In that case, the router may try to protect other input pins connected to the same net with extra routing and vias ('layer-hopping'), or add extra diode cells to avoid 'false' antenna violations. The verification commands may flag false violations also.

The best way to avoid this warning is to add the correct antenna diffusion-area data to the library data.

You can also use the set\_message -suppress command to turn off this warning message. This might be appropriate if you know that antenna violations are rare in this technology, and you are willing to tolerate some extra layer-hopping, or extra diode cells that are not really necessary.

### **IMPOAX-923**

### **NAME**

IMPOAX-923

#### **SUMMARY**

Found unsupported shape with type '%s' in the OpenAccess (OA) database. The shape has bounding box co-ordinates from (%.11g,%.11g) to (%.11g,%.11g) and is on layer '%s'. In non-update mode these shapes will be lost in round trip. However, in update mode these shapes will be preserved in the OA database.

#### DESCRIPTION

When text information is attached to pin shapes, a warning like the following will appear.

\*\*WARN: (IMPOAX-923): Found shape with unsupported type 'AttrDisplay' in the OpenAccess (OA) database. The shape has bounding box co-ordinates from (1063.911,1022.813) to (1064.826,1029.3) and it is lying on layer 'PIN'. In non-update mode these

Error and Warning Messages

shapes will be lost in round trip. However, in update mode these shapes will be preserved in the OA database.

First, follow all the settings required for Virtuoso and this tool interoperability as explained in the Mixed-Signal Interoperability Guide. For this specific message make sure "set db -oa update mode true" is set.

The reason in this case for the "\*\*WARN: (IMPOAX-923):" is that shapes with unsupported types like "AttrDisplay", "Arc", "Dot" and "Line" are not read in OA DB. These object types should not be used in OA DB intended for interoperability with tool.

### **IMPOAX-931**

#### NAME

IMPOAX-931

#### SUMMARY

Found Pcell vias/instances in the design but Express Pcells are not enabled (Environment variable CDS\_ENABLE\_EXP\_PCELL is not defined). Layout data for the pcell instances cannot be read from the pcell cache directory. Enable Express Pcells in the environment and retry.

### **DESCRIPTION**

The error above is reported when importing an OpenAccess (OA) design from Virtuoso to tool that contains Pcells. When I open the design in tool the Pcells are not the proper size. What setup is required to transfer the Pcells properly?

Error and Warning Messages

Prior to saving the design to OA in Virtuoso, make sure the following is done:

1. At the Linux prompt set the following:

setenv CDS ENABLE EXP PCELL true

setenv CDS\_EXP\_PCELL\_DIR ./.expressPcells

- 2. Invoke Virtuoso and open the design. Note in Virtuoso versions before IC6.1.4.500.1 VLS-XL or VLS-GXL is required to save the express PCell cache. In IC6.1.4.500.1 and later version all Virtuoso products support this.
- 3. Select Tools->Express Pcell Manager. Fill out all the details and Enable Caching of the Pcells check box with Auto Save option. Press Save Copy to save the Pcell Layout Cache. This step is necessary to enable inter-operation of the data between this tool and Virtuoso.
- 4. Save the design to OA and exit Virtuoso.
- 5. Prior to invoking tool set the following:

setenv CDS ENABLE EXP PCELL true

setenv CDS\_EXP\_PCELL\_DIR ./.expressPcells

# **IMPOAX-956**

#### NAME

**IMPOAX-956** 

#### **SUMMARY**

While annotating the placement data from %s/%s/%s, the logical instance '%s' was not found in the OpenAccess (OA) design. One reason for this could be that logical netlist data read during init\_design is different from the OA cellview's embedded module hierarchy (EMH) data created from a previously read OA design. The OA database used to read physical information should be consistent with the verilog file or the OA database used for reading logical netlist.

#### DESCRIPTION

This message comes when any instance being read from OpenAccess (OA) during read\_oa process is

not present in FEDB.

If you are planning to merge floorplan data from OA to tool or incrementally loading the floorplan data then read\_oa has a new option "-filter {boundary pin\_shapes}" that tells tool to read only the information specified, and ignore any mismatches. So for example, if you used -filter pin\_shapes, any existing pin shapes would be replaced by the ones read from the OA cellview. Please refer the documentation for more details.

If you are using a prior version of tool than 13.2, the -filter option isn't available and a workaround is required:

1)load the config file in tool.

2)save OA design

Error and Warning Messages

- 3)Load the design in Virtuoso Layout-XL
- 4)File->Load Physical View (Be sure to load the pins in "update" mode)
- 5)Save the new/updated design
- 6)Restore this design in tool and continue with the P&R flow.

# **IMPOAX-986**

#### **NAME**

IMPOAX-986

#### **SUMMARY**

%s can't support a MUSTJOIN terminal in bus bit format." "The terminal '%s' is renamed to '%s'.

#### **DESCRIPTION**

Loading LEF with below MUSTJOIN definition in the LEF issues IMPOAX-986 warning in OpenAccess based flow. The reason for this warning is that master pins can be a bus bit, but the slave cannot. Only pins that exist in the logical netlist can be bus bits.

The P/G and MUSTJOIN terminals (physical side only) cannot be bus bits.

| Example :   |        |       |
|-------------|--------|-------|
|             | ====== | ===== |
| PIN pad_mj1 |        |       |

# Innovus Stylus Common UI Error Message Reference Error and Warning Messages

| DIRECTION INPUT ;         |
|---------------------------|
| USE SIGNAL ;              |
| PORT                      |
| LAYER Metal2 ;            |
| RECT 2.97 4.3 3.53 4.72 ; |
| END                       |
| END pad_mj1               |
| PIN pad[1]                |
| DIRECTION INPUT ;         |
| USE SIGNAL ;              |
| MUSTJOIN pad_mj2;         |
| PORT                      |
| LAYER Metal2 ;            |
| RECT 2.92 1.3 3.48 0.72 ; |

Error and Warning Messages

| ΕI | V | D |
|----|---|---|
|----|---|---|

END pad[1]

-----

In the above example

PIN pad[1] # this is not allowed, needs to be a simple name like pad\_1

MUSTJOIN pad\_mj2;

# IMPOAX-1017

### NAME

IMPOAX-1017

#### SUMMARY

Creating a database with the '-no\_connectivity' option will result in a database that cannot be read back into %s.

#### DESCRIPTION

The OpenAccess database created with '-no\_connectivity' option will not contain any nets, terms and instterms. The design created with this option will contain only physical shapes. This type of database is for use with tools that do not require connectivity in the database.

Some 'layout' views may not contain terminals and if the design references any

Error and Warning Messages

cells that will be bound to those cellViews, then the '-no\_connectivity' option should be specified.

By default, 'write\_oa' will maintain connectivity, but that requires that terminals to exist on all cellViews that referenced from the instances within the design.

# **IMPOAX-1034**

### **NAME**

IMPOAX-1034

#### SUMMARY

Cannot open report file %s.oaread.rpt for writing. Check if you have correct permissions to write into this file.

### **DESCRIPTION**

You have this message because you may not have write permission on current working directory or have run out of disk space.

Example:

Check if you have permission on current working directory:

20> file writable [pwd]

1

Check if you have necessary disk space:

Error and Warning Messages

16> df -kH [pwd]

Filesystem Size Used Avail Use% Mounted on

/disk/subDirectory/case/case11189 2.2T 2.0T 271G 88%

/disk/subDirectory/case/case11189

# **IMPOAX-1050**

#### NAME

IMPOAX-1050

#### **SUMMARY**

Type of trim layer '%s' is not identified as TRIMPOLY/TRIMMETAL layer. Tool only supports TRIMPOLY and TRIMMETAL layers. This layer will be read as MASTERSLICE layer.

### **DESCRIPTION**

Either the layer is missing trim function or it belongs to diffusion/substrate cutting. You can use "techLoadDump -d <libName> <technology file name>" to check the technology.

### **IMPOAX-1092**

#### **NAME**

IMPOAX-1092

#### SUMMARY

Logical instance '%s' of cell '%s' cannot be created in the OpenAccess database. It could be a problem in EMH (Embedded Module Hierarchy) data creation. Refer to any earlier error messages. Confirm that cell '%s' exists in the reference libraries.

#### DESCRIPTION

When attempting to save an OpenAccess database, the tool gives above error messages and does not save the design.

What is the reason for tool giving above error messages?

This problem occurs if the reference library attached to the design library is not present in the cds.lib or path to access this library is incorrect.

Please check your cds.lib file and correct the path. If the paths are correct, then you need to check that you have defined following variables before saving your design:

set init oa design lib TEST

set init oa design cell row dec

set init oa ref libs gsclib090

set init\_oa\_design\_view layout

set init oa abstract views abstract

set init\_oa\_layout\_views layout

# **IMPOAX-1151**

#### NAME

IMPOAX-1151

#### SUMMARY

Non-leaf cell %s will be treated as a leaf cell.

#### **DESCRIPTION**

Non-leaf cells are determined by LEF MACRO and dotlib definitions. If this is a hierarchical design, remove LEFs and dotlibs for flattened partitions. These are referenced in <design>.globals, viewDefinition.tcl, and tcl scripts with init\_design. Ignoring this message can result in unexpected results when restoring a saved OpenAccess database.

# **IMPOAX-1255**

#### NAME

IMPOAX-1255

#### SUMMARY

No VIARULE GENERATE statement between routing layers '%s' and '%s' while reading technology information from the library.

#### DESCRIPTION

VIARULE GENERATE (standardViaDef from technology database) defines formulas for generating via arrays. User can use the VIARULE GENERATE statement to cover special wiring that is not explicitly defined in the VIARULE statement.

Rather than specifying a list of vias for the situation, you can create a

Error and Warning Messages

| ormula to specify | how to generate the cut | layer geometries. |
|-------------------|-------------------------|-------------------|
|-------------------|-------------------------|-------------------|

Example:

The following example describes a formula for generating via cuts:

VIARULE via12 GENERATE

LAYER m1;

ENCLOSURE 0.05 0.01; #2 sides must be >=0.05, 2 other sides must be >=0.01

WIDTH 0.2 TO 100.0; #(optional)for m1, between 0.2 to 100 microns wide

LAYER m2;

ENCLOSURE 0.05 0.01 ; #2 sides must be >=0.05, 2 other sides must be >=0.01

WIDTH 0.2 TO 100.0; #(optional)for m2, between 0.2 to 100 microns wide

LAYER cut12

RECT -0.07 -0.07 0.07 0.07 ; #cut is .14 by .14

SPACING 0.30 BY 0.30; #center-to-center spacing

END via12

### **IMPOAX-1257**

#### NAME

IMPOAX-1257

#### **SUMMARY**

Allowing write\_db to create OpenAccess (OA) based reference library data on-the-fly is not recommended.

#### **DESCRIPTION**

Allowing write\_db to create OpenAccess (OA) based reference library data (FEOAreflib) on-the-fly can result in multiple copies of reference library information as well as increase the run time of the write\_db process. Externally translating the LEF information into OA reference libraries is recommended using lef2oa/verilogAnnotate or LEF-to-OA migration scripts.

# **IMPOAX-1265**

### **NAME**

IMPOAX-1265

### **SUMMARY**

Some of the library data inside '%s %s %s' has data on invalid layers %s that will be ignored.

### **DESCRIPTION**

Error and Warning Messages

This is most likely because the OpenAccess technology has multiple metal-stack options and the init\_oa\_extractor\_setup that defines the valid layers for this design was not set correctly. See the init\_design Tcl documentation for more details. In some methodologies this is allowed, in which case you should add (set\_message -suppress 1265) to turn off these warnings.

# **IMPOAX-1266**

#### NAME

IMPOAX-1266

### **SUMMARY**

Some of the library data inside cell "%s" has data on invalid layer "%s" that will be ignored.

#### DESCRIPTION

This is most likely because the OpenAccess technology has multiple metal-stack options and the init\_oa\_extractor\_setup that defines the valid-layers for this design was not set correctly. See the init\_design Tcl documentation for more details. In some methodologies this is allowed, in which case you should add (set\_message -suppress 1266) to turn off these warnings.

# **IMPOAX-1274**

### **NAME**

IMPOAX-1274

### **SUMMARY**

Terminal %s is not on the interface of cell %s, the OpenAccess (OA) cellview terminal's isInterface bit is set to false. Logical connectivity of this terminal to corresponding net may get lost upon reading the data. In order to fix the problem, either run the VerilogAnnotate command on the layout view of the cell or recreate the reference libraries with interface bit set for this terminal.

#### DESCRIPTION

The issue occurs because the mentioned bit is not on the interface of the cell. The isInterface bit is meant to align to the

Verilog modules. So, if a OpenAccess abstract terminal has isInterface = nil, that means that it should not appear in the Verilog netlist when running write\_netlist unless the -include\_pg\_ports or -phys options are used. Terminals with isInterface = nil should only be connected to a USE POWER/GROUND net, not a regular signal net. Assuming that the Verilog module (and .lib) has port, then running verilogAnnotate will set the bit on the abstract's terminal to true instead of nil.

To run verilogAnnotate:

verilogAnnotate -refLibs libraryList -verilog fileList [Optional Arguments]

Example:

read db -oa lib\_cell\_view {lib cell view}

# If you only have the top level design netlist but no this cell's netlist, you need to generate leafOnly.v.

write netlist leafOnly.v -only leaf cells

# Make sure you have write permission to update the OpenAccess database

verilogAnnotate -refLibs library\_1 -verilog leafOnly.v

Error and Warning Messages

exit
restart tool
read\_db -oa\_lib\_cell\_view {lib cell view}
connect\_pin ...
write\_db ...

The saved design will have the changes saved.

# **IMPOAX-1275**

#### NAME

IMPOAX-1275

#### SUMMARY

Interface bit for term %s of instance %s is not set. Dropping connection of this terminal with its corresponding net %s. In order to fix the problem, set the interface bit for these terminals in the reference libraries and recreate the OpenAccess database.

### **DESCRIPTION**

The issue occurs because the mentioned bit is not on the interface of the cell. The isInterface bit is meant to align to the Verilog modules. So, if a OpenAccess abstract terminal has isInterface = nil, that means that it should not appear in the Verilog netlist when running write\_netlist unless the -includePowerGround or -phys options are used. Terminals with isInterface = nil should only be connected to a USE POWER/GROUND net, not a

Error and Warning Messages

| regular signal net. Assuming that the Verilog module (and .lib) has port, then |
|--------------------------------------------------------------------------------|
| running verilogAnnotate will set the bit on the abstract's terminal to true    |
| instead of nil.                                                                |

To run verilogAnnotate:

verilogAnnotate -refLibs libraryList -verilog fileList [Optional Arguments]

Example:

read\_db -oa\_lib\_cell\_view {lib cell view}

# If you only have the top level design netlist but no this cell's netlist, you need to generate leafOnly.v.

write\_netlist leafOnly.v -only\_leaf\_cells

# Make sure you have write permission to update the OpenAccess file

verilogAnnotate -refLibs library\_1 -verilog leafOnly.v

exit

restart tool

read\_db -oa\_lib\_cell\_view {lib cell view}

connect\_pin ...

write\_db ...

The saved design will have the changes saved.

### **IMPOAX-1307**

#### NAME

IMPOAX-1307

#### **SUMMARY**

Via definition for std via '%s' is not found in the OpenAccess (OA) technology database associated with the design. Possible reason could be that this design has been read or created using a different OA technology database or LEF and these two database are out of sync. This serious issue should be fixed before proceeding further. To save the design, %s is creating custom via definition in current OA technology database for the std via '%s'.

### **DESCRIPTION**

If a VIA in the tool database is parameterized and refers to a LEF rule VIARULE .. GENERATE, then write\_oa will expect a matching (by name) oaStdViaDef to use for the parameterized via. If the oaStdViaDef is not found, then a fixed via (oaCustomViaDef) will be created instead which means that the parameterized form is lost in the roundtrip (write\_oa -> OpenAccess (OA) -> read\_oa).

If the creation succeeds and the user doesn't need the Vias remain parameterized, the message can be ignored.

If the user would want to have the Vias remain parameterized, they should compare their "technology" data to see why the oaStdViaDef name does not match the LEF VIARULE GENERATE name.

# **IMPOAX-1313**

#### NAME

IMPOAX-1313

#### **SUMMARY**

The library '%s' has its data compression level set to '%d', while the compression level for this %s session is %d. Any new data being saved into this library will be saved with its compression settings, irrespective of the global value.

#### **DESCRIPTION**

When user brings a design from virtuoso and save it, tool gives following warning message:

In OpenAccess data model 4, you have an option to compress the library and save it. By default, virtuoso saves design in uncompressed mode, whereas, tool saves in compressed mode. So when you open a design initialized in virtuoso and save it in, you will get this warning message. To change compression level in tool use command

set\_db -oa\_new\_lib\_compress\_level 0

Virtuoso IC 616 and tool version 11.1 and above can read and save compressed design library.

However, IC 615 cannot handle the compressed design.

Therefore you need to run oazip -decompress before restoring compressed design in virtuoso 615.

# **IMPOAX-1609**

#### NAME

IMPOAX-1609

#### **SUMMARY**

pull\_pin\_constraint is unable to pull pin constraint from cell '%s' because it has no layout cellview bound to it. If the cell is bound to abstract cellview, use option -cellview to specify the 'lib cell view' name for pull pin constraint to find the target layout cellview.

#### **DESCRIPTION**

When any of the options (-cell, -inst or -all\_blocks) is specified, this command pulls the pin constraints from the layout cellview that is bound to the cell(s). This error is displayed when there is no layout cellview bound to the cell itself. One possibility could be that the master cellview of the cell is an abstract cell and tool can't find its corresponding layout cellview. In such case, by default, tool expects the view name of the layout cellview to be 'layout' and its location to be under the same library/cell directory as the abstract cellview. Use the option -cellview to specify the 'lib cell view' name for pull\_pin\_constraint to find the target layout cellview.

### **IMPOAX-1625**

#### **NAME**

IMPOAX-1625

### **SUMMARY**

The tech graph in '%s' is different from the library '%s' which was used to create the %s technology information. This can result in problems during the save process if the vias, layer rules, etc are different in the two cases. The simplest solution to the problem is to have the '%s' reference the refLib of current design for technology information. To create a new library, use create\_oa\_lib with the -oa\_reference\_tech\_libs option.

#### DESCRIPTION

The technology information in the design library that the cellview is being saved into must be the same as the original library technology that was used to create the in session technology information.

You need to set this library as design library so that tool understands the hierarchy library/cell/view.

To set the library as design library use following command

set init\_oa\_design\_lib "test1"

After this setting, tool will not give the warning message (IMPOAX-1625) during write db.

### Example:

\*\*WARN: (IMPOAX-1625): The tech graph in 'designLibOA' is different from the library 'ref\_lib' which was used to create the technology information. This can result in problems during the save process if the vias, layer rules, etc are different in the two cases. The simplest solution to the problem is to have the 'designLibOA' reference the refLib of current design for technology information. To create a new library, use create\_oa\_lib with the -oa reference tech libs option.

In the globals file used to invoke the design, you have following entries

# Innovus Stylus Common UI Error Message Reference Error and Warning Messages

| set oareflib "tech1"                                                                                        |
|-------------------------------------------------------------------------------------------------------------|
| set DATA_DIR "./inputs"                                                                                     |
| set init_netlist_files "\${DATA_DIR}/conf.v"                                                                |
| set init_top_cell sar10b_v2                                                                                 |
| set init_oa_ref_libs \$oareflib                                                                             |
| +++++++++++++++++++++++++++++++++++++++                                                                     |
| After that you create a library called "test1", in which you will be saving the design after placement etc. |
| You need to set this library as design library so that tool understands the hierarchy library/cell/view.    |
| To set the library as design library use following command                                                  |
| set init_oa_design_lib "test1"                                                                              |
| After this setting, tool will not give the warning message (IMPOAX-1625) during write_db.                   |
|                                                                                                             |

# **IMPOAX-1751**

#### NAME

IMPOAX-1751

#### SUMMARY

The WSP purpose '%s' specified by user through 'set\_db -oa\_wsspd\_purpose' is not found in OpenAccess technology. default global WSP will be read from cellview or technology.

#### **DESCRIPTION**

Tool reads WSP with purpose either specified through 'set\_db -oa\_wsspd\_purpose' or read default WSP. Make sure either you provide correct purpose or default WSP will be read.

# **IMPOAX-1753**

#### NAME

IMPOAX-1753

#### **SUMMARY**

WSPs can not be saved in OpenAccess database. We can not create purpose '%s' in technology, because the technology database associated with library '%s' is readonly.

### **DESCRIPTION**

Since the technology database needs to be incrementally updated, the recommended method is to create

local technology database in design library either using 'create\_oa\_lib -oa\_reference\_tech\_libs' or 'set\_db

-oa lib create mode reference' option. For example:

Error and Warning Messages

create\_oa\_lib myLib -oa\_reference\_tech\_libs myRefLib

set init oa design lib myLib

Or

set db -oa lib create mode reference

Then define the place and route technology rules in myRefLib by importing a technology LEF. This creates a local technology database in the design library that can be modified incrementally. Overall, when setting up your mixed-signal design environment we recommend using a Base PDK which contains the base technology file and an incremental technology database (ITDB) which references the Base PDK. The ITDB contains the information for physical design and can be updated, while the Base PDK can remain read-only.

### **IMPOAX-5110**

#### NAME

IMPOAX-5110

#### SUMMARY

Default Rule '%s' is not found in the technology library (%s). The default rule was specified using the global variable init\_oa\_default\_rule, check the spelling to confirm that constraint group exists in the technology library. Either correct the init\_oa\_default\_rule specification or update the technology library to contain a valid LEFDefaultRouteSpec.

### **DESCRIPTION**

This error is caused by a missing LEFDefaultRouteSpec or not properly referencing the library which defines the LEFDefaultRouteSpec. To debug this do the following.

First, use Virtuoso to output an ascii version of the technology file from the ITDB (techLoadDump -d gsclib090 output.ascii). It should contain a LEFDefaultRouteSpec constraint group as shown below. This defines the rules for physical design:

| ;( group [override] )           |
|---------------------------------|
| ;( )                            |
| ("LEFDefaultRouteSpec" nil      |
|                                 |
| spacings(                       |
| ( minWidth "Cont" 0.12 )        |
| ) ;spacings                     |
|                                 |
| routingGrids(                   |
| (horizontalPitch "Metal1" 0.29) |

# Innovus Stylus Common UI Error Message Reference Error and Warning Messages

| (verticalPitch "Metal1" 0.29)                                                                              |
|------------------------------------------------------------------------------------------------------------|
| ( horizontalOffset "Metal1" 0.145 )                                                                        |
| ( verticalOffset "Metal1" 0.145 )                                                                          |
| ) ;routingGrids                                                                                            |
|                                                                                                            |
| Also, verify it references the base technology file. For example, you can see it references gpdk090 below: |
| controls(                                                                                                  |
| techVersion("1.0")                                                                                         |
| refTechLibs(                                                                                               |
| ; techLibName                                                                                              |
| ;                                                                                                          |
| "gpdk090"                                                                                                  |

Error and Warning Messages

) ;refTechLibs

);controls

Lastly, when reading the design into tool, make sure you specify the OpenAccess reference library:

In \*.global file:

set init\_oa\_ref\_libs {gsclib090}

# **IMPOAX-6022**

#### NAME

IMPOAX-6022

### **SUMMARY**

The value 'VCE' for the oa view sub type argument is obsolete.

#### **DESCRIPTION**

The value 'VCE' for the oa\_view\_sub\_type argument is no longer supported. To avoid this warning and to ensure compatibility with future releases, update your script to use 'oa\_view\_sub\_type VXL'.

# **IMPOAX-6024**

#### NAME

IMPOAX-6024

#### **SUMMARY**

Error while %s %s. OA Exception: %s.

#### **DESCRIPTION**

This error often happens when you try to write an OpenAccess view while design is open in other session or Virtuoso, thus the database is locked. Use different view name or close other session or Virtuoso that open the same view.

# **IMPOGDS-391**

#### NAME

**IMPOGDS-391** 

#### SUMMARY

Line %d: Object Type '%s' specified with layer '%s' is not legal. The map file maybe being a DFII/Virtuoso map file. For a list of legal object types refer to the map file syntax in the User Guide.

#### **DESCRIPTION**

This error can occur due to the wrong layer Map file or the incorrect inputs specified to the StreamOut command. To resolve this warning, try few things:

- 1. Use the supported layer map file from the foundry.
- 2. Generate the generic layer map file from the Innovus.

Note: A generic mapping file from Innovus can be generated by running streamOut command

Error and Warning Messages

without specifying a mapping file. It will create a generic map file named streamOut.map which you can then edit to map the layers to the required GDS layers.

# **IMPOGDS-392**

#### NAME

IMPOGDS-392

#### **SUMMARY**

Unknown layer %s

#### DESCRIPTION

This message is triggered during command write\_stream <filename> -map\_file <string> . If in the specified map file a layer name is used that is not known from the LAYER statement of the LEF (or the respective the OA) technology file or GUI customer layer, then this warning is issued.

### **IMPOGDS-399**

### **NAME**

IMPOGDS-399

#### SUMMARY

Only %d layer(s) (%s) of a %s object is(are) specified in map file '%s'. A %s object needs 3 layers (%s %s %s) being specified at the same time in the map file. Add %s contruct(s) to the map file for the following layer(s): %s or remove %s construct(s) from the map file for the following layer(s): %s.

#### **DESCRIPTION**

While streaming out GDS, innovus write\_stream reports the message. write\_stream uses the object type VIA to map the bottom, top and via layer of via cells to GDS. So the map file must define VIA

object types for all metal and via layers.

### **IMPOPT-132**

#### NAME

IMPOPT-132

#### SUMMARY

Inverter '%s' was not deleted because it is not part of a back-to-back inverter pair, or because it is not possible to delete the inverter(s) due to fixed/dont touch attributes.

#### **DESCRIPTION**

eco\_delete\_repeater can only delete inverters in back-to-back pairs. This message occurs when the user has specified an inverter to be deleted, but a second inverter as part of a back-to-back inverter pair could not be found in the design, or any/both of the inverters have fixed/dont\_touch attributes. Please refer to the documentation for eco\_delete\_repeater for more information.

### **IMPOPT-136**

#### NAME

IMPOPT-136

#### **SUMMARY**

Cell '%s' does not exist in power domain '%s'.

#### DESCRIPTION

Possible reasons are :-

1. View definition does not bound the timing libraries containing this cell to this power domain.

Error and Warning Messages

2. CPF does not bound the timing libraries containing this cell to this power domain.

Use update\_delay\_corner command or modify CPF to update the timing libraries of this power domain.

# **IMPOPT-306**

#### NAME

IMPOPT-306

#### **SUMMARY**

Found placement violations in the postRoute mode.

#### **DESCRIPTION**

This warning is issued when the tool while checking placement detects any placement violations during postRoute optimization flow.

In order to fix this issue the user needs to run 'check\_place' command and correct all placement violations in specific and also it is advisable to correct the other remaining violations in general before proceeding further.

# **IMPOPT-310**

#### **NAME**

IMPOPT-310

#### **SUMMARY**

Design density (%.2f%%) exceeds/equals limit (%.2f%%).

### **DESCRIPTION**

Error and Warning Messages

This error comes when Design Global density exceeds the default or user limit. User can get rid of this error depending upon design stage.

- 1. If this error message comes during preCTS then most likely either the die area needs to increase or user needs to look at improving the placement in design.
- 2. If this error message comes during CTS (or postCTS) then quality of Clock Tree needs to be debugged specially if density increases a lot from preCTS to postCTS.
- 3. If this error message comes during postRoute user should specify list of Fillers and Decaps before optimization. This will ensure that opt\_design swap filler/decap cells with other cells and do not use filler/decap cells during global density calculation.

### **IMPOPT-393**

#### NAME

IMPOPT-393

#### SUMMARY

No noise libraries are specified, timing libraries will be used instead in order to perform the noise analysis which are not as accurate. To load the noise libraries use the 'create\_library\_set/update\_library\_set -si' command.

#### DESCRIPTION

#### Example:

An example of how to use the commands:

create\_library\_set -name IsCOM-1V \\

-timing [list stdcell F 1V.lib ram F.lib pad.lib] \\

-si [list stdcell F 2.cdb ram F.cdb pad.cdb]

update library set -name minLibs \\

-si {stdcell CVF 1V.lib ram CVF.lib pad.lib}

#### NAME

IMPOPT-519

#### SUMMARY

No cells matching pattern '%s' were found.

### **DESCRIPTION**

The set\_opt\_dont\_use command could not find any cells matching the specified cell name pattern. Please check and correct the pattern.

Example:

The following example sets all library cells matching the sub-string 'BUFF' as don't use:

set\_opt\_dont\_use \*BUFF\* true

# **IMPOPT-569**

### **NAME**

IMPOPT-569

#### **SUMMARY**

Design data is not loaded.

#### **DESCRIPTION**

A design must be loaded before running any optimization command.

Example:

The following command loads the saved design files from the test.enc database:

Error and Warning Messages

"source test.enc"

Alternatively see 'man read\_db' for further information.

### **IMPOPT-576**

#### NAME

IMPOPT-576

#### **SUMMARY**

%d nets have unplaced terms.

### **DESCRIPTION**

This message is issued when I/O pins connecting to signal nets are not placed or instances connecting to nets are not placed. user can report unplaced I/O pins by running "check pin assignment -report violating pin -out file viol pins.rpt"

To report un-placed Instance user can run "check\_place check\_place.rpt" and review the file.

### **IMPOPT-600**

#### NAME

**IMPOPT-600** 

### **SUMMARY**

No usable buffer and inverter has been found. At least one of them have to.

#### DESCRIPTION

You should check if the buffer(s)/inverter(s) are available in the timing libraries. If yes ensure footprint and function of buffer(s)/inverter(s) are defined properly in the library. To make

Error and Warning Messages

buffer(s)/inverter(s) usable:

- define buffer(s)/inverter(s) in libraries
- do not set buffer(s)/inverter(s) as dont use, both in libraries and in constraint file(.sdc file)

You can use report\_dont\_use\_cells command to reports cells that cannot be used for timing optimization. This command also reports the source of the timing constraint: the timing library file, timing constraint file, or the user (by specifying the set opt dont use command).

In lower power designs verify the proper power domain binding has been done as following:

- 1. If your analysis views are defined in your CPF then commitCPF automatically creates delay corners for each analysis view of the name analysis\_view\_dc. For example, "create\_analysis\_view -name slow\_PM01" will have a delay corner created named slow\_PM01\_dc. Innovus will automatically create the viewDefinition.tcl according to the CPF and bind the libraries to the respective delay corner and power domain.
- 2. If you have defined the MMMC definitions in a viewDefinition.tcl, you must define the complete MMMC information in the viewDefinition.tcl, which means that each power domain has "update\_delay\_corner -power\_domain" to associate the delay corner to the power domains. There is no need to define the view in CPF.

If CPF has the views, commitCPF will create the info which viewDefinition.tcl does not have.

#### Example:

In older releases you will get SOCOPT-600, SOCOPT-596, SOCOPT-3000 and SOCOPT-3001 for ENCOPT-600, ENCOPT-596, ENCOPT-3000 and ENCOPT-3001 messages respectively.

### **IMPOPT-616**

#### NAME

**IMPOPT-616** 

#### **SUMMARY**

Buffer insertion not successful. Reason: %s

#### **DESCRIPTION**

Error and Warning Messages

The error is generated when buffer insertion is not successful.

#### Possible reasons are:

- -The buffer insertion affects a net which cannot be optimized. You can run"report\_ignored\_nets out\_file ignored.rpt" to get a list of nets which cannot be optimized because they are clock nets, marked dont touch, etc.
- -The buffer insertion will change the port boundaries of a hierarchical instance which has hierarchical port constraints set by "set\_db opt\_keep\_ports keepPortHinstFile". You can run "getOptMode -keepPort#get db opt\_keep\_ports" to see the setting.
- -The default location for the added buffer is not compatible with the driver power domain. If you want to specify the location manually, you can use the -location option.
- -There may be an existing MSV violation on the net (the driver PD is incompatible with the sink PD). Maybe you want to insert an always on buffer, you can try and insert it with setting "set\_db opt\_add\_always\_on\_feed\_through\_buffers true".

### **IMPOPT-622**

#### **NAME**

IMPOPT-622

#### SUMMARY

Failed to open file %s!

#### **DESCRIPTION**

This is related to "set\_db opt\_size\_only\_file dont\_touch.txt\_003"; This file is missing. Please make sure the file exist before running this command.

#### Example:

\*\*ERROR: (ENCOPT-622): Failed to open file dont touch.txt 003!

#### NAME

IMPOPT-624

#### **SUMMARY**

No option provided for time\_design. Use either -report\_only or -pre\_place | -pre\_cts | -post\_cts | -post\_route | -sign\_off

#### **DESCRIPTION**

This error occurs when the time\_design command is run without any option

To get rid of this error message user should do the following

Provide one of the following options:

```
-pre_place | -pre_cts | -post_cts | -post_route | -sign_off or -report only
```

- -report\_only specifies the use of existing extraction and timing analysis data to generate timing reports. When you use this parameter, the software does not run extraction; instead it uses data that is already in memory.
- \* -report\_only is not honored when used with -pre\_place.
- \* -ideal\_clock is not honored when used with -report\_only.
- \* -sign\_off is honored when used with -report\_only. This is used to run a signoff timing analysis based on external SPEF files.

Note: Specifying -pre\_cts, -post\_cts, or -post\_route is optional with -report\_only.

#### Example:

- <CMD> time\_design -hold -report\_dir tmp
- \*\*ERROR: (ENCOPT-624): You have to add either -report\_only or -pre\_place | -pre\_cts | -post\_cts | -post\_route | -sign\_off option.

Usage: time\_design [-help] [-batch] [-drv\_report] [-expand\_reg2reg]

[-expanded\_views] [-hold] [-ideal\_clock] [-ilm]

Error and Warning Messages

[-nollm] [-num\_paths <integer>] [-report\_dir <string>]
[-path\_report] [-report\_prefix <string>] [-prototype]
[-report\_only] [-si] [-slack\_report]
[-timing\_debug\_report] [-use\_transition\_files]
[-pre\_place | -pre\_cts | -post\_cts | -post\_route |
-sign\_off]

# **IMPOPT-628**

#### NAME

**IMPOPT-628** 

#### SUMMARY

No equivalent cell found in the library for the substitution. Use "%s false" to allow the swapping of cells if the two cells are of different functionality.

#### **DESCRIPTION**

User is trying to swap the existing cell with the new cell having different functionality (characterized by footprint) using the change\_cell command.

E.g. Buffer to inverter, buffer to delay cells having different footprints.

# **IMPOPT-629**

#### NAME

IMPOPT-629

### **SUMMARY**

No alternate cell exists in the library for current power domain. To ignore MSV checks, specify '%s

Error and Warning Messages

false'.

#### DESCRIPTION

This error comes during ECO resize when tool looks for the correct library cell.

The problem is occurring because of missing definition of the cell in liberty file.

Possible reasons:

Wrong cell function.

Wrong observable power domains.

### **IMPOPT-655**

#### NAME

IMPOPT-655

#### SUMMARY

No usable delay or buf cells with footprint "%s" or "%s".

### **DESCRIPTION**

This warning message pops-up when the user tries to run opt\_design without specifying holdFixingCells list through setOptMode command and the tool finds that there are no usable delay or buffer cells in the library that can be used for hold fixing. The reason could be that these cells have a "dont\_use" attribute assigned to them.

#### Example:

In order to resolve this issue and to avoid this warning message the user needs to specify hold fixing cells through "set\_db opt\_fix\_hold\_lib\_cells" and make sure the specified cells in this list doesn't have a "dont\_use" attribute

#### NAME

IMPOPT-661

#### SUMMARY

The netlist is not uniquified. Optimization requires that hierarchical modules to be optimized have unique instances.

#### **DESCRIPTION**

Optimization requires unique instances of hierarchical modules. To uniquify the netlist run the uniquifyNetlist executable outside of Innovus then import the resulting uniquified netlist into Innovus.

If you are running the post-assembly closure (PAC) flow using master/clone partitions the master/clone partitions must either be ILM modeled or set to read only. You can use 'set module view -partitions partitionName -type readOnly' to do this.

#### Example:

To uniquify a netlist the separate uniquifyNetlist command can be used as follows: uniquifyNetlist -top top unique\_output.v non\_unique\_input.v

### **IMPOPT-665**

#### NAME

**IMPOPT-665** 

#### **SUMMARY**

%s: Net has unplaced terms or is connected to uplaced instances in design.

#### DESCRIPTION

This warning message is issued during optimization if there are nets connected to any unplaced I/O pins or unplaced instances in the design. The unplaced instances can be reported by running check\_place command and unplaced I/O's can be reported by running 'check\_pin\_assignment - report\_violating\_pin' command.Once these issues are fixed the warning message will not be reported.

### **IMPOPT-800**

#### NAME

IMPOPT-800

#### SUMMARY

Turning off Critical Region Resynthesis. Reason: %s

### **DESCRIPTION**

Either genus is not available in the path, or the version is not compatible with this innovus version or the genus licensing is not properly setup or some other error (detailed after "Reason:") caused the genus workers to not be properly setup.

A valid genus executable must be setup in the path for this feature to work.

### **IMPOPT-801**

#### **NAME**

IMPOPT-801

#### **SUMMARY**

Genus executable not found in the path%s.

#### DESCRIPTION

Unix variable \$path or \$PATH (depending on your shell) must include a directory containing a genus executable; alternatively, you can specify it in the innovus shell as:

append env(PATH) ":<directory>

# **IMPOPT-802**

#### **NAME**

IMPOPT-802

#### **SUMMARY**

Genus returned unmapped primitive '%s'.

#### DESCRIPTION

A genus worker was not able to properly remap some logic. The error is gracefully handled by the tool and the move causing it will be discarded. No bad logic or adverse side effect should be expected.

However, this can be considered an internal error and should be notified to Cadence support.

### **IMPOPT-803**

#### NAME

IMPOPT-803

#### **SUMMARY**

Cannot synchronize with genus workers after %d seconds.

### **DESCRIPTION**

Error and Warning Messages

The initial handshake with the genus workers did not complete successfully. This can occur if the genus process is killed or there is some error processing the libraries in genus.

This can be considered an internal error and should be notified to Cadence support.

# **IMPOPT-2901**

#### NAME

IMPOPT-2901

#### **SUMMARY**

Design is not placed. Place the design before running

#### **DESCRIPTION**

Use place\_design or place\_opt\_design to place the design.

### **IMPOPT-2902**

#### NAME

IMPOPT-2902

#### **SUMMARY**

Insufficient number of usable buffers %s

#### DESCRIPTION

Please use get\_db to make sure the .dont\_use attribute is set to false for the buffer cells you want to use

#### NAME

IMPOPT-2903

#### SUMMARY

Insufficient number of usable inverters %s

### **DESCRIPTION**

Please use get\_db to make sure the .dont\_use attribute is set to false for the inverter cells you want to use

# **IMPOPT-2904**

### **NAME**

IMPOPT-2904

### **SUMMARY**

Power domain %s does not have available always-on buffers to use.

#### DESCRIPTION

It is because either always-on buffer is set to don't use/don't touch, or the 2nd power/ground is disabled in power intent file, or always-on buffer liberty is not bound to the domain. Fix it accordingly if always-on buffer is needed in this domain for buffering.

#### NAME

IMPOPT-2907

### **SUMMARY**

hInst %s Is marked dont touch, no buffers can be added in the hInst.

### **DESCRIPTION**

Please use set\_db to update the .dont\_touch attribute

# **IMPOPT-2909**

#### **NAME**

IMPOPT-2909

### **SUMMARY**

Maximum length %.3f is too short. It is less than the optimal drive distance of %.3f and may result in excessive buffering.

#### **DESCRIPTION**

Check the optimal drive distance for each layer, and check that the maxLength is greater than the value with some margin built in.

#### NAME

IMPOPT-3000

#### SUMMARY

Buffer footprint is not defined or is an invalid buffer footprint.

#### **DESCRIPTION**

This warning message is issued when optimization engine does not find any buffers.

In order to fix this warning message the following things should be checked.

- 1. Buffer(s) are available in the timing libraries.
- 2. Footprint and function of buffer(s) are defined correctly in the library.

Buffers should contain only two signal pins. The power and ground pins should be defined properly with USE POWER and USE GROUND in the LEF.

3. Buffer(s) are not set to dont use in libraries or in constraint file(.sdc file).

Use "get db lib cells -if {.is dont use == true }" or run "report preserves" command.

4. In low power designs proper binding of buffer libraries to the respective delay corner and power domain is done.

### **IMPOPT-3001**

#### **NAME**

IMPOPT-3001

#### SUMMARY

Inverter footprint is not defined or is an invalid inverter footprint.

#### DESCRIPTION

This warning message is issued if optimization didn&'t find any Inverter.

In order to fix this warning message the following things can be checked.

- 1. Inverter(s) are available in the timing libraries.
- 2. Footprint and Function of inverter(s) are defined properly in the library.

Inverter(s) should contain only two signal pins. The power and ground pins should be defined properly with USE POWER and USE GROUND in the LEF.

3. Inverter(s) are not set to dont use in libraries or in constraint file(.sdc file).

Use "get db lib cells -if {.is dont use == true }" or run "report preserves" command.

4. In low power designs inverter libraries are binded to the respective delay corner and power domain is done.

# **IMPOPT-3025**

#### **NAME**

IMPOPT-3025

#### SUMMARY

Optimization Restructuring is disabled because the tool cannot find cells needed for this type of optimization.

#### DESCRIPTION

Optimization restructuring need to have access to cells functionalities such as ANDs/ORs/Inverters.

Check the functions of the cells that are available to the tool; you can double check the dont\_use settings for example.

#### NAME

IMPOPT-3034

#### **SUMMARY**

Optimization process capabilities limited due to %d assigned nets.

#### **DESCRIPTION**

The message is to inform the user that there are assign statements in the netlist which opt\_design cannot optimize. If these are not on timing critical paths then it is likely okay assuming your flow allows for assign statements. Often designers do not want assign statements and therefore remove them during synthesis or in Innovus System using the setDoAssign command.

# **IMPOPT-3035**

#### **NAME**

IMPOPT-3035

#### SUMMARY

Optimization process capabilities limited due to 1 assigned net.

### **DESCRIPTION**

This warning message is issued by opt\_design in case there is one assign net in the design and there is no way to optimize it.

setDoAssign command can be used to remove assign statements in the design and replace them with a buffer when importing the netlist.

#### NAME

IMPOPT-3040

#### SUMMARY

opt clock skew will overwrite scheduling file %s

### **DESCRIPTION**

This warning comes when opt\_clock\_skew is run in preCTS mode. To get rid of this warning user should specify a scheduling file name using set scheduling file command.

#### Example:

set\_scheduling\_file scheduling\_file.cts
opt\_clock\_skew

# **IMPOPT-3050**

#### NAME

IMPOPT-3050

#### SUMMARY

set db opt useful skew cells is pointing to the cell %s which is set as dont use in the library

### **DESCRIPTION**

SkewClock command is potentially going to insert a cell which has been marked as dont\_use in the library. You should double check that this is your intent.

Example:

Error and Warning Messages

set\_db opt\_useful\_skew\_cells {CLKBUFX8 CLKBUFX12 CLKINVX8 CLKINVX12}

set\_db opt\_useful\_skew true

opt\_design

check for all don't use cells : get\_lib\_cells \* -filter "is\_dont\_use == true" or dbGet [dbGet head.allCells.isDontUse 1 -p].name

# **IMPOPT-3058**

#### NAME

IMPOPT-3058

#### SUMMARY

Cell %s/%s already has a dont\_use attribute %s.

### **DESCRIPTION**

This message occurs because you set dont\_use attribute on a cell that has same value as what you are specifying.

This is not harmful and can be ignored if the value of dont\_use attribute is what you want it to be.

#### Example:

\* The following example sets library cell AND2 as dont\_use:

innovus> set opt dont use libSlow/AND2 true

innovus> set dont use libSlow/AND2 true

\* The following example turns off dont\_use attribute of library cell AND2:

innovus> set\_opt\_dont\_use libSlow/AND2 false

innovus> set\_dont\_use libSlow/AND2 false

#### NAME

IMPOPT-3080

#### **SUMMARY**

All delay cells are dont use. Buffers will be used to fix hold violations.

### **DESCRIPTION**

This Warning message means all delay cells in the loaded libraries have "dont\_use" attribute and the tool will use only Buffer cells to fix hold violations

#### Example:

To fix this issue and to avoid the Warning message the user can either set "set\_dont\_use false \*dlylibCell\*" in the SDC or if he wants do the same in the Innovus shell for MMMC design can run "set\_interactive\_constraint\_modes [all\_constraint\_modes -active]" followed by "set\_dont\_use" command and then re-run "opt\_design -hold

### **IMPOPT-3115**

#### NAME

IMPOPT-3115

#### **SUMMARY**

Netlist is not uniquified, optimization will be ignoring nets around modules that are not uniquified.

#### **DESCRIPTION**

Nets connected to non uniquified modules will be ignore for optimization.

You can Run uniquifyNetlist outside Innovus environment in a unix shell to generate a uniquified

Error and Warning Messages

netlist. You can also direct the tool to automatically uniquify the design after flattening by setting global variable init\_design\_uniquify to 1.

To see if the design is uniquified run check\_unique.

# **IMPOPT-3121**

#### NAME

IMPOPT-3121

#### SUMMARY

No usable buffer cell.

#### DESCRIPTION

This warning message is related to MMMC setup. If the standard cell library is missing from any library set or when creating a delay corner the "-library\_set" option is missing, then any active view that uses the library set will not have a buffer cell defined. So while running opt\_design the tool issues a warning saying no usable buffer cell is found.

#### Example:

In order to avoid this Warning message the user needs to make sure that when library sets are defined in the viewDefinition.tcl, make sure that the library set for all active views are properly defined and all libraries are included.

### **IMPOPT-3129**

#### **NAME**

IMPOPT-3129

#### SUMMARY

Unable to delete instance %s.

#### DESCRIPTION

This warning message is issued when the user tries to delete a buffer using 'eco\_delete\_repeater' command.

Possible causes for the error:

- inst is dont touch'ed or FIXED
- any net connect to the inst is dont touch'ed
- library cell of the inst is dont\_touch'ed
- the inst is an inverter.

#### Example:

In order to brute force the deletion: feedthrough buffer can be deleted using dbDeleteBuffer command. An example command would be 'dbDeleteBuffer [dbGetInstByName inst\_name]'

# **IMPOPT-3135**

#### **NAME**

IMPOPT-3135

#### SUMMARY

eco\_add\_repeater -relative\_distance\_to\_sink works with -pins or -net with 1-sink net on routed design.

#### DESCRIPTION

This error message comes when user runs eco\_add\_repeater -relative\_distance\_to\_sink with value other than 1 on a multi fanout net for buffering multiple sink terms.

#### Example:

eco\_add\_repeater -cells C12T32\_LL\_BFX33\_P10 -net SOCE\_PRECTS\_NET\_INCR\_SETUP\_DRV\_FE\_OFCN1278\_SOCE\_INPUT\_BOUNDARY\_ISOL ATION 4949 tst io testmode N -relativeDistToSink 0.5

\*\*ERROR: (ENCOPT-3135): eco\_add\_repeater -relative\_distance\_to\_sink works with -pins or -net

with 1-sink net on routed design.

### **IMPOPT-3142**

### **NAME**

IMPOPT-3142

#### SUMMARY

Could not open the file %s. Option '-reportIgnoredNets' will be ignored.

#### **DESCRIPTION**

The message occurs because Innovus can not write the file that you have specified with 'reportIgnoredNets'. Please check if you have necessary permission to write the file on target
directory (usually working directory) and have sufficient disk space or if you specify sub-directory that it exists.

#### Example:

\* The following example checks if you have permission to write on current working directory: innovus 20> file writable [pwd]

1

\* The following example checks if you have sufficient disk space:

innovus 21> df -kH [pwd]

Filesystem Size Used Avail Use% Mounted on

/disk/dir 2.2T 2.0T 271G 88% /disk/dir

### IMPOPT-3144

#### NAME

IMPOPT-3144

#### **SUMMARY**

Could not open the file %s. Option '-out\_file' will be ignored.

#### **DESCRIPTION**

The message occurs because Innovus can not write the file that you have specified with '-out\_file'. Please check if you have necessary permission to write the file on target directory and have sufficient disk space or if you specify sub-directory - that it exists.

#### Example:

\* The following example checks if you have permission to write on current working directory: innovus 20> file writable [pwd]

1

\* The following example checks if you have sufficient disk space:

innovus 21> df -kH [pwd]

Filesystem Size Used Avail Use% Mounted on

/disk/dir 2.2T 2.0T 271G 88% /disk/dir

### **IMPOPT-3180**

#### NAME

IMPOPT-3180

#### SUMMARY

Could not open the file %s to report ignored nets.

#### DESCRIPTION

The message occurs because you may not have permission to write a file or run out of disk space. Please check if you have necessary permission to write a file on target directory (usually the working directory) and have sufficient disk space or if you specify sub-directory - that it exists.

Error and Warning Messages

## Example:

\* The following example checks if you have permission to write on current working directory: innovus 20> file writable [pwd]

1

\* The following example checks if you have sufficient disk space:

innovus 21> df -kH [pwd]

Filesystem Size Used Avail Use% Mounted on

/disk/dir 2.2T 2.0T 271G 88% /disk/dir

# **IMPOPT-3186**

### NAME

IMPOPT-3186

## **SUMMARY**

\*\*\* switching analysis mode to "set\_db timing\_analysis\_useful\_skew true" so that newly generated latencies are taken in account by the timing engine\*\*\*

## **DESCRIPTION**

This warning message is issued when 'set\_db opt\_useful\_skew true' and the user tries to run opt\_design command.

## Example:

When usefulSkew is set to true the tool produces scheduling and latency files before CTS runs, or adds buffers and inverters after CTS, just as opt\_clock\_skew does. This parameter sets 'set\_db timing\_analysis\_useful\_skew true', so that timing analysis can read the latency file.

## NAME

IMPOPT-3195

## **SUMMARY**

Analysis mode has changed.

## **DESCRIPTION**

You have this message because Innovus temporarily changes the analysis mode for optimization use. This is usually not harmful and you may ignore this message.

One of these 5 analysis mode changes will cause this:

timing analysis clock source paths true

timing\_analysis\_clock\_propagation\_mode sdcControl

timing analysis useful skew false

- -virtualIPO false
- -skew true

# **IMPOPT-3213**

## **NAME**

IMPOPT-3213

## **SUMMARY**

The netlist contains multi-instanciated modules. The optimization engine will consider these modules as dont touch. Uniquify the netlist to get better quality of results.

Error and Warning Messages

## DESCRIPTION

opt\_design requires the netlist to be unique. If you are running the post-assembly closure (PAC) flow using master/clone partitions, the master/clone partitions must either be ILMs or set to read only (set\_module\_view -partitions partitionName -type readOnly).

To uniquify the netlist, run uniquifyNetlist outside of Innovus System. Then import the resulting, uniquified netlist into Innovus System.

## Example:

uniquifyNetlist -top top non unique.v unique.v

From 10.1USR2 the ordering of input and output files are different. In other words first the output file and then non-unique input file:

uniquifyNetlist -top top unique.v non\_unique.v

# **IMPOPT-3225**

## NAME

IMPOPT-3225

### SUMMARY

SpefIn flow is used. Re-extract RC and read spef for accuracy.

## **DESCRIPTION**

This warning message is issued when the user tries to run optimization through spef based flow. For each corer spef needs to be read in separately, if spef is missing for any corner tool will issue above warning and will re-extract Parasitics.

read\_spef command has an option to read corner spef file using '-rc\_corner' option. For each of the corner in the design user needs to read in separate spef files before performing spef based optimization.

## NAME

IMPOPT-3313

### SUMMARY

Skipping %s which is an assign net.

## **DESCRIPTION**

This message pops-up when the user tries to run 'add\_io\_buffers' command on an assigned net.

In order to avoid this Warning message the user needs to first set 'setDoAssign on -buffer buf\_name' before importing the design and then run 'add\_io\_buffers' command.

# **IMPOPT-3314**

## NAME

IMPOPT-3314

## **SUMMARY**

Skipping net '%s' which has fewer than two connected pins.

## **DESCRIPTION**

This warning is issued by the 'add\_io\_buffers' command when nets with only one or zero connected pins are encountered. 'add\_io\_buffers' does not add buffers on such nets.

## NAME

IMPOPT-3315

### **SUMMARY**

Common path pessimism removal is not enabled even though timing derates are applied. This can cause optimization to see more pessimistic timing than expected. To enable CCPR for both setup and hold use "set db timing analysis cppr both".

## **DESCRIPTION**

CPPR (Common Path Pessimism Removal) removes pessimism from clock paths that have a portion of the clock network in common between launch and capture paths. This error message indicates that timing derates are applied, so that the clock part of the launch and capture paths may be timed differently, but that removal of resulting pessimism in the common clock path is not enabled.

## Example:

set\_db timing\_analysis\_type onChipVariation setAnalysisMode timing\_analysis\_cppr both

# **IMPOPT-3318**

## **NAME**

IMPOPT-3318

## **SUMMARY**

Missing -pre\_cts|-post\_cts|-post-route option.

Error and Warning Messages

## DESCRIPTION

This warning message is issued when the user tries to run opt\_design command without specifying the design stage, meaning preCTS, postCTS or postRoute.

## Example:

This message can be avoided by running opt\_design with correct options depending upon on the stage of the design. As an example if the clock tree is not placed in the design then 'opt\_design - pre\_cts' can be run to optimize the design for the set-up.

# **IMPOPT-3319**

## NAME

IMPOPT-3319

## **SUMMARY**

The -hold option is not available with -pre\_cts.

## **DESCRIPTION**

This warning message is issued when the user tries to run -pre\_cts optimization in hold mode and the command exits without running pre\_cts optimization. The '-hold' option cannot be specified with pre\_cts optimization.

In order to avoid this warning message '-hold' option should be removed while running pre\_cts optimization meaning only setup optimization makes sense at pre\_cts stage.

# **IMPOPT-3326**

## NAME

IMPOPT-3326

## SUMMARY

The -dry option not allowed in -hold mode.

## **DESCRIPTION**

This warning message is issued when the user tries to run opt\_design in hold mode with '-drv' option. The tool issues the warning and comes out without running optimization.

When running hold fixing, opt design will maintain exiting setup and dry in the setup recovery step.

### Example:

This issue can be fixed by removing '-drv' option. As an example the user cannot run 'opt\_design - post\_cts -hold -drv', the correct command options are 'opt\_design -post\_cts -hold'

## **IMPOPT-3327**

## NAME

IMPOPT-3327

## SUMMARY

The -drv option not allowed with -incremental option.

## **DESCRIPTION**

This warning message is issued when user tries to run drv fixing with -incremental option and the command exits without performing DRV fixing. The DRV fixing cannot be run with -incremental option.

## Example:

The correct command will be 'opt\_design -post\_cts -drv' or running DRV fixing on selected nets/terms by specifying them in a file.

## NAME

IMPOPT-3328

### SUMMARY

The -incremental option is ignored with -hold option.

## **DESCRIPTION**

This warning message is issued when hold optimization is run with '-incremental' option. The tool issues this warning message and performs regular hold fixing on the design.

## Example:

In order to avoid this warning message '-incremental' option can be avoided while running hold fixing.

# **IMPOPT-3396**

### **NAME**

IMPOPT-3396

## **SUMMARY**

Cannot determine how to connect %s. There is a mismatch in number of pins between the cells being swapped.

## **DESCRIPTION**

Here is no direct way to do this in Innovus System currently. The recommendation is to handle this in RTL Compiler.

## NAME

IMPOPT-3465

### SUMMARY

The buffer cells were automatically identified. The command set\_buffer\_footprint is ignored. If you want to force the tool to honor this setting, you have to load a footprint file through the read\_footprint command.

## **DESCRIPTION**

This warning message is issued when the user uses footprintless flow and tries to run the command set\_buffer\_footprint to specify the buffer cell footprint. In order to use footprint flow the user needs to specify the footprints using read\_footprint command and then run set\_buffer\_footprint command, this will fix the warning issue.

## **IMPOPT-3466**

### NAME

IMPOPT-3466

## **SUMMARY**

The inverter cells were automatically identified. The command set\_inverter\_footprint is ignored. If you want to force the tool to honor this setting, you have to load a footprint file through the read footprint command.

## **DESCRIPTION**

This warning message is issued when the user uses footprintless flow and tries to run the command set inverter footprint to specify the Inverter cell footprint. In order to use footprint flow the user

Error and Warning Messages

needs to specify the footprints using read\_footprint command and then run set\_inverter\_footprint command, this will fix the warning issue.

## IMPOPT-3467

## NAME

IMPOPT-3467

## **SUMMARY**

The delay cells were automatically identified. The command set\_delay\_footprint is ignored. If you want to force the tool to honor this setting, you have to load a footprint file through the read\_footprint command.

## DESCRIPTION

This warning message is issued when the user uses footprintless flow and then tries to runs set\_delay\_footprint command to specifies the delay cell footprints. In order to use footprint flow the user needs to specify footprints using read\_footprint command and then run set\_delay\_footprint command, this will remove the warning issued.

# **IMPOPT-3468**

## NAME

IMPOPT-3468

### SUMMARY

The command read\_footprint has disabled the footprintless flow. Now using the classes of equivalence defined in the footprint file.

## **DESCRIPTION**

Error and Warning Messages

This message is seen when the command "read\_footprint" is executed. Innovus by default follows the footprintless flow. If the user want to define the foot prints and disable the footprintless flow, it can be done using the command "read\_footprint".

### Example:

<CMD> read\_footprint -in\_file modified\_foot\_print.file

\*\*WARN: (ENCOPT-3468): The command read\_footprint has disabled the footprintless flow. Now using the classes of equivalence defined in the footprint file.

Clearing footprints for all libraries

Loading footprints for all corners.

# **IMPOPT-3481**

## NAME

IMPOPT-3481

## **SUMMARY**

There is no buffer defined for the following power domain(s):%s.

## **DESCRIPTION**

This warning message is issued while running opt\_design command in pre\_cts/post\_cts/etc..., if there are library binding issues with power domain and the cells have dont\_use attribute

### Example:

In order to fix this issue the user needs to check if the library binding with respective Power domain is o.k, this can be verified by running &'check\_power\_domains -lib\_cell\_binding &' and also ensure that the required cells are available for optimization, meaning there are no dont\_use attribute associated to them

## NAME

IMPOPT-3531

### **SUMMARY**

No usable inverter has been found. It could be that there are no inverters defined in the libraries or all inverters are set as dont-use. Ensure that all required libraries have been loaded & check the dont-use settings for inverter cells.

## **DESCRIPTION**

## Example:

To get a list of all cells marked dont-use: report\_dont\_use\_cells To disable a dont-use? on a library cell: set\_opt\_dont\_use <cell-name> false

# **IMPOPT-3532**

## NAME

IMPOPT-3532

## **SUMMARY**

No usable buffer has been found. It could be that there are no buffers defined in the libraries or all buffers are set as dont-use. Ensure that all required libraries have been loaded & check the dont-use settings for buffer cells.

## DESCRIPTION

To get a list of all cells marked dont-use: report\_dont\_use\_cells

To disable a dont-use? on a library cell: set opt dont use <cell-name> false

## NAME

IMPOPT-3535

### SUMMARY

OptDesign command could not find any buffers which could be used for optimization. It could be that" "a) There are no buffers in libraries (Ensure that all required libraries have been loaded) OR " "b) All buffers are set as dont use (Check the dont use settings for buffer cells within the libraries).

## **DESCRIPTION**

For example:

To get a list of all cells marked dont-use, issue command:

report dont use cells

To disable a dont-use on a library cell, issue command:

set opt dont use <cell name> false

# **IMPOPT-3543**

## NAME

IMPOPT-3543

## **SUMMARY**

Option set db opt resize level shifter and iso insts is set to true (default false).

## DESCRIPTION

This warning message is issued when 'opt\_resize\_level\_shifter\_and\_iso\_insts' is set to true in setOptMode. This means even if they are marked as dont\_touch, opt\_design may resize some shifter and isolation cells for timing optimization

### Example:

Don't touch instances and are not changed during timing optimization. When this parameter is set to true, the shifters and isolation cells are resized for timing optimization by using opt\_design.

# **IMPOPT-3547**

## NAME

IMPOPT-3547

## **SUMMARY**

Net %s is connected to unplaced instance(s). Drv(s) cannot be fixed on it.

## **DESCRIPTION**

Please ensure that the design is legally placed before running optimization.

Use the check place command.

## Example:

To report the instances to which a net connects:

dbGet [dbGet -p top.nets.name <net-name>].instTerms.inst.name.

To report a list of unplaced instances:

dbGet [dbGet -p top.insts.pStatus unplaced].name.

## NAME

IMPOPT-3560

## **SUMMARY**

SDF based flow is used. The final timing report summary cannot be printed out in this mode.

## **DESCRIPTION**

SDF based flow does not report the final timing summary after optimization. This is due to the fact the original SDF(s) are not valid after optimization and have to be regenerated after optimization.

## Example:

To report the timing after optimization, regenerate the SDFs, load them and time the design:

read sdf-view <view1> ...

read sdf-view <view2> ...

time design -report only

# **IMPOPT-3563**

### NAME

IMPOPT-3563

## SUMMARY

"setTrialRouteMode -keepExistingRoutes true" is not supported by opt\_design/time\_design. This route\_trial option will be disabled.

## **DESCRIPTION**

The opt\_design or time\_design commands cannot honour "setTrialRouteMode - keepExistingRoutes true", the reason being the design is at pre-route stage and these commands are going to re-run route\_trial and estimate parasitics hence existing routes in the design cannot be preserved. In order to avoid this message either the user needs to change "setTrialRouteMode - keepExistingRoutes false" before running opt\_design or time\_design command or else the tool will automatically disable it.

## **IMPOPT-3579**

### NAME

IMPOPT-3579

### SUMMARY

Cell '%s' is marked as dont touch. %s command will skip this cell.

## **DESCRIPTION**

This warning message is issued by an attempt to run the interactive ECO command on a dont\_touch library cell. This can be overridden with "set\_db eco\_honor\_dont\_touch false". Alternatively adjust the dont\_touch status on the cell.

# **IMPOPT-3580**

## **NAME**

IMPOPT-3580

## **SUMMARY**

Cell '%s' is marked as dont use. %s command will skip this cell.

## DESCRIPTION

This warning message is issued by an attempt to run the interactive ECO command on a dont\_use library cell. This can be overridden with "set\_db eco\_honor\_dont\_use false". Alternatively adjust the dont use status on the cell.

# **IMPOPT-3581**

### NAME

IMPOPT-3581

### SUMMARY

Instance '%s' is marked as dont touch. %s command will skip this instance.

## **DESCRIPTION**

This warning message is issued by an attempt to run the interactive ECO command on a dont\_touch instance. This can be overridden with "set\_db eco\_honor\_dont\_touch false". Alternatively adjust the dont\_touch status on the instance.

## **IMPOPT-3585**

### NAME

IMPOPT-3585

## **SUMMARY**

Instance '%s' is marked as fixed. %s command will skip this instance.

## **DESCRIPTION**

This error comes when user runs an ECO command on a FIXED instance. To get rid of this error message user should specify instance whose placement status is not FIXED. User can also use dbSet command to change placement status of instance from FIXED to PLACED.

## **NAME**

IMPOPT-3588

## SUMMARY

%s is not a cell!

## DESCRIPTION

When trying to change the cell for a specific instance using eco\_update\_cell. It reports that the specific cell "is not a cell!"

The cell exists in the LEF. eco\_update\_cell requires that the cell you specify, cellXYZ in this example, must be defined in the timing library. If it does not have a timing definition for it then this message will get issued. Create a timing definition in the .lib for this cell to resolve this issue.

Use check design to confirm if all cells in the design has all timing library bounded.

# **IMPOPT-3593**

### NAME

IMPOPT-3593

## **SUMMARY**

The cell %s is not defined in any library file. If you wish to use this cell please ensure a timing library file defining this cell is bound to each timing analysis-view.

## **DESCRIPTION**

Error and Warning Messages

## Example:

To see a list of defined timing analysis-views:

all\_analysis\_views | all\_setup\_analysis\_views | all\_hold\_analysis\_views

To see the library-sets defined for each analysis-view:

get\_delay\_corner [get\_analysis\_view <analysis-view> -delay\_corner] -library\_set | -early\_library\_set | -late\_library\_set

To see the list of library files defined for each library-set:

get library set < library-set> -timing

Alternatively check your &'viewDefinition.tcl&' file.

# IMPOPT-3594

### NAME

IMPOPT-3594

## **SUMMARY**

'%s' is inside ILM block. %s command will skip it.

## **DESCRIPTION**

This message comes when user tries to use an ECO command on an ILM object. ILM objects are read-only and cannot be modified by ECO commands.

## Example:

```
<CMD> eco_delete_repeater -insts FE_OFC4333_des_interface_n_3736
```

'FE\_OFC4333\_des\_interface\_n\_3736' is inside ILM block. eco\_delete\_repeater command will skip it.

<sup>\*\*</sup>ERROR: (IMPOPT-3594):

## NAME

IMPOPT-3596

## **SUMMARY**

Running 'time\_design -post\_route -si (-hold)' with 'set\_db timing\_analysis\_type bcwc' is not recommended.

## **DESCRIPTION**

Running &'time\_design -post\_route -si (-hold)&' with &'set\_db timing\_analysis\_type bcwc&' might lead to incorrect timing analysis results. This is because the SI delay push-outs (or pull-ins for -hold mode) on the clock nets get annotated to both the launch and the capture clock paths resulting in optimistic slacks to be reported. To get accurate timing analysis results, use &'set\_db timing\_analysis\_type onChipVariation&', which requires the design to be run in either in multi-mode multi-corner (MMMC) or single-mode single-corner (SMSC) mode. For more information, see the &'Specifying the MMMC Environment&' section in the &'Optimizing Timing&' chapter of the Innovus User Guide.

## **IMPOPT-3600**

### NAME

IMPOPT-3600

## **SUMMARY**

The setSiMode "-analysisType pessimistic" can only be set in conjonction with the set\_db timing\_analysis\_type -onChipVariation

## **DESCRIPTION**

To get accurate SI timing analysis results, use &"set\_db timing\_analysis\_type onChipVariation&", which requires the design to be set either in multi-mode multi-corner (MMMC) or single-mode single-corner (SMSC) mode. If the MMMC and OCV modes are not enabled, and if the &"opt\_design -post\_route -si&" and &"time\_design -post\_route -si&" commands will exit with an error.

### Example:

- <CMD> setDelayCalMode -engine Aae
- <CMD> setAnalysisMode -analysisType single
- <CMD> setSiMode -analysisType pessimistic

Should be changed to:

- <CMD> setDelayCalMode -engine Aae
- <CMD> setAnalysisMode -analysisType onChipVariation
- <CMD> setSiMode -analysisType pessimistic

# **IMPOPT-3602**

### NAME

IMPOPT-3602

## **SUMMARY**

The specified path group name %s is not defined.

## DESCRIPTION

This error occurs when an unknown path group name is specified to

set path group options. Check the name or create the path group as required.

## Example:

The following example defines a path group and sets the path group optimization effort level to high:

group path -name PATH GROUP A -to [get pins ff1/D]

set\_path\_group\_options PATH\_GROUP\_A -effort\_level high

# **IMPOPT-3610**

## **NAME**

IMPOPT-3610

## **SUMMARY**

Multi-CPU optimization is only supported in set\_distribute\_host -local mode.

## **DESCRIPTION**

Multi-Cpu optimization supports multi-threading on the local host only. This can be setup using set\_distribute\_host -local and set\_multi\_cpu\_usage -localCpu <num of cpus>

## Example:

set\_distribute\_host -local
set\_multi\_cpu\_usage -local\_cpu <num of cpus>

# **IMPOPT-3611**

## **NAME**

IMPOPT-3611

## **SUMMARY**

Multi-CPU optimization is disabled.

## **DESCRIPTION**

This option is for internal use only. To enable the multi-cpu optimization use set\_multi\_cpu\_usage -

Error and Warning Messages

enable opt

Example:

To enable multi-cpu optimization use: set multi cpu usage -enable opt

To disable multi-cpu optimization use: set multi cpu usage -disable opt

# **IMPOPT-3626**

## NAME

IMPOPT-3626

## SUMMARY

NanoRoute option "route\_with\_timing\_driven" is set to "false" by user."opt\_design" will automatically set this option to "true" in nanoRoute based flow.

## **DESCRIPTION**

This warning message is issued while running preCTS optimization in NRGR based flow when 'route with timing driven' is set to false

## **IMPOPT-3629**

### NAME

IMPOPT-3629

## **SUMMARY**

Option "-criticalRange <value>" for command setOptMode is obsolete and has been replaced by "opt\_all\_end\_points true|false".

## **DESCRIPTION**

This message comes when user tries to use option "-criticalRange <value>" of setOptMode command with the latest version of the tool. In order to get rid of this message user should use set\_db opt\_all\_end\_points true|false

# **IMPOPT-3631**

### NAME

IMPOPT-3631

## **SUMMARY**

Option -criticalRange for the command set\_path\_group\_options is obsolete and is being ignored.

## **DESCRIPTION**

The message occurs because the option '-criticalRange <value>' for the command set\_path\_group\_options is obsolete. Please update your script with 'set\_db opt\_all\_end\_points <boolean>'.

## Example:

The following example enables WNS/TNS optimization:

set\_db opt\_all\_end\_points true

The following example enable WNS optimization only:

set db opt all end points false

# **IMPOPT-3634**

## NAME

IMPOPT-3634

## **SUMMARY**

reg2reg optimization will not be run because there are no reg2reg paths in the design.

## DESCRIPTION

This warning message is issued during optimization when the design doesn't have clock definition meaning there are no &"create\_clock&" statements in the SDC file. The issue can be resolved by fixing this problem.

## **IMPOPT-3638**

## NAME

IMPOPT-3638

### **SUMMARY**

Cell %s is not defined in any timing analysis view. This cell will be marked dont\_use.

## **DESCRIPTION**

This warning comes when the cell %s defined by user does not exist in any timing analysis view.

To remove the warning user needs to check the following

- Correct cell name is used.
- 2. Cell library is added to at least one timing analysis view. To review the library binding user can either check viewDefinition.tcl file or run the following commands
- a) Use all\_analysis\_views | all\_setup\_analysis\_views | all\_hold\_analysis\_views to get the name of all analysis views.
- b) Use get\_delay\_corner [get\_analysis\_view <analysis-view> -delay\_corner]
- -library\_set | -early\_library\_set | -late\_library\_set to see the library-sets defined for each analysis-view.
- c) Use get\_library\_set library-set> -timing to see the list of library files defined for each library-set.

## NAME

IMPOPT-3649

## **SUMMARY**

Reset VT partitioning data

## **DESCRIPTION**

Info message shown upon "setOptMode -reset -defineVtPartition"

Example:

innovus 23> setOptMode -reset -defineVtPartition

Reset VT partitioning data

0

# IMPOPT-3654

## NAME

IMPOPT-3654

## SUMMARY

Could not find lib: %s, specified in custom VT file: %s, in the libset for power view (%s).

## **DESCRIPTION**

User defined vt partitioning has a different name other than LVT, SVT and HVT.When user specifies a vt partition name as anything other these names, for example, MVT or OSVT or FVT, are not acceptable. The user defined vt partition names have to be either LVT, SVT or HVT only.

## Example:

Could not find lib: OSVT, specified in custom VT file:

my user defined VT partitioning.txt, in the libset for power view (view FUNC MODE).

## **IMPOPT-3655**

### NAME

IMPOPT-3655

## SUMMARY

%d standard cell libs (listed below) are missing in custom VT file. Please review, correct the custom VT file and try again. Cells in these libs will not be part of any VT partition:

## **DESCRIPTION**

## Example:

Assume the design has the below libs set:

Lib set:

GS70 S 105 1.1 1.1 CORE.db

GS70 S 105 1.1 1.1 CORE CUSTOM.db

GS70 S 105 1.1 1.1 CORE PM.db

GS70 S 105 1.1 1.1 CORE PM XSVT.db

GS70\_S\_105\_1.1\_1.1\_CORE\_XSVT.db

GS70\_S\_105\_1.1\_1.1\_CORE\_CUSTOM\_XSVT.db

GS70 S 105 1.1 1.1 CORE CUSTOM OSVT.db

GS70\_S\_105\_1.1\_1.1\_CORE\_OSVT.db

GS70\_S\_105\_1.1\_1.1\_CORE\_PM\_OSVT.db

They should be partitioned as follows in the custom VT file with no lib missing:

## Custom VT file:

LVT

GS70\_S\_105\_1.1\_1.1\_CORE.db

GS70\_S\_105\_1.1\_1.1\_CORE\_CUSTOM.db

GS70\_S\_105\_1.1\_1.1\_CORE\_PM.db

**SVT** 

GS70 S 105 1.1 1.1 CORE PM XSVT.db

GS70\_S\_105\_1.1\_1.1\_CORE\_XSVT.db

GS70\_S\_105\_1.1\_1.1\_CORE\_CUSTOM\_XSVT.db

HVT

GS70\_S\_105\_1.1\_1.1\_CORE\_CUSTOM\_OSVT.db

GS70\_S\_105\_1.1\_1.1\_CORE\_OSVT.db

GS70 S 105 1.1 1.1 CORE PM OSVT.db

## **IMPOPT-3657**

## NAME

IMPOPT-3657

## **SUMMARY**

"opt\_layer\_aware" setOptMode option will be obsoleted. This option still works in this release, but to avoid this warning and to ensure compatibility with future releases, updating your script is recommended.

## **DESCRIPTION**

This warning message is issued when the user tries to set 'set\_db opt\_layer\_aware true" in Innovus-14.1 to perform layer aware optimization while running opt\_design command.

Example:

Error and Warning Messages

In Innovus-14.1 onwards layer aware optimization is made default, there is no need for the user to set this option separately. Hence it's recommended to update the user scripts accordingly to avoid this warning message.

# **IMPOPT-3663**

### NAME

IMPOPT-3663

## **SUMMARY**

Power view is not set. First setup analysis view (%s) will be treated as power view and VT partitioning will be done on basis of leakage specified in this view. If this is incorrect, specify correct power view via command "set db power view <view name>".

## **DESCRIPTION**

Before executing the command "setOptMode -defineVtPartition my\_vt\_partition\_file.txt", "set\_db power\_view my\_power\_view" has to be set. This warning is given when vt partitioning is mentioned without setting the power analysis view.

### Example:

\*\*WARN: (ENCOPT-3663): Power view is not set. First setup analysis view (view\_FUNC\_MODE) will be treated as power view and VT partitioning will be done on basis of leakage specified in this view. If this is incorrect, specify correct power view via command "set\_power\_analysis\_mode - analysis\_view <view\_name>".

## **IMPOPT-3665**

## **NAME**

IMPOPT-3665

## **SUMMARY**

VT partitioning could not complete due to above error(s). Fix the error(s) and rerun the command.

### DESCRIPTION

There are some problems when "setOptMode -defineVtPartition my\_vt\_partition\_file.txt" and tool started doing vt partitioning, but could not complete it because of some errors may be in the file my\_vt\_partition\_file.txt; Please check the syntax of the vt partitin file and correct it.

### Example:

\*\*ERROR: (ENCOPT-3665): VT partitioning could not complete due to above error(s). Fix the error(s) and rerun the command.

Number of VT partitions: 0

Power view : view\_FUNC\_MODE

Cells in design: 1443

Instances in design: 331073

Instance distribution across the VT partitions:

Reporting took 2 sec

# IMPOPT-3714

### NAME

IMPOPT-3714

## SUMMARY

Cannot add buffer inside hierarchy '%s' as it is don't touch.

## **DESCRIPTION**

The error is generated when tool is not allowed to add instances inside this hierarchy.

Possible reasons are: -

-The hierarchy is marked dont touch using set db command.

Error and Warning Messages

- -The hierarchy belongs to (or is present inside) a multi-instantiated cell and ECO inside multi-instantiated cells is not allowed.
- -The hierarchy is present inside an ILM.

# **IMPOPT-6022**

### NAME

IMPOPT-6022

## **SUMMARY**

%s will not do any insertions on %s as this net has been set to dont\_touch.

## **DESCRIPTION**

Please confirm if it was intentional to set this net as "dont touch".

Example:

To alter the "dont touch" setting on a net:

set dont touch [get nets <net name>] false|true

# **IMPOPT-6055**

### NAME

IMPOPT-6055

## **SUMMARY**

The following cells have a "dont-touch" property but without being "dont-use". This could lead to optimization problems if a cell is inserted by the tool but then cannot be modified. Please check the dont-touch and dont-use settings for these cells within your libraries.

## DESCRIPTION

## Example:

To alter these settings on library cells use:

set\_opt\_dont\_use <cell-name> false | true

set\_dont\_touch [get\_lib\_cells <cell-name>] false | true

# **IMPOPT-6056**

### NAME

IMPOPT-6056

## SUMMARY

Option "-extractionEngine" for command setSIMode is obsolete. This option has been mapped to the following option based on your selection of extraction engine for use in SI flow: %s Modify your script to use the above setting instead of setSIMode -extractionEngine.

## DESCRIPTION

How do I control which extractor is used to generate spef file?

It seems the behavior of set\_db extract\_rc\_engine and extract\_rc\_effort\_level have changed indicated by the warnings above. Using set\_db options extract\_rc\_engine and extract\_rc\_effort\_level to control which extractor is used by extract\_rc is described below.

The extract\_rc\_engine option indicates whether to use the preRoute or postRoute extraction engine. The extract\_rc\_engine values default, detail and CCE are now obsolete.

Use extract\_rc\_engine preRoute when the design has not been detail routed by NanoRoute yet. This is equivalent to extract\_rc\_enginee default in previous versions of Innovus. When extract\_rc\_engine preRoute is set RC extraction is done by the fast density measurements of the surrounding wires; coupling is not reported.

Use extract\_rc\_engine postRoute after the design has been detail routed by NanoRoute.RC extraction is done by the detailed measurement of the distance to the surrounding wires; coupling is reported. The effortLevel parameter further specifies which postRoute engine is used for balancing

Error and Warning Messages

performance versus accuracy needs.

The extract\_rc\_effort\_level value controls which extractor is used when the postRoute engine is used.

low - Invokes the native detailed extraction engine. This is the same as specifying the extract rc engine postRoute setting.

medium - Invokes the Turbo QRC (TQRC) extraction mode. TQRC performance and accuracy falls between native detailed extraction and IQRC engine. This engine supports distributed processing. TQRC engine is recommended for process nodes < 65nm. Note: This setting does not require a QRC license.

high - Invokes the Integrated QRC (IQRC) extraction engine. IQRC provides superior accuracy compared to TQRC. IQRC is recommended for extraction after ECO. In addition, IQRC supports distributed processing. Note: IQRC requires a QRC license.

signoff - Invokes the Standalone QRC extraction engine. This engine choice provides the highest accuracy. The engine has several runModes, thereby, providing maximum flexibility.

The default value depends on the value of setDesignMode. The default for nodes above 65nm is low. TQRC (effortLevel medium) is the default extraction engine in the postroute flow for 65 nm and below design. However, TQRC and IQRC do not support the obsoleted 3 corner flow (defineRCCorner flow) and require a QRCTechfile. Therefore, Native Detailed (effortLevel low) engine remains the default engine if no QRCTechfile has been defined or if the defineRCCorner command has been used.

Should you use Turbo QRC (tQRC) or standalone QRC?

The extraction time with tQRC is typically a small percentage of the total flow time. With standalone QRC, the runtime would be longer.

Standalone QRC requires the usage of a QRC license (tQRC uses the Innovus license). It writes out a DEF and invokes the standalone tool. It is slower than tQRC. It is not incremental like tQRC, so the runtime impact may be high. tQRC is incremental and if changes are small, extraction runtime drops to almost zero. The delta between standalone QRC and tQRC in terms of accuracy is typically small, so there is usually no flow advantage or end QoR gain by doing it.

Cadence's suggestion is to use TurboQRC for 65nm and below nodes in the postRoute flow, and for signoff use standalone QRC.

Note: setSIMode -extractionEngine is obsolete and extraction during SI fixing will use the values of set\_db extract\_rc\_engine and extract\_rc\_effort\_level to determine the extractor to use.

## NAME

IMPOPT-6064

### SUMMARY

honorFixedStatus is set to false. Fixed instance %s will be deleted.

## **DESCRIPTION**

This warning message is issued when the user tries to delete a fixed instance using 'eco\_delete\_repeater' command.

## Example:

When the 'set\_db eco\_honor\_fixed\_status false' and the user tries to delete a fixed Buffer/Inverter using 'eco\_delete\_repeater -inst <inst\_name>' command the tool issues above warning and deletes the specified Buffer/Inverter.

# **IMPOPT-6072**

### NAME

IMPOPT-6072

## **SUMMARY**

Timing after commit may not match evaluate timing as spef for net %s is disabled with "evaluateOnly".

## **DESCRIPTION**

This warning message in Innovus indicates that the RC for this particular net is not available, even if the SPEF is loaded. Please note that in the absence of SPEF, evaluation timings might not match

the timing that you get after commit.

Example:

\*\*WARN: (ENCOPT-6072): Timing after commit may not match evaluate timing as spef for net n1 is disabled.

---- Cell: BUFX1 ----

Through-object Slack: 8.067

Global Slack: 4.913

Max Tran Slack: 2.2547

0

For example, in this case the net &'n1&' does not have detail parasitics:

> get\_property [get\_net n1] has\_detailed\_parasitics

false

You would not get this warning message if you read the parasitics for this net, like using below example:

> write\_parasitics -spef\_file testef

> read spef testef

You can also check the parasitics for this net is now available.

> get property [get net n1] has detailed parasitics

true

Running eco add repeater now would not issue above warning message:

> eco add repeater -net n1 -cell BUFX1 -evaluateOnly

Using master clock &'ck&' for generated clock &'gck&'

Calculate delays in Single mode...

Topological Sorting (CPU = 0:00:00.0, MEM = 325.7M)

Number of Loop: 0

Start delay calculation (mem=325.660M)...

Delay calculation completed. (cpu=0:00:00.0 real=0:00:00.0 mem=325.660M 0)

\*\*\* CDM Built up (cpu=0:00:00.0 real=0:00:00.0 mem= 325.7M) \*\*\*

---- Cell: BUFX1 ----

Error and Warning Messages

Through-object Slack: 8.067

Global Slack: 4.913

Max Tran Slack: 2.2547

0

# **IMPOPT-6080**

## **NAME**

IMPOPT-6080

### SUMMARY

AAE-SI Optimization can only be turned on when the timing analysis mode is set to OCV.

## DESCRIPTION

The Advanced Analysis Engine (AAE) requires timing analysis to be run in On-Chip Variation (OCV) mode. To enable OCV mode run:

set\_db timing\_analysis\_type onChipVariation

With OCV mode you typically want to enable Common Path Pessimism Removal (CPPR) as well: set db timing analysis cppr both

# **IMPOPT-6089**

### NAME

IMPOPT-6089

### SUMMARY

Cannot delete instance '%s' as instance is resize only.

### DESCRIPTION

This message is reported when user tried to delete an instance which have "ResizeOnly" attribute. This property was set by opt\_design with the option set\_db opt\_size\_only\_file <file>, where <file> is user define list of cell to have this attribute.

Remove ResizeOnly property for the instance to delete.

The property can be removed as follows:

set inst B1

dbDelProp [dbGet -p [dbGet -p top.insts.name \$inst].props.name ResizeOnly]

Note: starting 14.2 these property will be revised to a new scheme.

Example:

Once the "resizeOnly" attributes get removed, we can now delete the buffer using "eco\_delete\_repeater" command, as shown below:

eco delete repeater -inst B1

# **IMPOPT-6095**

## **NAME**

IMPOPT-6095

#### SUMMARY

Cannot delete instance '%s' as cell '%s' is neither a buffer nor an inverter. Only buffers & inverters can be deleted with this command.

### DESCRIPTION

This error comes when tool does not find the specified instance as a buffer/inverter.

In order to get rid of this error: -

- 1. Check the name of buffer/inverter instance specified.
- 2. Dump out the footprint of the cell using report\_footprints command. If the cell is not interpreted as a buffer/inverter, check library for buffer/inverter footprint and function.

# **IMPOPT-6108**

### NAME

IMPOPT-6108

### SUMMARY

Used -pins with -relative\_distance\_to\_sink option set to value 1. Ignoring -relative\_distance\_to\_sink option.

### **DESCRIPTION**

This warning message is issued when the user tries to run eco\_add\_repeater command with '-pins' option and using '-relative\_distance\_to\_sink 1'. Relative distance to sink 1 means that the repeater needs to be placed close to driver. If not all sink terms of the net are specified with -pins option, - relative\_distance\_to\_sink option is ignored.

# **IMPOPT-6111**

### NAME

IMPOPT-6111

## **SUMMARY**

The location {%.2f %.2f} specified in %s option is outside the design boundary. Command %s will ignore this option.

# **DESCRIPTION**

This message comes when user specifies a location outside the design boundary.

In order to get rid of this message user should make sure the specified location lies within the

design boundary. The design boundary can be checked using dbGet top.fplan.box.

# **IMPOPT-6115**

## **NAME**

IMPOPT-6115

### SUMMARY

ECO batch mode has been activated, and '(batch mode)' has been added to the prompt as a reminder of that situation. Specify '%s false' after all ECOs are over.

### DESCRIPTION

This warning is seen if the initial innovus db itself has batch mode enabled or the user has set it intentionally. Multiple ECO changes can be done in batch mode. This takes lesser run time when compared to batch mode false. Once all the ECOs are done, we must exit batch mode, because optimization and many other commands do not work properly in batch mode. Timing updates for all ECOs done inside batch mode are done at once when batch mode is exited.

#### Example:

set db eco batch mode true

eco\_add\_repeater/eco\_delete\_repeater/eco\_update\_cell ...; # No timing update is done during these ECOs.

set\_db eco\_batch\_mode false; # This would update timing incrementally for all the above ECOs at once.

report\_timing ...; # Timing should be up-to-date here.

#For more details, please look into the COS "Speeding up eco\_add\_repeater runtime when in batch mode

# **IMPOPT-6116**

### NAME

IMPOPT-6116

## **SUMMARY**

ECO operation to delete a buffer fails if the buffer is a feedthrough buffer.

## **DESCRIPTION**

Feedthrough buffers deletion is prohibited by the tool as in some cases, this will result in an assign statement, which is prohibited by default. This check is strict and will also prevent feedthrough buffer deletion on cases that don't require assign creation.

To remove this error in 13.x, user should add -allowCreateAssign option to eco\_delete\_repeater (source is CCR 1043429)

In 14.1, this should apparently be fixed through HECO, still according to the same CCR.

## Example:

```
[DEV]innovus 3> eco_delete_repeater -insts physical_lake_3/digrf_1/digrf_core_inst/regsp_top/digrf_regsp/FE_MHHOLD_ECO_DB100o_6489
```

\*\*ERROR: (ENCOPT-6116): Cannot delete instance physical\_lake\_3/digrf\_1/digrf\_core\_inst/regsp\_top/digrf\_regsp/FE\_MHHOLD\_ECO\_DB100o\_6489 as instance is a feed through buffer.

\*\*WARN: (ENCOPT-3129): Unable to delete instance physical\_lake\_3/digrf\_1/digrf\_core\_inst/regsp\_top/digrf\_regsp/FE\_MHHOLD\_ECO\_DB100o\_6489.

# **IMPOPT-6135**

## **NAME**

IMPOPT-6135

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

## SUMMARY

Multiple instances with multiple cells are not supported with command %s.

# **DESCRIPTION**

This message is issued when multiple cells are specified with multiple instances during resize. The possible combinations are: a single instance with multiple cells (evaluation only), or a single cell with multiple instances (commit only).

# **IMPOPT-6206**

## NAME

IMPOPT-6206

## **SUMMARY**

Net %s is a special net.

### **DESCRIPTION**

This Warning message is issued when user tries to run interactive ECO using eco\_update\_cell, eco\_delete\_repeater or eco\_add\_repeater commands when one of the pins of the cell is connected to a special net.

# **IMPOPT-6249**

## **NAME**

IMPOPT-6249

## **SUMMARY**

Routing for net %s is not clean/complete. The terms to be buffered cannot be identified based on %s option. Use option -pins or -net to add buffer on the net.

### DESCRIPTION

Buffer addition to offload the net could not be done using specified options because software has identified some issues with the net routing. It could be that net has opens, shorts or incomplete routing etc. Review the routing of this net.

# IMPOPT-7071

## **NAME**

IMPOPT-7071

### **SUMMARY**

The distributed optimization engine is obsolete and has been replaced by the GigaOpt optimization engine which is default in this release. Please update your scripts to remove any explicit settings of 'setDelayCalMode -engine feDc'or 'setDelayCalMode -engine signalStorm' so you get the default Advanced Analysis Engine (AAE) delay calculator to enable the GigaOpt engine.

## DESCRIPTION

feDC delay calculation engine is not available in Innovus 14.1. When "setDelayCalMode -engine feDC" is executed, this error is seen. In Innovus 14.1, default delay calculation engine is AAE. If feDC delay calculation is required, revert to Innovus 13.2.

## Example:

\*\*ERROR: (ENCOPT-7071): The distributed optimization engine is obsolete and has been replaced by the GigaOpt optimization engine which is default in this release. Please update your scripts to remove any explicit settings of 'setDelayCalMode -engine feDc' or 'setDelayCalMode -engine signalStorm' so you get the default Advanced Analysis Engine (AAE) delay calculator to enable the GigaOpt engine.

\*\*ERROR: Batch process failed.

# **IMPOPT-7075**

## **NAME**

IMPOPT-7075

### SUMMARY

Timing data-to-data checks are present and will be disabled during optimization. To enable data-to-data checks during optimization use'set\_db opt\_enable\_data\_to\_data\_checks true'.

### DESCRIPTION

Timing data-to-data checks are found in the design and are disabled during optimization so that optimization focuses on regular data-to-clock timing checks. To enable data-to-data checks during optimization use 'set\_db opt\_enable\_data\_to\_data\_checks true'.

# **IMPOPT-7077**

## **NAME**

IMPOPT-7077

### SUMMARY

Some of the LEF equivalent cells have different

ANTENNAGATEAREA/ANTENNADIFFAREA/PINS etc... attributes. They will not be swapped for fixed instances and for lefsafe operations like opt\_leakage\_power in postroute mode. To find out what cells are LEF equivalent use the report\_lef\_equivalent\_cells command.

# **DESCRIPTION**

Due to differences between cells in the design physical library such as OBS,PINS,

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

ANTENNAGATE, ANTENNADIFF etc... swapping is not allowed for such instances. For more information use the new report\_lef\_equivalent\_cells command. It requires the name of a LEF cell to check, and optionally an output file for the results:

report\_lef\_equivalent\_cells -lib\_cell <lib\_cell> -out\_file <out\_file>

During normal timing optimization, opt\_design will resize instances as required. Cells of different sizes but the same function are not equivalent, because you cannot safely swap one for the other without risk of overlap or other DRV. Commands like opt\_leakage\_power, or timing optimization on fixed instances, will attempt what is known as "lefsafe" swapping, where you replace one cell with another of the same size, pin geometry, antenna gate area, etc. You can do this postRoute without risk of overlaps or need to re-legalize the placement. If two cells have the same function and size but are not lefsafe, report\_lef\_equivalent\_cells will explain why.

| Example:                                                                     |
|------------------------------------------------------------------------------|
| report_lef_equivalent_cells -lib_cell INVXL -out_file myfile                 |
|                                                                              |
| LEF Equivalent cells { INVXL }                                               |
| Non-LEF Equivalent cells of same size but different pin geometries { INVX1 } |
|                                                                              |
| report_lef_equivalent_cells -lib_cell DFND4BWP22P90                          |
|                                                                              |
| LEF Equivalent cells { DFND4BWP22P90 DFND4BWP22P90ULVT }                     |
|                                                                              |

# **IMPOPT-7085**

### NAME

IMPOPT-7085

## **SUMMARY**

opt\_virtual is now using the GigaOpt optimization engine which is default in this release. Please update your scripts to remove any explicit settings of 'setDelayCalMode -engine feDc'or 'setDelayCalMode -engine signalStorm' so you get the default Advanced Analysis Engine (AAE)

delay calculator to enable the GigaOpt engine.

### DESCRIPTION

feDC delay calculation engine is not available in Innovus 14.2. When "setDelayCalMode -engine feDC" is executed, this error is seen. In Innovus 14.2, default delay calculation engine is AAE. If feDC delay calculation is required, revert to Innovus 13.2.

#### Example:

\*\*ERROR: (ENCOPT-7085): opt\_virtual is now using the GigaOpt optimization engine which is default in this release. Please update your scripts to remove any explicit settings of 'setDelayCalMode -engine feDc' or 'setDelayCalMode -engine signalStorm' so you get the default Advanced Analysis Engine (AAE) delay calculator to enable the GigaOpt engine.

\*\*ERROR: Batch process failed.

# **IMPOPT-7253**

## **NAME**

IMPOPT-7253

## **SUMMARY**

The standard cell <%s> is part of the timing library but does not have a physical definition. Please ensure that this cell is described in the LEF.

## DESCRIPTION

Please provide the LEF for the cell or mark the cell don't use (set\_dont\_use <cell> true)

# IMPOPT-7254

### NAME

IMPOPT-7254

## **SUMMARY**

The standard cell <%s> cannot be legally placed. opt\_design will consider the cell don't use.

## **DESCRIPTION**

Cell without row defined cannot be legally placed and should be marked don't use. Please add setDontUse on the cell or define row for the cell.

# **IMPOPT-7255**

### NAME

IMPOPT-7255

## **SUMMARY**

The net <%s> is marked don't touch and has %d fanout. Timing and drv optimization of such nets are limited.

## **DESCRIPTION**

The don't touch property can be removed using the command set\_dont\_touch

# **IMPOPT-7256**

## **NAME**

IMPOPT-7256

## **SUMMARY**

The net <%s> is ideal and has %d fanout. Timing and drv optimization of such nets are limited.

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

### DESCRIPTION

The ideal net property can be removed using the command reset\_ideal\_net/reset\_ideal\_network

# **IMPOPT-7257**

## NAME

IMPOPT-7257

## **SUMMARY**

The net <%s> has msv violation. Timing and drv optimization of such nets are limited.

## **DESCRIPTION**

To get more information about net with MSV violation, please run check\_power\_domains - nets\_missing\_iso -nets\_missing\_shifter

# **IMPOPT-7261**

### NAME

IMPOPT-7261

## **SUMMARY**

The drcMargin %f with internal margin of %f is less than 0 and so DRV will not be fixed up to the library/sdc defined target

## DESCRIPTION

The drcMargin considering the margin should be equal or greater than 0. A negative value will lead to underfixing DRVs.

# **IMPOPT-7262**

### NAME

IMPOPT-7262

### SUMMARY

Net %s has a bottom preferred layer defined on layer z=%d but the maximum route layer is lower and defined on layer z=%d.

## DESCRIPTION

A bottom preferred layer cannot be defined on a layer higher than the maxRouteLayer. It is recommended for the bottom preferred layer to be lower or equal to maxRouteLayer -1. It can be changed using set\_route\_attributes

# **IMPOPT-7263**

## **NAME**

IMPOPT-7263

### SUMMARY

Net %s has a bottom preferred layer defined on layer z=%d but the maximum route layer is defined same layer.

## **DESCRIPTION**

A bottom preferred layer should be a layer <= maxRouteLayer - 1. We need 2 layers to route the net. It can be changed using set route attributes

# **IMPOPT-7264**

## NAME

IMPOPT-7264

# **SUMMARY**

Running power optimization flow with leakage to dynamic ratio of %f but without activity file loaded.

## **DESCRIPTION**

Please provide activity file.

# **IMPOPT-7266**

# **NAME**

IMPOPT-7266

## **SUMMARY**

Running power optimization flow but no leakage power view provided.

# **DESCRIPTION**

Please use set\_analysis\_view -leakage <>.

# **IMPOPT-7267**

## **NAME**

IMPOPT-7267

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

# **SUMMARY**

Running power optimization flow but no dynamic view provided.

## **DESCRIPTION**

Please use set\_analysis\_view -dynamic <>.

# **IMPOPT-7268**

## **NAME**

IMPOPT-7268

## SUMMARY

Running power optimization flow but the leakage power analysis view '%s' is not part of the active analysis views.

## **DESCRIPTION**

The list of active view can be found using all\_setup\_analysis\_view and all\_hold\_analysis\_view. Please change the power view or make the power view active.

# **IMPOPT-7269**

## **NAME**

IMPOPT-7269

# **SUMMARY**

Running power optimization flow but the dynamic power analysis view '%s' is not part of the active analysis views.

### DESCRIPTION

The list of active view can be found using all\_setup\_analysis\_view and all\_hold\_analysis\_view. Please change the power view or make the power view active.

# IMPOPT-7271

## NAME

IMPOPT-7271

# **SUMMARY**

NDR %s doesn't exist in the database and will be ignored by gigaOpt.

## **DESCRIPTION**

The list of all available non default rule in the design can be found by using the following query dbGet head.rules.name

# **IMPOPT-7273**

#### NAME

IMPOPT-7273

### **SUMMARY**

check\_design cannot continue checking opt category due to invalid route\_trial maxRouteLayer value

## **DESCRIPTION**

The max route layer can be specified via the command set\_max\_route\_layer.

# **IMPOPT-7275**

### NAME

IMPOPT-7275

## **SUMMARY**

The net <%s> will not be routed due to skip\_routing property defined on the net.

## **DESCRIPTION**

Verify if the skip routing attribute is necessary or not. If it is not necessary, please use set\_route\_attributes to disable the skip routing attribute.

# **IMPPP-133**

## NAME

IMPPP-133

# **SUMMARY**

The block boundary of instance '%s' was increased to (%f %f) (%f %f) because cell geometry (%f %f) (%f %f) was outside the original block boundary.

## **DESCRIPTION**

Some blocks have pins or obstructions outside block boundary. The block boundary will be extended which may have influence on power planning around block area.

### NAME

IMPPP-188

## **SUMMARY**

The nets "%s" does not exist in the domain %s.

## **DESCRIPTION**

Make sure the nets specified have been connected to PG pin of the domain.

# **IMPPP-190**

## **NAME**

IMPPP-190

## **SUMMARY**

The net '%s' does not exist in design.

# **DESCRIPTION**

Make sure if the power nets have been defined in the globals file.

The power and ground nets are declared in the globals file using the following commands:

set init\_pwr\_net {VDD}

set init\_gnd\_net {VSS}

### NAME

IMPPP-333

### **SUMMARY**

%s can not be selected at the same time as stripe boundary. The power planner will generate stripes only over %s.

## **DESCRIPTION**

Selected objects can not be stripe boundary at the same time in one add\_stripes command. Check the selected objects if stripes are not generated in desired one.

# **IMPPP-354**

#### NAME

IMPPP-354

## **SUMMARY**

The power planner did not generate %s stripe at %f %f %f with width %f either because the stripe would merge with rings, or because stripe could not be connected to any legal targets, or because stripe would break design rule.

## **DESCRIPTION**

To debug the cause, first you can check if the stripe is removed because of obstruction or no target; then you can check the error/warning message in log file; at last you can add the stripe manually and run verify\_drc to check the drc violation. For further help, please contact Cadence Support.

### NAME

IMPPP-362

## **SUMMARY**

The area specified in option -area intersects both the default and nondefault power domains. The power planner will create stripes only over the default power domain.

## **DESCRIPTION**

When area specified in option -area intersects both the default domain and nondefault domains, power planner only creates stripes over default domain. If stripes are desired to be generated in nondefault domain, the specified area should be refined.

# **IMPPP-527**

## **NAME**

IMPPP-527

# **SUMMARY**

ViaGen failed to modify via %s.

## **DESCRIPTION**

This message may be reported because specified via size violates rules. Reasonable values should be specified.

### NAME

IMPPP-543

## **SUMMARY**

Inconsistent cut size definition in VIARULE '%s' and '%s'.

## **DESCRIPTION**

This warning indicates that there are multiple via sizes on the same cut layer without cut class definition.

# **IMPPP-557**

## NAME

IMPPP-557

## **SUMMARY**

A single-layer VIARULE GENERATE for turn-vias is obsolete and is being ignored. Remove this statement from the technology file: VIARULE %s GENERATE.

## **DESCRIPTION**

In old versions, special turn vias were defined to fill the corner with metal when a special route changed directions. Turn vias are no longer required in Innovus System as the router automatically makes a proper connection.

### NAME

**IMPPP-4033** 

### **SUMMARY**

The net '%s' is not a primary but secondary net of the power domain %s.

## **DESCRIPTION**

Tool can generate stripes of secondary net of a power domain. This message is to warn user for checking whether the net setting is right.

# **IMPPP-4051**

## NAME

IMPPP-4051

## **SUMMARY**

Fail to add rings. Gaps among IO cells may exist. Execute command add\_io\_fillers to fill gaps among cells before add\_rings.

## **DESCRIPTION**

If working on top level implementation, use "-follow io" switch to add\_rings command which creates the rings abutting to the boundary.

### NAME

**IMPPP-4055** 

## **SUMMARY**

The run time of add\_stripes will degrade with multiple cpu setting according to the number of stripe sets, ignore the setting of set\_multi\_cpu\_usage in add\_stripes.

## DESCRIPTION

add\_stripes uses multiple cpu feature dynamically according to the number of stripes to generate and the cpu on this machine. If the number of stripes is less, it's not recommended to use multiple cpu which may cost more runtime.

# **IMPPP-4500**

## NAME

IMPPP-4500

## **SUMMARY**

Large amount of geometries exist around {%f, %f} between Layer %s and %s. Long running time might be introduced.

## **DESCRIPTION**

This warning will typically be seen where a macro has very complex power pins. In turn these may be a result of mistakes in the creation of the abstract view for the macro.

### NAME

IMPPP-5000

# **SUMMARY**

The valude of -pattern contains illegal character, or the length is more than %d.

## **DESCRIPTION**

The legal characters for option -pattern are '1', '0', and ' '. And it has the maximum length restriction.

# **IMPPPR-638**

## **NAME**

IMPPPR-638

## **SUMMARY**

In line %d of constraint file '%s', the PAIR constraint does not have available bump or instance name, so it will be ignored.

## **DESCRIPTION**

At least a PAIR constraint should have one available bump and one available instance for the net.

### NAME

IMPPPR-641

### SUMMARY

In line %d of constraint file '%s', bump or IO instance '%s' cannot be found or not suitable for qui show bump connections, so it will be ignored for net '%s'.

## **DESCRIPTION**

The instance or bump name, pin name or port number does not exist; the net of IO port is different from PAIR net; or the IO port is too small or narrow.

# **IMPPSO-123**

#### NAME

IMPPSO-123

## **SUMMARY**

Option -continuePattern must be specified with -globalPattern option.

## DESCRIPTION

In power switch ring insertion, Option "-continuePattern 1" should be used along with -globalPattern option so that the power switch insertion pattern continues along the power domain edges. If "-continePattern 1" option is not specified, the pattern specified by -globalPattern stops at the edge and a new pattern starts from next edge.

#### Example:

In below example, a global pattern of switches is defined using -globalPattern

```
and same will continue around the power domain switch_pd as option -continuePattern is specified.
addPowerSwitch -ring \
-powerDomain switch_pd \
-enablePinIn {enIn} -enablePinOut {enOut} \
-enableNetIn "Ctrl1_ip_0" \
-enableNetOut "power_en_out" \
-globalSwitchCellName {{PSW65_1 sw1} {PSW65_2 sw2}} \
-globalPattern {sw1 sw2 sw2 sw1} \
-globalFillerCellName {FILLERcell} \
```

-continuePattern 1

## **NAME**

IMPPSO-133

#### SUMMARY

Power and/or Ground pin of inserted power switches might not be connected power or ground nets. Please check the CPF/power intent.

## **DESCRIPTION**

When power switches are added in design, the power and ground pins are also logically connected to power and ground nets based on CPF/power intent specification. In case this specification is found to be missing during power switch insertion using addPowerSwitch this warning message is shown.

Example:

To debug this issue, user should check below CPF specifications for debug:

Example:

create\_power\_domain -name PD\_VIRTUAL

update\_power\_domain -name PD\_VIRTUAL -primary\_power\_net VDDR

-primary\_ground\_net VSS

create\_power\_domain -name PD3 -instances inst1/b -shutoff\_condition {pse3}

-base\_domains PD\_VIRTUAL

create\_power\_switch\_rule -name psr\_pd3 -domain PD3 -external\_power\_net VDDR

update\_power\_switch\_rule -name psr\_pd3 -cells HDRDID1BWPHVT -prefix

CDN\_SW\_PD3

# **IMPPSO-134**

### NAME

IMPPSO-134

## **SUMMARY**

Adding power switches to an always on power domain.

#### DESCRIPTION

The power switches are supposed to be added for a switchable power domain for which - shufoff\_condition is defined in the CPF. This warning message is showed in case where power domain specified in-powerDomain option of addPowerSwitch does not have shutoff condition specified in CPF file.

#### Example:

To debug this issue, please check create\_power\_domain specification of the power domain specified in addPowerSwich.

addPowerSwitch -powerDomain PD2 -column ...

## In CPF, there is no shutoff condition.

create power domain -name PD2 -instances inst1/a

### NAME

IMPPSO-155

### **SUMMARY**

CPF option -acknowledge\_receiver of update\_power\_switch\_rule ignored due to -enableNetOut option specified.

## **DESCRIPTION**

This warning will be seen when there is -acknowledge\_receiver\_pin is defined in update\_power\_switch\_rule for the power domain specified in addPowerSwitch command. In case -enableNetOut is not specified in addPowerSwitch command, then the last enable net out from last power switch cell will get auto connected to the pin specified in acknowledge\_receiver\_pin. ( Here assumption is that there will be single enable net out from power switches) Since user is overriding this spec by giving -enableNetOut, this warning is given.

## Example:

addPowerSwitch -powerDomain PD -ring -globalSwitchCellName CDN\_RING\_SW \

- -enablePinIn NSLEEPIN -enableNetIn Net1 -enablePinOut NSLEEPOUT \
- -enableNetOut n\_5 -globalOffset 10 -switchModuleInstance mod11
- \*\*WARN: (IMPPSO-155): CPF option -acknowledge\_receiver update\_power\_switch\_rule ignored due to
- -enableNetOut option specified.

If you intended for the CPF -acknowledge receiver definition to be honored, do

not

use the -enableNetOut option.

### NAME

IMPPSO-170

### **SUMMARY**

Fewer power switches inserted than specified on side: %s

## **DESCRIPTION**

This warning message is seen during power switch ring insertion when user specifies number power switches to be inserted per power domain side. In case user specifies more number of power switches than the number that can be placed on a specific power domain edge/side, this warning message will be seen.

### Example:

Here user did ring type power switch insertion on power domain HEAD and specified 4 switches per side.

But on top and bottom edge only 3 switches were inserted and so the warning message.

Number of switches inserted for all sides: 4 3 4 3

\*\*WARN: (IMPPSO-170): Fewer switches inserted than specified on

side: 2 (Top) : 3 < 4

\*\*WARN: (IMPPSO-170): Fewer switches inserted than specified on

side: 4 (Bottom): 3 < 4

Total number of switches added to HEAD: 14

## NAME

IMPPSO-186

## **SUMMARY**

The specified module in -switchModuleInstance is in a different domain: %s

## **DESCRIPTION**

From the warning message it means that, the module user specified in-switchModuleInstance does not belong to the power domain user want to add using addPowerSwitch -powerDomain. User need to correct the '-switchModuleInstancea' or update your CPF if user miss defining the instance in power domain.

## Example:

```
addPowerSwitch -powerDomain PD_sw1 -column \
-globalSwitchCellName HDswHVT \
-switchModuleInstance INST/U_CPU_core/u_wrapper1 \
(Where PD_sw1a's hier. instance name is: INST/U_CPU_core/u_wrapper, see the 1 at the end)
```

\*\*WARN: (IMPPSO-186): The specified module in -switchModuleInstance is in a different domain: PD\_default != PD\_sw1 ...

# **IMPPSO-187**

## **NAME**

IMPPSO-187

## **SUMMARY**

The specified module in -switchModuleInstance domain and -powerDomain are different: %s

## **DESCRIPTION**

From the warning message, the module user specified does not belong to the power domain user want to add power switches i.e. as specified in addPowerSwitch -powerDomain. User need to correct the '-switchModuleInstancea', or update CPF if used missed defining the instance in power domain.

#### Example:

addPowerSwitch -powerDomain PD\_sw1 -ring \

- -globalSwitchCellName HDswHVT \
- -switchModuleInstance INST/soc core/u wrapper1 \

(Where PD\_sw1a's hierarchical instance name is: INST/soc\_core/u\_wrapper, see

the 1 in end of instance)

\*\*WARN: (IMPPSO-187): The specified -switchModuleInstance domain and

-powerDomain are different: PD\_default != PD\_sw1.

# **IMPPSO-188**

### NAME

IMPPSO-188

### **SUMMARY**

The power switches are added in domain %s which is different from the -powerDomain %s. You can use -switchModuleInstance to specify a correct module hierarchy of the power domain.

### DESCRIPTION

By default, addPowerSwitch will insert power switch instances into top design if user doesn't

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

provide -switchModuleInstance. When the default domain of the top design is not equal to -powerDomain, we will meet this message that the power switch instance is added into a domain which is different from-powerDomain. It's required to specify -switchModuleInstance to ensure that the power switch instances are inserted to the correct logic of the power domain.

# **IMPPSO-192**

## NAME

IMPPSO-192

## **SUMMARY**

The specified -enableNetIn is different from the power intent rule net: %s. The net name defined in cpf rule will be ignored. Please correct the net name if it's not the expected enable input net.

## **DESCRIPTION**

If you have already specified update\_power\_switch\_rule -enable\_condition or create\_power\_domain -shutoff\_condition in your CPF file, you do not need to specify this parameter. update\_power\_switch\_rule -enable\_condition takes precedence over create\_power\_domain -shutoff\_condition for enable net In connection. This message appears when the net name defined in -enableNetIn is different from the net in the power switch rule in the cpf file. You need to check if it's a correct net and correct it either in -enableNetIn or update power switch rule in cpf file.

# **IMPPSO-206**

## **NAME**

IMPPSO-206

### SUMMARY

First instance is not placed because it was blocked at location: %s. Please use offset options in addPowerSwitch to place the power switch instance in an available location.

### DESCRIPTION

addPowerSwitch will try to insert the power switch instances according to the offset options in addPowerSwitch. The issue usually appears when the offset value is not suitable. Please check the location in the message and tune the offset value to fix the issue.

# **IMPPSO-306**

### **NAME**

IMPPSO-306

## **SUMMARY**

row @%s with site %s is not covered by a switch. Type 'man IMPPSO-306' for more details.

### DESCRIPTION

The message could happen in addPowerSwitch or verifyPowerSwitch. addPowerSwitch will verify row coverage at end of a column insertion and print which row is not covered by a switch. You can turn it off with the option "-noRowVerify" in addPowerSwitch. You can use "addPowerSwitch - incremental -area" to insert the power switch to the location if you need the row to be covered by a switch.

# **IMPPSO-627**

## **NAME**

IMPPSO-627

## **SUMMARY**

Option '-reportViolationsOnly' for optPowerSwitch command is obsolete and has been replaced by '-reportOnly'. The obsolete option still works in this release, but to avoid this warning and to ensure compatibility with future releases, update your script to use '-reportOnly'.

### DESCRIPTION

This option '-reportViolationsOnly' of CMD 'optPowerSwitch' still works in this release(14.1), but to avoid this warning and to ensure compatibility with future releases, user should update the script to use option '-reportOnly'.

### Example:

If use below CMD and option in TCL file, IMPPSO-627 will exist.

<CMD> optPowerSwitch -reportViolationsOnly

WARNING (IMPPSO-627): Option '-reportViolationsOnly' for optPowerSwitch command is obsolete and has been replaced by '-reportOnly'. The obsolete option still works in this release, but to avoid this warning and to ensure compatibility with future releases, update your script to use '-reportOnly'.

... ...

This WARN will disappear after modify the TCL file to below:

<CMD> optPowerSwitch -reportOnly

# **IMPPSO-800**

### **NAME**

IMPPSO-800

### SUMMARY

Power switch verification completed with %s. Please check the issue in above messages.

### DESCRIPTION

verifyPowerSwitch will print all the warning messages after verification is completed and will summarize the total warning numbers. Please check the issues in the above messages.

## NAME

IMPPSO-806

### SUMMARY

Number of warnings on domain %s. Please check the issues in above warning messages.

## **DESCRIPTION**

Print the total number of warnings in the end of verifyPowerSwitch. User can check the issues in above warning messages.

# **IMPPSO-808**

## NAME

IMPPSO-808

## **SUMMARY**

Power switch instance pin is floating: %s. It's usually caused by addPowerSwitch could not find a available enable net to connect to the pin. Please use rechainPowerSwitch to reconnect the power switch instance pins.

## **DESCRIPTION**

The warning message usually appears when addPowerSwitch is completed. Please check the enable net connections of the power switch instances in the message. Use rechainPowerSwitch or update options in addPowerSwitch to fix the issue.

## NAME

IMPPSO-809

### **SUMMARY**

Power switch chain forms a loop involving the following: %s. The enable signal loops maybe formed accidently during enable net chaining. Please check the enable net connections of the power switch chain.

## **DESCRIPTION**

The message appears when verifyPowerSwitch -checkLoop to report if power switch enable chain forms a loop.

# **IMPPSO-906**

## **NAME**

IMPPSO-906

## SUMMARY

Option -unchainByInstances of command addPowerSwitch will become obsolete in the next major release as same option function is now available command rechainPowerSwitch - unchainByInstances. The obsolete option still works in this release, but to avoid this warning and to ensure compatibility with future release, update the scripts to use the command rechainPowerSwitch-unchainByInstances.

## **DESCRIPTION**

The power switch enable chain and unchain feature was first implemented as part of addPowerSwitch command. Now the power switch chain and unchain feature options are available

in command rechainPowerSwitch.

# **IMPPSO-907**

### NAME

IMPPSO-907

### SUMMARY

Option -chainByInstances of command addPowerSwitch will become obsolete in the next major release as same option function is now available under command rechainPowerSwitch - chainByInstances. The obsolete option still works in this release, but to avoid this warning and to ensure compatibility with future release, update the scripts to use the command rechainPowerSwitch-chainByInstances.

## **DESCRIPTION**

The power switch enable net chain and unchain feature options were previously made available using addPowerSwitch command. But later this functionality was moved to new command rechainPowerSwitch.So its recommended for user to use the feature with rechainPowerSwitch command

# **IMPPSO-1551**

## **NAME**

**IMPPSO-1551** 

# **SUMMARY**

IEEE1801 option -ack\_port of create\_power\_switch ignored due to -enableNetOut option specified.

# **DESCRIPTION**

Error and Warning Messages

This warning will be seen when there is -ack\_port is defined in create\_power\_switch for the power domain specified in addPowerSwitch command. In case -enableNetOut is not specified in addPowerSwitch command, then the last enable net out from last power switch cell will get auto connected to the pin specified in -ack\_port. ( Here assumption is that there will be single enable net out from power switches) Since user is overriding this spec by giving -enableNetOut, this warning is given.

#### Example:

addPowerSwitch -powerDomain PD -ring -globalSwitchCellName CDN\_RING\_SW \

- -enablePinIn NSLEEPIN -enableNetIn Net1 -enablePinOut NSLEEPOUT \
- -enableNetOut n 5 -globalOffset 10 -switchModuleInstance mod11
- \*\*WARN: (IMPPSO-1551): IEEE1801 option -ack port of create power switch ignored due to
- -enableNetOut option specified.

If you intended for the IEEE1801 -ack\_port definition to be honored, do

not

use the -enableNetOut option.

## **IMPPTN-90**

#### NAME

IMPPTN-90

#### SUMMARY

Pin %s of abutted partition %s could not be assigned. Could not find a feasible slot for the pin. Create more feasible location before for pin assignment by inserting feedthrough buffers using add\_partition\_feedthrus command or allowing more layers for assigning pins or using set\_db assign\_pins\_strict\_abutment false or using set\_db assign pins allow unconnected in abutted edge true for relaxing this check.

## **DESCRIPTION**

Error and Warning Messages

In order to resolve this issue, do the following before pin assignment:

#1 In abutted designs, pins of following type can not be placed on common edges between two adjoining partitions.

.in +2

- A. Pins of net not connected to adjacent partition (fences of the two partitions being connected are not touching each other in create\_floorplan).
- B. Pins of nets having connections to two or more partitions any pin belonging to net of above type will have to route over an unconnected partition and result in illegal routing.

Feedthrough step is required to get rid of pins which connect non-adjacent partitions or multiple partitions, by changing netlist and making all pins connect to only one pin on adjacent partition to make the routing of net feasible/legal

C. Floating pins

.in

#2. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

- #3. Use set\_db assign\_pins\_strict\_abutment false to relax abutment violations checks for placing multi partition pin of a net, non neighbor pins of a net and floating pins on abutted edges.
- #4. Use set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true to relax abutment violations checks for placing floating pins on abutted edges.

| Evam | പം   |  |
|------|------|--|
| Exam | DIE. |  |

-----

Error and Warning Messages

eg. if pins are not assigned for a net which has more than two partition pins to connect use add\_partition\_feedthrus command to change netlist to have new nets added and older net modified in way that, now nets only connect two pins of adjacent partitions only.

## **IMPPTN-100**

#### NAME

IMPPTN-100

#### SUMMARY

The net %s is not connected to any terminal. This net will not be considered for feedthrough buffer insertion. Correct the netlist to get this net considered for feedthrough buffer insertion.

#### DESCRIPTION

An unconnected net will not be considered for feedthrough insertion. The net should be connected to an output port and an input port to be considered for feedthrough insertion.

## **IMPPTN-233**

#### NAME

IMPPTN-233

### **SUMMARY**

No legal free slots available for %s of partition %s. Create additional slots using create\_partition command or by removing blockage before pin assignment.

## **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

# **IMPPTN-426**

#### NAME

IMPPTN-426

#### SUMMARY

Adjusting partition %s core to left from %f to %f because specified core spacing value is not multiple of placement grid.

## **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

| Example: |
|----------|
|----------|

Error and Warning Messages

<CMD> create\_partition -hinst uCORE/uPKTSS/uPKTSS\_PPCS\_PMA\_SYS -core\_spacing {2.7 2.7 1.9 1.9} -reserved\_layer {1 2 3 4 5 6 7 8} -route\_halo 1.9 -route\_halo\_top\_layer 7 - route\_halo\_bottom\_layer 1 -place\_halo {2.7 2.7 1.9 1.9} -rail\_width 0.1 -min\_pitch\_left 3 - min\_pitch\_right 3 -min\_pitch\_top 3 -min\_pitch\_bottom 3 -pin\_layer\_top {3 5} -pin\_layer\_bottom {3 5} -pin\_layer\_left {4 6} -pin\_layer\_right {4 6}

Creating partition PKTSS\_PPCS\_PMA\_SYS.

- \*\*WARN: (IMPPTN-426): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to left from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-427): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to right from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-428): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to top from 2.700000 to 2.850000.
- \*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

Placement grid is at 0.135 x-direction, 0.095 y-direction.

## **IMPPTN-427**

### **NAME**

IMPPTN-427

#### SUMMARY

Adjusting partition %s core to right from %f to %f because specified core spacing value is not multiple of placement grid.

#### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Error and Warning Messages

| Example: |  |
|----------|--|
|----------|--|

\*\*WARN: (IMPPTN-427): Adjusting partition lbrx\_top\_0 core to right from 0.000000 to 0.100000.

# **IMPPTN-428**

#### NAME

IMPPTN-428

#### **SUMMARY**

Adjusting partition %s core to top from %f to %f because specified core spacing value is not multiple of placement grid.

#### **DESCRIPTION**

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

\*\*WARN: (IMPPTN-428): Adjusting partition lbrx\_top\_0 core to top from 0.000000 to 3.680000.

# **IMPPTN-429**

## **NAME**

IMPPTN-429

#### SUMMARY

Adjusting partition %s core to bottom from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

\*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

## **IMPPTN-555**

### **NAME**

**IMPPTN-555** 

#### SUMMARY

A feasible legal location was not found for %d (out of %d) pins. Consequently, the following pins could not be assigned:

#### DESCRIPTION

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

A. By removing blockages

- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## **IMPPTN-624**

### **NAME**

IMPPTN-624

#### SUMMARY

add\_partition\_feedthrus could not find a path for net '%s' to reach '%s'. If the -topoFile option is being used, the topology specified for this net is incomplete.

### DESCRIPTION

In case automatic feedthrough insertion is being done, it means that a path to some of the terminals could not be found. If the routeBased option is used, the routing may be incomplete. For the case the topology file is used an explanation follows.

Tool issues above warning during add\_partition\_feedthrus command step, when topology file provided with -topoFile is used to guide the tool for creating the feedthrough in a specified partition for multi-fanout nets. You will get above warning if the topology file did not define for all the terminals for a multi-fanout net. Always follow the convention from\_pin to to\_pin for writing the topology file.

### Example:

If the net goes to three partition A, B and C and you want to make a part of the net from A to D then

Error and Warning Messages

to C, then you can use the following approach to write the topology file.

net n123

hinst-hinst A D;

hinst-hinst D C;

hinst-hinst A B;

end net

So, here all the combinations are covered where the net goes, instead of defining the A-D-C.

## **IMPPTN-646**

### NAME

IMPPTN-646

#### **SUMMARY**

add\_partition\_feedthrus is trying to find a feedthrough path for net %s. It could not find a path to partition or terminal [%s]. Partitions connected to this net may not be adjacent to each other.

## **DESCRIPTION**

Automatic feedthrough insertion derives the feedthrough topology using the placement. It assumes a channel-less design. The possibility of routing through channels is considered minimal. In this design a path to a partition or terminal connected to the above mentioned net could not be found without avoiding the channels.

## **IMPPTN-647**

## **NAME**

IMPPTN-647

#### **SUMMARY**

add\_partition\_feedthrus skipping net [%s] because a path to some of the partitions or terminals could not be found. It might not be necessary to insert feedthrough buffers for this net. If you wish to insert feedthrough buffers for this net, then use the topology file for guided feedthrough buffer insertion or use the -routeBased option after routing the net.

### DESCRIPTION

add\_partition\_feedthrus assumes the design to be channel-less and partitions to be in the line of sight for feedthrough path to pass from one partition to another. In case of channel based designs where this is not true, the named net is ignored. In case feedthrough insertion is required for the net, either route the design and used add\_partition\_feedthrus -routeBased or define the path for the net in a topology file and use add\_partition\_feedthrus -topoFile <filename>

```
Example:
-----
route_early_global
add_partition_feedthrus -routeBased
Or
add_partition_feedthrus -topoFile <filename>
```

# **IMPPTN-652**

#### **NAME**

IMPPTN-652

### **SUMMARY**

The push\_down\_buffer command cannot create an instance with name [%s%s]. An instance with this name already exists in the design. Using default prefix and name [%s] for this instance.

## **DESCRIPTION**

Error and Warning Messages

This message is issued if the push\_down\_buffer uses the prefix provided with the -prefix option and the resulting name has a conflict with an existing instance name. No action needs to be taken as it will make another name with the default prefix.

# **IMPPTN-716**

#### NAME

IMPPTN-716

#### SUMMARY

Partition %s constraint missing. Specify a Guide, Region, Fence constraint on the partition or place the blackbox instance.

#### DESCRIPTION

While committing partitions 1. Blackboxes should be placed inside core 2. Partitions fences must be core

## **IMPPTN-780**

#### NAME

IMPPTN-780

### **SUMMARY**

Selected pin assignment: could not assign %d (out of %d) pins because feasible legal location was not found for following pins, need legal locations for pin to be assigned.

## **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## **IMPPTN-882**

#### NAME

IMPPTN-882

### **SUMMARY**

The add\_partition\_feedthrus command was invoked with the -routeBased option, but the design has not yet been routed. The add\_partition\_feedthrus command will skip the nets that are not routed. Route the design using route\_early\_global for these nets to be considered for feedthrough insertion.

#### DESCRIPTION

The add\_partition\_feedthrus command invoked with the -routeBased option requires routing for the net to find a path based on which it will insert the feedthrough ports.

The net reported is not routed so it gets ignored. Route the design prior to running this command.

Error and Warning Messages

The route early global command can be used to route the design.

Otherwise add\_partition\_feedthrus should be invoked without using the -routeBased option in which case the command will try to find a path for the net based on the create\_floorplan and placement (placement based feedthrough insertion).

Example:
----route\_early\_global
add partition feedthrus -routeBased.

## **IMPPTN-946**

### **NAME**

IMPPTN-946

### **SUMMARY**

Pin named [%s] does not exist in cell [%s]. Ignoring the pin. Check and correct the pin name.

## **DESCRIPTION**

Pin name specified for the specified partition does not exist. Check the pin name and partition name and correct accordingly. Problem could be case sensitivity. Command requires exact name which is case sensitive or incorrect manipulation of "alphabet I or numeric 1" "likewise "alphabet o and numeric 0"

Example:

-----

Pin name could be "isCaseSensitive" but pin name supplied could be "iscasesensitive

## **IMPPTN-1211**

#### NAME

IMPPTN-1211

#### SUMMARY

Specified layer [%s] is not within the allowed pin layer range [%s] and [%s] of the partition %s. Respecify a valid pin layer value or change the partition definition to allow this pin layer and rerun the command again.

### **DESCRIPTION**

Specified layer is not within the allowed pin layer range of the specified partition. Use the Partition->Specify Partition GUI to view the current specified allowed layers. Edit the current allowed pin layers of the partition to include this specified pin layer or re-specify pin layer and rerun the command again.

## **IMPPTN-1250**

### **NAME**

**IMPPTN-1250** 

### **SUMMARY**

Pin placement has been enabled on metal layer 1.

## **DESCRIPTION**

You have this message because you have enabled metal layer 1 for pin placement. However, metal layer 1 is generally reserved for follow pins. Make sure follow pins are already routed, to ensure that the pins do not block follow pins creation.

Error and Warning Messages

| Exa | ample:      |          |           |         |         |         |    |
|-----|-------------|----------|-----------|---------|---------|---------|----|
|     |             |          |           |         |         |         |    |
| set | _db design_ | _bottom_ | _routing_ | layer 1 | enables | pins ir | M1 |

# **IMPPTN-1520**

#### NAME

IMPPTN-1520

#### SUMMARY

Pin '%s' of %s '%s' cannot be placed at the constrained location [%0.2f %0.2f] due to a blocked pin slot close to the location. Placing the pin at location [%0.2f %0.2f].

#### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

# **IMPPTN-1521**

## **NAME**

**IMPPTN-1521** 

#### SUMMARY

Unable to get any valid location for the constrained pin [%s] at location [%0.2f %0.2f].

#### DESCRIPTION

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## **IMPPTN-1550**

#### **NAME**

**IMPPTN-1550** 

#### SUMMARY

Cell [%s] cannot be specified as a black box because the design does not have any instance associated with this cell or instance may create nested blackBox. Ensure the design has an instance referenced to this cell or specify correct name of cell and rerun %s again.

### **DESCRIPTION**

Specified cell cannot be defined as a black box because the design does not have any instance that is referenced to this cell or instance may create nested blackBox. Ensure there is at least one instance that is associated with this cell and rerun the command again.

## **IMPPTN-1669**

### **NAME**

**IMPPTN-1669** 

#### **SUMMARY**

Ptn %s does not have any reserved slots for assigning ptn pins. Check the allowed layers for the partition and make sure that layers based on preferred routing tracks are reserved.

#### **DESCRIPTION**

This warning message is issued while assigning pins on a partition using the Innovus GUI with Partition => Assign Pin... or when using the assign partition pins Tcl command.

The create\_floorplan likely contains a problem with routing tracks and/or pin layer definitions. The problem can be debugged graphically using: Partition => Specify Partition

Select the offending partition and review the Partition Pin Layer Used section. Make sure the layers defined for pins are included in the Layers Reserved For Partition. Corrections may be made and applied with this form. Check the min max layer allowed though get\_db another reason could be presence of route blockage or PG on partition edge blocking the routing tracks.

Next, confirm there are preferred routing tracks defined for the pin layers using the Layer Control => Track => Pref Track and the Wire&Via layer defined for the pins. If the tracks are incorrect, they may be regenerated using the "generateTracks" Tcl command.

#### Example:

get\_pin\_constraint -cell c -side all -layer

Constraint on partition c:

Allowed layer on side [top]: 246

Allowed layer on side [left]: 35

Allowed layer on side [bottom]: 2 4 6

Allowed layer on side [right]: 35

get db design bottom routing layer design top routing layer

design\_bottom\_routing\_layer 2 # string, default=""

design\_top\_routing\_layer 15 # string, default=""

{design bottom routing layer 2} {design top routing layer 15}

Look for the Tracks in a section with: Track:

While corrections can be made to the tmp.fp file and reloaded with the "read floorplan tmp.fp" Tcl

command, it is generally easier to do make changes with the Innovus GUI.

## **IMPPTN-1671**

### **NAME**

IMPPTN-1671

#### SUMMARY

The option %s cannot be used for updating pin attribute. Correct the command options and run the command again.

#### DESCRIPTION

Specified option cannot be used for just updating pin attribute. This option is used with other options for assigning pin location. Check the reference manual for the legal specified options. Then correct the command options and rerun the editPin command again.

## **IMPPTN-1699**

## **NAME**

**IMPPTN-1699** 

#### SUMMARY

Selective-pin-assignment by specifying just partition name(s) to command assign\_partition\_pins is obsolete and will be removed in future releases. The old usage still works in this release, but to avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with "assign\_partition\_pins -partitions -pins".

## **DESCRIPTION**

To avoid this warning and to ensure compatibility with future releases, replace the obsolete usage

Error and Warning Messages

with 'assign\_partition\_pins -partitions <ptnName> -pins <pinName>'

Example:

-----

\* The following command assign pins name starting with "in" of partition "A" and pins name starting with "out" of partition "B"

assign partition pins -partitions {A} -pins {in\*} -partitions {B} -pins {out\*}

\* The following command accept a file pinLst.txt that contains the list of pins to be placed for partition A and partition B.

assign partition pins -partitions A -partitions B -pin file pinLst.txt

## **IMPPTN-1704**

#### NAME

IMPPTN-1704

### **SUMMARY**

The options [-row] and [-bringBackRow] are obsolete. Rows are brought back automatically, without using any of these options. To avoid this warning and ensure compatibility with future releases, update your script to not use any of these options.

### **DESCRIPTION**

This messages is issued when obsolete options are used. Using these options will have no impact in this case.

Example:

-----

eg. use uncommit\_partitions

# **IMPPTN-1717**

#### NAME

IMPPTN-1717

#### SUMMARY

The specifyPartition command will be obsolete in the next release. Use the create\_partition command to define the partitions.

#### **DESCRIPTION**

The message occurs because you are using 'specifyPartition' which is obsoletelease use the 'create\_partition' command to define the partitions.

```
Example:
-----
The following example defines a partition:
create_partition \
-hinst ctr_inst \
-core_spacing 0.56 0.56 0.0 0.0 \
-rail_width 0.0 \
-min_pitch_left 2 \
-min_pitch_right 2 \
-min_pitch_top 2 \
-min_pitch_bottom 2 \
-reserved_layer {1 2 3 4} \
-pin_layer_top {2 4} \
-pin_layer_left {3} \
-pin_layer_bottom {2 4} \
-pin_layer_right {3} \
-pin_layer_right {3} \
```

-place\_halo 1.0 1.0 1.0 1.0 \
-route\_halo 1.0 \
-route\_halo\_top\_layer 7 \
-route\_halo\_bottom\_layer 1

## **IMPPTN-1755**

#### **NAME**

IMPPTN-1755

#### **SUMMARY**

Pin [%s] of %s [%s] connected to net [%s] is [%s] at location (%8.3f, %8.3f) on layer %1d %s.

### **DESCRIPTION**

Message reports specific error/violation on a partition pin.

Example of ABUTMENT violation on a pin:

-----

Pin [pin\_1] of partition [ptn\_1] connected to net [net\_1] is [PLACED] at location (210.452, 540.160) on layer 8 has ABUTMENT violation WITH partition chip.

In above example error/violation is being reported for partition "ptn\_1" pin's "pin\_1" which is connected to net "net\_1" and is placed at location "210.452, 540.160" on layer "8" having assignment status as "placed". Pin has abutment (is placed on adjoining boundary of "ptn\_1" and "chip") violation with partition named "chip". Ideally the pin pair of two adjoining (abutting) partitions should be placed on same track on edge of partition boundaries, touching each other (abutting).

Abutment violation could be because of following two reasons:

- 1. Net has multi-partition-pins. Since all other pins of different partitions cannot be placed at same location (no electrical connection through any overlap of physical shape), so it is reported as abutment violation.
- 2. "pin\_1" pin of net "net\_1" is not connected to any pin of adjoining (abutted) partition "chip".

Error and Warning Messages

List other violations on pin:

- pin min-width violation
- pin min-depth violation
- pin missing metal shape violation
- pin min-area violation
- pin-color violation
- pin not on routing track (or ndr-rule-routing-track) violation
- pin not on fence violation
- pin spacing (drc and spacing constraints) violation
- pin not on allowed layer violation
- For nested partition it checks for child fence area violation
- pin outside pin-guide or bus-guide violation
- Pin associated pin-group or net-group violation

## **IMPPTN-1802**

#### NAME

**IMPPTN-1802** 

### **SUMMARY**

Route layer setting through routing modes [set\_db %s <value>] or [set\_db %s <value>] setting will not be honored. Set the value using setDesignMode command [set\_db %s <value>] and run the command again.

### **DESCRIPTION**

This message is reported related to IO pin routing if there are any IO pins falls above maxRouteLayer. Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer, and user would like to set min/max layer of pin that is different from route early global. Innovus

Error and Warning Messages

checks for this issue and generate the message as user may forget to set min/max layer of pin when it differs from route\_early\_global.

Example:

-----

Because of the following reason the ENCPTN-1802 is reported.

Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set db or set db for minLayer but has missed to set setDesignMode for minLayer.

Use "set db design top routing layer < layer>" to placing IO pins, to avoid this problem.

## **IMPPTN-3207**

#### NAME

IMPPTN-3207

### **SUMMARY**

The hierarchical-PG net %s is connected to an instance term %s inside the partition hinst %s. However, it is not connected to any PG port of the partition hinst. This is erroneous data. As a consequence, instance term %s will become unconnected. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside the partition, and run the command again.

### DESCRIPTION

Reason of such incorrect PG net connection is generally introduced by either incorrect UPF or incorrect GNC rule. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside partition. Or, if this connection is not needed inside the partition hinst, then ensure that the net does not connect to any of the PG terms inside the partition hinst.

# **IMPREPO-102**

#### NAME

IMPREPO-102

#### **SUMMARY**

Instance %s of the cell %s has no physical library or has wrong dimen- sion values (<=0). Check your design setup to make sure the physical library is loaded in and the attributes specified in physical library are correct.

### **DESCRIPTION**

Check LEF files to see if the cell is defined in LEF; if it is, then check if it's dimension is defined by number which is less than 0.

# **IMPRM-143**

### **NAME**

IMPRM-143

#### **SUMMARY**

%s is not defined on cut layer "%s" in the technology DB. VIARULE GENERATE values will be used instead. The generated vias, using the VIARULE GENERATE values, are probably not optimal for signal routing and pin access.

#### DESCRIPTION

This command requires correct enclosure rules to auto-generate correct vias. This warning reports that enclosure rules are not defined on the layer and/or for the cut class, so the cut enclosure values in the VIARULE GENERATE statement will be used. This is not recommended usage except for old technology (LEF version 5.5 and older), because the VIARULE values are often larger than the

Error and Warning Messages

DRC rules require, which will cause the vias to be too large. Routing results with these vias will likely be more congested and produce longer wires. Check the LAYER section of the technology definitions (the first file listed in the init\_lef\_files variable), to ensure enclosure rules are defined correctlylease note: the ENCLOSURE rule is used by add\_route\_via\_defs, not ENCLOSUREEDGE rule. You can look at the LEF/OA manual to find the correct syntax.

Example: \*\*WARN: (ENCRM-143): ENCLOSURE ABOVE for CUTCLASS VSINGLECUT is not defined on cut layer "VIA4" in the technology DB. VIARULE GENERATE values will be used instead. The generated vias, using the VIARULE GENERATE values, are probably not optimal for signal routing and pin access.

Example: Example of ENCLOSURE rule used by add route via defs: PROPERTY LEF58 ENCLOSURE "ENCLOSURE CUTCLASS VX ABOVE 0 0.03; ENCLOSURE CUTCLASS VX ABOVE 0.02 0.02; **ENCLOSURE CUTCLASS VX BELOW 0 0.03:** ENCLOSURE CUTCLASS VX BELOW 0.02 0.02; ENCLOSURE CUTCLASS VXBAR ABOVE END 0.02 SIDE 0.02; ENCLOSURE CUTCLASS VXBAR ABOVE END 0.03 SIDE 0.01; ENCLOSURE CUTCLASS VXBAR ABOVE END 0.04 SIDE 0; ENCLOSURE CUTCLASS VXBAR BELOW END 0.02 SIDE 0.02; ENCLOSURE CUTCLASS VXBAR BELOW END 0.03 SIDE 0.01; ENCLOSURE CUTCLASS VXBAR BELOW END 0.04 SIDE 0: If the ENCLOSURE rule is missing, the VIARULE GENERATE value will be used: VIARULE M2 M1 GENERATE LAYER M1: ENCLOSURE 0.03 0.03; WIDTH 0.05 TO 4.5; LAYER M2;

Error and Warning Messages

| ENCLOSURE 0.03 0.03;           |
|--------------------------------|
| WIDTH 0.05 TO 4.5 ;            |
| LAYER VIA1 ;                   |
| RECT -0.025 -0.025 0.025 0.025 |
| SPACING 0.13 BY 0.13 ;         |
| END M2 M1                      |

## **IMPRM-148**

### **NAME**

IMPRM-148

#### **SUMMARY**

Command 'add\_route\_via\_defs' is normally used for debugging and testing. The vias are only generated in this Innovus session, and will not be kept during write/read for nanoroute to use the next time. Use 'set\_db add\_route\_vias\_auto true' before 'init\_design' or 'read\_db' if you want generated vias to be used by nanoroute in later Innovus sessions.

### **DESCRIPTION**

Command 'add\_route\_via\_defs' can generate all the vias for signal routing automatically, including single cut vias, double cut vias, MAR vias, and even DFM vias. It is used in the Innovus flow, to help insure good routing results. Users don't need to manually create vias to meet the complex rules in advanced technology, 'genereateVias' will consider the rules (including non-default rules) and create the vias needed for routing. Since the vias are only generated in current Innovus session, and will not be kept during write/read for NanoRoute to use the next time, this command is only used for debugging and testing. The standard usage flow is to set 'set\_db add\_route\_vias\_auto true' before 'init\_design' or 'read\_db'. It will call 'add\_route\_via\_defs' whenever the design is initialized or restored in innovus. This mode option setting can be saved in database by write\_db. You can get more information about 'set\_db' by 'man set\_db'.

| ∟xa | m | pı | е |  |
|-----|---|----|---|--|
|     |   |    |   |  |

Debug flow example:

read db

add route via defs

route design

Standard usage flow example:

set db add route vias auto true

read db

route\_design

# **IMPSC-1001**

#### NAME

IMPSC-1001

### **SUMMARY**

Unable to trace scan chain "%s". Check the information during tracing.

#### DESCRIPTION

Possible reason for scan trace failure is that instance in the scan chain has multiple corresponding pins for scan tracing.

How to solve the problem:

1. Use a Scan DEF file to define the exact instance pins trace\_scan should trace through. Most modern synthesis tools can export a Scan DEF file which can then be imported into Innovus System using the read\_def command:

read\_def scanchain.def

- 2. If the design contains bidirectional pads, try defining the start/stop points of the scan chain on the core side of the pad so the tracer does not have to trace through the pad.
- 3. If instances in the scan chain has complex logic, set "set\_db reorder\_scan\_comp\_logic true" before trace scan.

Error and Warning Messages

#### Example:

-----

If the message is preceded with the following warnings:

\*\*WARN: (ENCSC-1020): Instance's output pin "reg\_1/Z" (Cell "DFFX12") has multiple corresponding input pins for scan tracing.

Please either specify the instance in the DEF scanchain, or use "set\_db reorder\_scan\_comp\_logic true". Otherwise scan trace may not succeed.

Then set setScanRorderMode reorder\_scan\_comp\_logic true prior to scan tracing. This will enable an advanced algorithm for tracing complex logic (gates with multiple inputs)

# **IMPSC-1010**

### NAME

IMPSC-1010

### **SUMMARY**

During incremental tracing, scan chain "%s" cannot trace from "%s" to "%s". Perform regular trace.

## **DESCRIPTION**

Incremental tracing will perform register to register tracing without other scan flops in between.

Check if any other scan flops were inserted between them in the flow.

# **IMPSC-1022**

## **NAME**

IMPSC-1022

## **SUMMARY**

Instance's output pin "%s/%s" (Cell "%s") has no corresponding input pin for scan tracing.

#### DESCRIPTION

After reading scandef file, Innovus system gives the message during trace\_scan. The warning message here is due to fact that scandef file and the verilog netlist are not compatible with respect to the scan chain and so tool is not able to trace it.

#### Example:

-----

\*\*WARN: (ENCSC-1022): Instance's output pin "i\_Scan/i\_Core/i\_inst/QN" (Cell "XXX") has no corresponding input pin for scan tracing.

The relevant part in the scandef file is like below:

========

#### + ORDERED

i Scan/i Core/i inst (IN SI) (OUT Q) ---> It should be QN here.

i\_digitalScan/i\_digitalCore/U9714 (IN B1) (OUT ZN)

\_\_\_\_\_

The output "QN" is reported by the tool for not having corresponding input pin for scan tracing because the scan chain is defined over the pin "Q" in scandef file.

The scan chain is defined at negated output QN of the Flop but scan def file points to pin Q of the flop (which is not the part of scan chain) and hence tool is not able to trace it. So, make sure that scandef file and the verilog netlist are compatible with respect to the scan chain for the tool to trace it successfully.

## **IMPSC-1138**

#### **NAME**

IMPSC-1138

#### SUMMARY

In scan chain "%s" DEF ordered section, buffers or logics following scan instance "%s" are

Error and Warning Messages

corrected to match the netlist.

#### DESCRIPTION

This message is generated when the original SCAN DEF does not match the design netlist. One possible reason this may happen is because of an ECO operation which adds a buffer to a scan chain for hold fixing.

```
Example
------
Sample SCAN DEF (excerpt):
...
u1/u2/u3/reg_0_6 (IN SI) (OUT Q)
u1/u2/u3/reg_0_7 (IN SI) (OUT Q)
u1/u2/u3/reg_0_8 (IN SI) (OUT Q)
```

Adding a buffer between reg\_0\_7 and reg\_0\_8 (to possibly fix a hold violation) will generate the above message.

# **IMPSE-31**

#### **NAME**

IMPSE-31

## **SUMMARY**

Tool name list given is not a proper TCL list: '%s'.

## **DESCRIPTION**

Please correct the list and try again.

# **IMPSE-32**

#### NAME

IMPSE-32

#### **SUMMARY**

Failed to locate '%s' in Cadence Online Support documents.

### **DESCRIPTION**

The documents may not be installed correctly, or the content you are searching for is not in the documents. Try searching for a command you know exists to see if the installation is correct. If that fails, look at the User Guide Installation chapter for how to install the documents.

# **IMPSE-34**

#### NAME

IMPSE-34

## **SUMMARY**

Metric snapshot stack is not at the top level.

### **DESCRIPTION**

A metric report was generated while still within a nested snapshot. This suggests a missing pop snapshot stack.

# **IMPSE-35**

### NAME

**IMPSE-35** 

### **SUMMARY**

Attempt to set undefined metric: %s

### **DESCRIPTION**

An attempt was made to set and undefined metric.

# **IMPSER-514**

### **NAME**

IMPSER-514

### **SUMMARY**

Binary DB for leaf cell %s has extra terminal %s. This terminal is not found in the .lef/.lib library definition. Connectivity of this terminal will be lost while reading the binary DB.

#### DESCRIPTION

One possible reason could be that either .lef/.lib are edited after the design was saved OR .lib is not being read that has the definition of missing terminal.

# **IMPSP-101**

#### NAME

IMPSP-101

#### SUMMARY

setPlaceMode Option '%s' is obsolete in current release. Use setPlaceMode option '%s' instead to access the same functionality.

### **DESCRIPTION**

In Innovus some setPlaceMode options are made obsolete because another setPlaceMode option is developed to provide better functionality or usability. This message tells user that equivalent setPlaceMode option %s should be used instead of obsolete setPlaceMode option %s.

# IMPSP-105

### NAME

IMPSP-105

#### SUMMARY

'setPlaceMode -maxRouteLayer' will become obsolete from next release. Use 'setRouteMode - earlyGlobalMaxRouteLayer N' to set maximum routing layer.

## **DESCRIPTION**

The message occurs because there is a command usage to set maximum routing layer, which is

Error and Warning Messages

'setRouteMode -earlyGlobalMaxRouteLayer N'. The original command 'setPlaceMode - maxRouteLayer' will become obsolete from next release. Please update your script with the new command usage.

Example:

-----

The following example sets the maximum routing layer to metal 7:

.in +4

innovus> setRouteMode -earlyGlobalMaxRouteLayer 7

.in

# **IMPSP-157**

#### NAME

IMPSP-157

### **SUMMARY**

Macro '%s' is not placed within core boundary.

### **DESCRIPTION**

Macro '%s' is not placed within core boundary with location (%d,%d). This will cause issues for placement and downstream flow. Either use place\_inst command to fix the macro inside core boundary or redo the floorplan using plan\_design command.

Example:

-----

\*\*WARN: (IMPSP-157):

Macro 'u\_rxb\_wrapper/u\_rxf/u\_hm\_0/u\_hm\_mem\_edram\_2port\_3/u\_edram/

WRAPBRCD/INTWRAP/DRAMT' is not placed within core boundary

To fix this warning use place\_inst command to place macro inside the core.

Error and Warning Messages

place\_inst

u\_rxb\_wrapper/u\_rxf/u\_hm\_0/u\_hm\_mem\_edram\_2port\_3/u\_edram/WRAPBRCD/INTWRAP/DRAMT 398.7 1480.2 -fixed

# **IMPSP-167**

### NAME

IMPSP-167

### **SUMMARY**

Layer Number Provided for MaxRouteLayer option exceeds the MaxLayerNumber for the design. Current option '%s' is ignored.

### **DESCRIPTION**

Need to get rid of this warning as we have deprecated MaxRouteLayer in setPlaceMode.

Example:

-----

# **IMPSP-182**

### **NAME**

IMPSP-182

### **SUMMARY**

Placeable area is 0. Stopping placement.

Error and Warning Messages

#### DESCRIPTION

This error is issued during place\_design. Placement does not proceed when the available space for placing instances is zero.

This can be confirmed through the following message from place\_design which shows the allocated area is 0:

Density for the design = 2311140.000.

= stdcell\_area 2311140 (330225 um^2) / alloc\_area 0 (0 um^2).

Please check if the design is completely blocked by placement blockage. User may find that a placement blockage cover the block. Also, make sure that there are sites / rows defined in the design.

## **IMPSP-183**

#### NAME

IMPSP-183

#### **SUMMARY**

Design has %s associated with some modules." "So software will override the current '0' value of '-keepEmptyModule'" "of import\_mode. Empty modules will not be deleted.

### **DESCRIPTION**

Default value 1 of -keepEmptyModule, is being applied to this mode option, as deleting an empty module which has constraint or power-domain associated with it can result in DB integrity issues. Hence, to ensure that software does not seg-fault, this option is being reverted back to its default value.

### NAME

IMPSP-185

#### **SUMMARY**

Found user set 'fastPolygon' mode for placement legalization API.

### **DESCRIPTION**

LEF MACRO geometries (PORT, OBS) are defined using POLYgon shapes, rather than RECT shapes. As DRV checking works with RECTs, these polygons need to be broken down to rectangle during checks. This can effect run-time, and in current implementation, is not thread-safe. This may have an effect on GigaOpt Engine.

# **IMPSP-259**

### NAME

IMPSP-259

### SUMMARY

\*\*Info: (IMPSP-259): %s %s was not on the placement grid. It has been moved from (%d,%d) to (%d,%d).

# **DESCRIPTION**

Example:

Error and Warning Messages

-----

\*\*Info (IMPSP-259): Cell icg\_f16\_dh\_12t\_svt is not on the placement grid. It has been moved from (2181212,1019656) to (2181060,1019200).

# **IMPSP-260**

#### NAME

IMPSP-260

### **SUMMARY**

Inst %s (cell %s) cannot be legally placed in constraint %s.

### **DESCRIPTION**

Inst %s (cell %s) cannot be legally placed in constraint %s. Most probably there is not enough space available in the constraint %s to legally place the cell. Increase the area of constraint %s and re-run placement again.

Example:

-----

# IMPSP-263

### **NAME**

IMPSP-263

### **SUMMARY**

Cannot find access pin for fterm '%s' (cell '%s').

Error and Warning Messages

### **DESCRIPTION**

This warning message is generated when there is no pin geometry for a cell's pin defined in the LEF file. This needs to be corrected so the router can route to the pin. Review the LEF being read in for this cell and confirm the physical shape of the pin is described in the PORT statement.

Example:

-----

Warning message was generated when running place\_design.

The RECT statement below describes the geometry of the pin shape. If this is missing, the warning above is issued:

MACRO INVD1

.in +2

...

PIN I

.in

.in +4

**DIRECTION INPUT;** 

**PORT** 

LAYER M1;

RECT .5 2 1 2.5;

**END** 

.in

.in +2

**ENDI** 

.in

If the pin is defined properly in the LEF, confirm this LEF file is specified in the configuration file and is read in before an antenna LEF files for this cell.

# **IMPSP-270**

### NAME

IMPSP-270

## **SUMMARY**

Cannot find a legal location for MASTER CELL '%s'.

### **DESCRIPTION**

Possible reasons for not finding any legal location for a cell are:

- 1. Cell's techSite has no rows in floorplan. To fix re-init floorplan
- 2. Width of cell is too large for the dense power stripes' pitch. Make sure that stripe's layer is not being treated as obstruction set\_db place\_detail\_preroute\_as\_obs setting may need to change.

# IMPSP-288

### NAME

IMPSP-288

### **SUMMARY**

Power domain %s has no fence constraint. Placement will ignore this power domain ...

### DESCRIPTION

Given Power Domain does not have an area specified for restricting

Error and Warning Messages

placement of its members. If this power domain needs level-shifters or isolation from other power domains, then tool will not be able to place these shifters/isolation cells to the power domain area boundary, to properly isolate.

Use command update power domain to specify a box for this domain.

# IMPSP-300

### NAME

IMPSP-300

## **SUMMARY**

No layer1-to-layer2 spacing rule specified for any Implant layer in-use. Ignoring - honorImplantSpacing option.

### **DESCRIPTION**

-honorImplantSpacing has no effect unless there is more than one Implant layer, and there is a spacing rule between different Implant layers, and your cell data has the corresponding Implant layer shapes in them.

Placer does not look at same-layer spacing rules for implant layers. It only enforces rules for spacing between different implant layers.

-honorImplantSpacing will be ignored until spacing rules between different implant layers are added to your technology rules.

For LEF, look for SPACING rules on the TYPE IMPLANT layers; and ensure that a spacing rule to a different layer exists as per syntax and example below: .in +8

SPACING minSpacing [LAYER layerName2]; SPACING 0.28 LAYER HVT; .in

For OpenAccess rules, look for the oacMinClearanceRule on the implant layers.

# IMPSP-305

### **NAME**

IMPSP-305

### **SUMMARY**

Cell:%s, Pin:%s geometry (<%d,%d> <%d,%d>) is sticking out of cell's " "boundary (<%d,%d> <%d,%d>). " "Placement will not be able to catch DRVs on the portion of pin " "outside the cell boundary. To avoid this, pin geom of the library cell " "model needs to be fixed.

### DESCRIPTION

When doing Cell-to-Preroute design rule checks, the cell PR boundary is used as the search area, and as bounding box for insertion into search trees. Thus, spacing checks from a special wire geometry may see the PR boundary to be ok as a pre-check, and may not do detailed checking on each pin in this situation.

Thus, in this corner case, the pin outside the PR boundary may be causing a spacing violation, but will not be detected.

This is library cell modeling issue, and can not be fixed at design stage.

# **IMPSP-307**

### **NAME**

IMPSP-307

## **SUMMARY**

\*\*Info: (IMPSP-307): Design contains fractional %d cell%s.

### **DESCRIPTION**

Fractional cells are cells where the width is not an integer multiple of the site and/or the height is not an integer multiple of the row height.

You can use command "check\_design -physicalLibrary" to get a list of cells considered fractional.

# IMPSP-308

### NAME

IMPSP-308

#### SUMMARY

\*\*Info: (IMPSP-308): Cell %s is fractional: %d:%d

### **DESCRIPTION**

Given cell's width is not an integer multiple of its techSite width.

The values given are <cell-width % techSite-width> : <techSite-width>

# **IMPSP-309**

### NAME

IMPSP-309

Error and Warning Messages

### **SUMMARY**

Pin %s in cell %s will cause issue in router access. Most probably the " "enclosure of via is larger than pin %s. Input the correct library cell %s " "and re-run placement.

### **DESCRIPTION**

Example:

-----

The via enclosure is larger than pin %s. Please correct the library cell %s and re-run placement.

# IMPSP-315

### NAME

IMPSP-315

### **SUMMARY**

Found %d instances insts with no PG Term connections.

### **DESCRIPTION**

Instances without PG connections, will fail legality check, as unconnected supply pins will short with followpins, if present. If followpin routing has not been done yet, although legality checks will not fail, design is still not in realizable state till these connections have been made.

One way to remedy the situation is to create global-net-connect rules, or if the rules exist, use command applyGlobalNet to make the connections.

### NAME

IMPSP-357

### **SUMMARY**

Could not initialize placement legalization data for power domain %s.

### **DESCRIPTION**

The possible reasons for not initializing the placement legalization data for a power domain are:

- 1. The power domain has no tech site information.
- 2. The constraint box of the power domain is invalid.
- 3. The row information for the power domain is missed.

# IMPSP-362

### NAME

IMPSP-362

### **SUMMARY**

Site '%s' has %s std.Cell height, so ignoring its X-symmetry.

### **DESCRIPTION**

In a floorplan with flipped rows, with supply followpins being shared between rows, the cells of a single (or odd multiple) row height cannot be flipped

in Y-direction, as that would cause power to short with ground. As a result, the techSite needs to be

Error and Warning Messages

defined with only symmetry Y, and must not have

symmetry X - allowing cells to be flipped around Y axis (R0->MY), but not X axis (R0->MX).

This message is reported when a core site definition includes the symmetry X which is typically not intended. SYMMETRY X means the site is symmetric about

the x axis. This means that N and FS sites are equivalent, and FN and S site are equivalent. A macro with an orientation of N matches N or FS rows.

Typically, this is not intended because it would allow the power rails to not align (i.e. the cell would be allowed to flip so a VDD rail aligns with a VSS

rail). Typically, only time X symmetry might be used for a site is with double height cells.

This message simply is indicating that Innovus does not believe the X symmetry was intended and therefore ignoring it. To avoid this message remove

the X symmetry from the site.

For more information on defining symmetry, please refer to the "LEF language reference" manual.

| Example:                                         |
|--------------------------------------------------|
|                                                  |
| Example site definition that causes this warning |
|                                                  |
| SITE core                                        |
| .in +4                                           |
| SYMMETRY x y ;                                   |
| CLASS core;                                      |
| SIZE 0.660 BY 5.040 ;                            |
| .in                                              |
| END core                                         |

# IMPSP-365

#### NAME

IMPSP-365

### **SUMMARY**

Design has inst(s) with SITE '%s', but the floorplan has no rows defined for this site. Any locations found for such insts will be illegal; create rows for this site to avoid this.

### DESCRIPTION

This warning will be reported by commands such as check\_floorplan and place\_design when the floorplan does not contain any rows for the specified site. Each standard cell in the LEF should have a SITE defined for it. Instances of this cell can only be placed in rows defined for this site.

Example:

-----

Run the following command(replace RAM\_site with your specific site name) to report the instances which use this site:

.in +2

dbGet [dbGet -p3 top.insts.cell.site.name RAM\_site].name

.in

When you create the initial floorplan, it should automatically create rows for the standard cells defined in the netlist. You can add additional rows using Floorplan - Row - Create Core Row or using the create\_row text command. If this warning is occurring on standard cells you must define rows for them or else they will not be placed.

If this problem occurs for hard macros such as memories you can ignore it.

Rows are not required by the hard macros. Remove the SITE definition in the LEF for the hard macros to avoid this message for them.

If this occurs for IO pads you can also ignore it. Rows for IO pads are optional. You can create IO rows using Floorplan - Row - Create I/O Row or using the create\_io\_row text command.

### NAME

IMPSP-372

### **SUMMARY**

Found mismatched FollowPin in rows. Switching off DRC check from preroutes for this run. This may cause illegal placement.

### **DESCRIPTION**

Example:

There are missing tech SITE warnings when the design is being loaded. These messages are related to the IMPSP-372 warnings that are issued later.

\*\*WARN: (IMPFP-3961): techSite 'foo\_SITE\_IO\_250000' has no related Cells, So Cannnot calculated VDDonbotom attributes. Need correct LEF filea?|a?|

\*\*WARN: (IMPFP-3961): techSite 'foo\_core2' has no related Cells, So Cannnot calculated VDDonbotom attributes. Need correct LEF filea?|a?|

\*\*WARN: (IMPFP-3961): techSite 'foo\_CORE3' has no related Cells, So Cannnot calculated VDDonbotom attributes. Need correct LEF filea?|a?|

\*\*WARN: (EMS-63): Message has exceeded the default message display limit of 20. To avoid this warning, increase the display limit per unique message.

If the site is not used in any standard cell macro, it can be ignored. The site should be removed from the LEF.

In Innovus it is assumed that all CLASS CORE site have standard cells associated with them, and we analyze the standard cells to identify power/ground followpins for consistency checks.

This results in the following message:

Error and Warning Messages

\*\*WARN: (IMPSP-372): Found mismatched FollowPin in rows. Switch off DRC check from preroute. This may cause illegal placement.

# IMPSP-373

### NAME

IMPSP-373

### **SUMMARY**

FollowPins in %d rows did not match the supply layout of the cells " "for that row orientation. This will result in power shorting to ground " "for all insts placed in these rows.

### **DESCRIPTION**

Followpin pre-routes for some std-rows do not match the supply layout of the cells for that row's orientation. That is, power pin of instances on that row is shorted to ground followpin stripe, and vice versa.

In check\_place results, this will show up as multiple 'Pre-route DRC' Violations.

Result of place\_design/refinePlace may be "placement" legal, but will not be DRC clean.

Delete and redo followpin routing, and rerun refinePlace to clean up any remaining DRCs.

# IMPSP-374

#### NAME

IMPSP-374

### SUMMARY

Expected %s to have rows of basic site %s, but found %d rows only of other " "site(s). Check if the %s's row creation is correct before proceeding.

#### **DESCRIPTION**

A floorplan object's basic site is usually the smallest site of all instances to be placed within that object.

Here, a floorplan object can be a power-domain, a partition, or the entire core of a top-level or block design.

There should be at least one row of the basic site in a given floorplan object; while other rows can be of sites whose dimensions are integer multiples of those of its basic site.

In this case, the floorplan object has no rows of its basic site. Thus, instances of the cells using the basic site will find no legal location within the confines of this floorplan object.

# IMPSP-452

#### NAME

IMPSP-452

### **SUMMARY**

Density for module '%s' (%s = {%.3f %.3f %.3f %.3f}) is greater than 100% (%.3f) since the available site area for this module is smaller than sum of module instance area and blockage area. Most probably this is caused due to overlapping floorplan constraints such as guides, regions or fences. Correct the floorplanning constraints for this module and re-run placement again.

### DESCRIPTION

This message is to check density of module. If the density of the module is greater than 100%, it will issue this message.

Error and Warning Messages

place\_design handles differently based on whether the region is a fence or power domain. In both cases the user should increase the size of the fence or power domain (PD) to accommodate the cells. If a PD is not large enough to accommodate the standard cell logic then place\_design will reports this message.

Example:
----
(1) Seed file

VERSION 1.0

BEGIN SEED

name=U\_IOP/U\_IOP\_MPI createfence=true util=1.1

END SEED

(2)

<CMD> plan design -constraints file tn seed.11

\*\*WARN: (IMPSP-452): Density for module 'U\_IOP/U\_IOP\_MPI' is greater than 100% (1.001) since the available site area for this module is smaller than sum of module instance area and blockage area. Most probably this is caused due to overlapping floorplan constraints such as guides, regions or fences. Correct the floorplanning constraints for this module and re-run placement again.

# IMPSP-508

#### NAME

IMPSP-508

### **SUMMARY**

Option -checkPinLayerForAccess takes a list of layer number, not layer name or boolean value. The default value 1 has been used for option -checkPinLayerForAccess.

## **DESCRIPTION**

The recommended setting is to specify the layer number list like "set\_db

Error and Warning Messages

place\_detail\_check\_pin\_layer\_for\_access {1 2 3}". Default value 1 would be used for checking when boolean value is asserted; it's unpredictable when layer name is specified - "set\_db place\_detail\_check\_pin\_layer\_for\_access M1 M2 MET3}" would be presented as "set\_db place\_detail\_check\_pin\_layer\_for\_access {1 2 3}" even MET3 doesn't be defined in LEF; "set\_db place\_detail\_check\_pin\_layer\_for\_access {V12}" would be presented as "set\_db place\_detail\_check\_pin\_layer\_for\_access {2}".

Example:

-----

<CMD> set\_db place\_detail\_check\_pin\_layer\_for\_access true

\*\*WARN: (IMPSP-508): Attribute place\_detail\_check\_pin\_layer\_for\_access takes a list of layer number, not layer name or boolean value.

The default value 1 has been used for attribute place\_detail\_check\_pin\_layer\_for\_access.

# IMPSP-514

#### NAME

IMPSP-514

### **SUMMARY**

Turning OFF selective property of soft-blockages, as design restored had been saved by Encounter %s, and that version did not have this property turned on.

### DESCRIPTION

The selective property of soft-blockages is now default true. If the design was saved by any version earlier then EDI14.1, then Innovus's behavior regards to soft blockage was different at the time design was saved. To not change the behavior, this selective property of soft-blockage is switched off when earlier DB version is detected.

To switch to the new default behavior, you can set place-mode as:

set db place detail selective blockage true

This will override the backward compatibility mode for this option, and soft blockages will only allow 1,2-pin cell instances.

### NAME

IMPSP-1760

### SUMMARY

Buffer footprint does not have non-inverting buffers. Using inverter footprint for Virtual IPO. Verify you have buffers defined in the libraries you have read in and confirm they are usable by running report\_dont\_use\_cells. Run 'set\_opt\_dont\_use bufferName false' to enable buffers which are currently unusable.

### DESCRIPTION

This message is issued when place\_design cannot find any usable buffers during timing driven placement.

Timing driven placement runs a virtual In-Place Optimization (VIPO) to predict how buffering will be done in order to achieve a better placement. If it cannot find any usable buffers it will use inverters instead.

Verify that you have:

- 1. Buffers defined in your library,
- 2. The timing libraries for the buffers have been read in,
- 3. The buffers are usable.

Run

.in +8

report dont use cells

.in

or

.in +8

report footprints -dontTouchNUse -outfile footprint.rpt

.in

Error and Warning Messages

to report don't use cells.

Use the set\_opt\_dont\_use command to control usability of cells. To enable a buffer which is currently unusable, run

.in +8

set opt dont use bufferName false

# **IMPSP-2002**

### NAME

IMPSP-2002

### SUMMARY

Density too high (%.1f%%), stopping detail placement.

### **DESCRIPTION**

The most likely reasons for excessive density are:

- 1. The presence of unfixed hard macros in the design.
- 2. Too many instances being inserted without legal locations.
- 3. The design being filled with filler cells.

# **IMPSP-2020**

### **NAME**

IMPSP-2020

#### SUMMARY

Cannot find a legal location for instance '%s' (Cell %s).

Error and Warning Messages

### DESCRIPTION

Possible reasons for no legal location found, are:

- 1. Width of instance's cell is too large for the dense power stripes'
- pitch. Make sure that stripe's layer is not being treated as obstruction. Place-mode's setPrerouteAsObs setting may need a change.
- 2. Floorplan rows are created incorrectly, making rows for this instance's cell not be placeable. Check correct basic site is set in floorplan creation.
- 3. Power/Ground followpin pre-routes do not match rows' orientations. Either re-create the rows, or re-route followpin wires.

This will cause run-time issues during detail placement step called by place design or refinePlace.

### Example:

-----

This issue can be seen when there is a problem with globalNetConnects. If the power/ground pins are not properly connected to the rail, then the rail appears as obstruction and the cells cannot be legalized. The issue can be fixed by having proper orientation of rows in the floor-plan and by [having] or re-routing follow pin wires matching row orientation.

For example, M2 followpin width is too large which causes spacing violations with M2 pins/obs of certain cells no matter where these cells are placed. This causes long runtimes during legalization and the resulting placement will not be illegal.

In order to debug this turn off DRC checking during place\_design or detail\_place using

.in +5

setPlaceMode -checkCellDRCFromPreRoute false.

.in

Once design is placed, turn DRC checking back-on and run check\_place. Look for DRC violations on these cells between M2 pins/obs and follow pin. Correct the follow pin routing to make sure the DRC violations are gone between cells and follow pin. Rerun place\_design/refinePlace again for legalized placement.

Check for verifyGeometry for Std. cell check and make sure your Std. cell is in Sync. with Tech file, to avoid legalization issues.

### NAME

IMPSP-2021

#### **SUMMARY**

Could not legalize <%d> instances in the design. Check warning message IMPSP-270, IMPSP-452, IMPSP-2024, IMPSP-2039, IMPSP-2040, IMPSP-2042 or IMPSP-2020 in log file for more details.

### **DESCRIPTION**

If there are instances in design that could not be legalized,

refinePlace would give a warning for each of those instances (IMPSP-2020), or master-cell (IMPSP-270). There can be a number of reason why refinePlace could not find a legal location, such as:

- \* Cell may not have its site rows defined correctly in floorplan, or
- \* There may be a conflict between cell-library and power-planning structure such that some cells always have a spacing violation between thier pin or obs geometry and power net wires/vias/cuts.
- \* Some Region/Fence constraint may be over subscribed (IMPSP-452)
- \* Track offset and definition used may not allow for on-grid pin-access (for som advanced node libraries)

**SEE ALSO** 

.in +5

Man-page for IMPSP-2020

.in

### NAME

**IMPSP-2022** 

#### **SUMMARY**

No instances to legalize %s

### **DESCRIPTION**

This message is issued by detail\_place if it does not find any instances to place. If command was invoked using '-inst' option, then some insts in the given list of instances should be valid for legalization.

detail\_place command will only legalize instances that are already in PLACED status. Thus, instances that are either in FIXED status, or UNPLACED status, are not counted.

# **IMPSP-2041**

### NAME

IMPSP-2041

### SUMMARY

Found %d fixed insts that could not be colored.

## **DESCRIPTION**

Design has instances fixed in locations where they are not considered legal. Due to same-mask spacing rules and adjacent colored geometries (such as PG nets wires and vias), the attempt to color them may result in incorrect color. Hence, these instances will not be colored till they are legalized.

Error and Warning Messages

You can run

.in 8

check\_place

.in

to find the reason why the instance is not considered legal.

# **IMPSP-2044**

### NAME

**IMPSP-2044** 

#### SUMMARY

The 'get\_db -add\_fillers\_cell\_name\_style' value is " "'flat' (not 'hier'). As such, physical insts added to the design will " "not be hierarchical, and will not have membership in fence/regions. " "If the design has fences, place\_detail will move placed physical " "insts out of the fences.

## **DESCRIPTION**

Flat physical instances means that in the design hierarchy, they will all be based on the top-level, and not inside the module hierarchy. As fences/power-domains/partitions all are set on a module at a lower-level then the top-of-the-design, the fillers will physically be placed inside the bounding-box, but in DB, they will not belong to the module associated with that placement-constraint. While legalizing these physical instances, detail\_place will see these instances as not having the fence membership, and will throw them out to the top-level.

Just changing this mode setting is not enough, as any fillers already added in the flow till this point (since the mode was set)

Error and Warning Messages

would already be inserted at the top-level. Hence those fillers will need to also be deleted, and re-inserted after the mode has been reset to 'hier'.

# **IMPSP-2702**

### NAME

IMPSP-2702

### **SUMMARY**

There is no techSite '%s' in the library.

## **DESCRIPTION**

The message is reported when a stand cell library does not have core site definition. To fix the warning check std cell lef and correct the core site.

Example:

-----

# **IMPSP-2704**

### **NAME**

IMPSP-2704

### **SUMMARY**

No GA fillers have been detected in the design for replacement. Any new GA cells will remain unplaced.

Error and Warning Messages

## **DESCRIPTION**

This error message is issued when no physical-only instances of the specified GA filler cell type(s) are present in the design. For ecoPlace to make use gate array fillers they must be physical-only.

Example:

-----

# **IMPSP-2707**

### **NAME**

IMPSP-2707

### **SUMMARY**

TechSite '%s' used by the GAFiller list does not have rows in the design.

## **DESCRIPTION**

The message is reported when the corresponding core site rows are not created,

Check and create the corresponding rows to over come this warning. Use create\_row -site <Site name>.

Example:

-----

# **IMPSP-2717**

#### NAME

IMPSP-2717

Error and Warning Messages

## **SUMMARY**

There are %.2f\%(unplaced instance ratio) unplaced instances in the design, please run place\_design instead of ecoPlace to avoid potential bad DRC and timing result.

### **DESCRIPTION**

For timing-driven ecoPlace, the threshold of unplaced instance ratio is 15%.

For non timing-driven ecoPlace, the threshold of unplaced instance ratio is 5%.

# **IMPSP-2901**

### NAME

IMPSP-2901

### **SUMMARY**

%i %s height segment%s too small to resolve.

### **DESCRIPTION**

Segments that are too small to resolve are likely caused by fixed cells that are too close together. These cells must be manually adjusted, or unfixed so they may be moved by add\_filler\_gaps.

# **IMPSP-2902**

#### NAME

IMPSP-2902

Error and Warning Messages

### SUMMARY

%i %s height segment%s impossible to resolve.

### **DESCRIPTION**

Segments that are impossible to resolve have an amount of free space that is nonzero and less than the provided minGap value. These segments may be resolved by enabling the 'medium' effort mode of add\_filler\_gaps. These segments may still be impossible to resolve under 'medium' effort if no nearby segments can be found for cell movement or swapping.

# **IMPSP-2903**

### **NAME**

IMPSP-2903

### **SUMMARY**

%i %s height segment%s too difficult to resolve.

### **DESCRIPTION**

Segments that are too difficult to resolve are probably caused by pin access constraints that interfered with the cell sliding mechanism.

The cells in these segments will probably have to be manually adjusted.

### NAME

IMPSP-5101

#### **SUMMARY**

The design must be completely placed before adding filler cell(s).

### **DESCRIPTION**

When running add\_fillers the warnings or error above are issued.

When add\_fillers runs it checks whether the entire design is placed or not. If it is not, you will see this messages. When user would like to work on floorplan and want to run DRC checks on it in PVS or other tool, you may like to fill all the entire row area with fillers instead of running an entire placement. If user receive the IMPSP-5101 warning it will still fill the rows with filler cells. It is simply warning you that the design is not entirely placed with below warnings.

\*\*WARN: (IMPSP-5102): There 'are' 10 unplaced instances in the design...
OR

\*\*ERROR: (IMPSP-503): Design must be placed before running "add\_fillers". If you receive the IMPSP-503 error you can still place fillers by specifying the core area.

Example:
----.in +2
add fillers -area [dbGet top.fplan.coreBox]

Error and Warning Messages

add\_fillers -area [dbGet top.fplan.coreBox] .in

# **IMPSP-5106**

### NAME

**IMPSP-5106** 

### **SUMMARY**

AddEndCap cannot place end cap cells at the ends of the site rows. Most probably there are preplaced std-cell inst%c at '%s' of '%s' row%c. Remove pre-placed instances and re-run add\_endcaps again.

### **DESCRIPTION**

The add\_endcaps command won't add end caps if there are existing cells at the end of rows, but if there are placement blockages and no existing cells it will add end caps next to the placement blockage.

Example:

-----

# **IMPSP-5113**

## **NAME**

IMPSP-5113

## **SUMMARY**

Maximum of only two tie-cells can only be provided.

### DESCRIPTION

When user provides more than two cells for -cell < > option, Innovus will error out with message IMPSP-5113.

User has to provide only two cells as in the example given below, Where one cell must be a tie-high driver, and the other is a tie-low driver.

Example:

-----

Right Approach:

addTieHiLo -cell "tieoff\_hi tieoff\_lo"
set db add tieoffs cells "tieoff hi tieoff lo"

Wrong Approach:

addTieHiLo -cell "tieoff\_hi tieoff\_lo tieoff\_hi\_pm tieoff\_lo\_pm"
set\_db add\_tieoffs\_cells "tieoff\_hi tieoff\_lo tieoff\_hi\_pm tieoff\_lo\_pm

# **IMPSP-5119**

### **NAME**

IMPSP-5119

### SUMMARY

AddEndCap is unable to add %s-cap cell (%s) at (%0.3f, %0.3f).

## **DESCRIPTION**

Most likely reason is:

Error and Warning Messages

The end location is already occupied by a fixed

instance or placement blockage.

It is illegal to add cap cell at this

location.

Fix these issues and re-run add\_endcaps command again.

Example:

-----

# **IMPSP-5123**

### **NAME**

IMPSP-5123

## **SUMMARY**

Cell %s is not found.

## **DESCRIPTION**

The message occurs when the filler cell(s) your specified for setFillerMode or add\_fillers can not be found. Please make sure the cell(s) exist in the design.

Example:

-----

.in +4

innovus 20> get\_lib\_cells FILL\*

lib1/FILL1 lib1/FILL2 lib1/FILL4

.in

<sup>\*</sup> The following example checks the existence of cells with prefix 'FILL':

### NAME

IMPSP-5125

### SUMMARY

No filler cell provided.

### DESCRIPTION

Previously in the ECO flows, the filler cells used to be deleted before ecoPlace and then they would be added back.

With the supercommand "eco\_design", the filler cells have to be identified by the user so that internally the commands for addition and deletion of FILL cells can be called.

```
Example:
```

```
-----
```

CMD> eco\_design -no\_eco\_route

FOO RUNDIR/FOO top.dat

FOO top ../../eco v/FOO top.v

Statistics of distance of Instance movement in

detailed placement:

.in +2

maximum (X+Y) = 0.00 um

mean (X+Y) = 0.00 um

.in

Total instances moved: 0

\*\*\* cpu=0:00:14.0 mem=2240.1M mem(used)=4.9M\*\*\*

ERROR (SOCSP-5125): No filler cell provided.

To resolve use below approch:

```
The FILL cells are identified by setting this:
setFillerMode -core {corefill_3 corefill_2 corefill_1} -corePrefix xofiller_

If the design is being restored from a previously saved session, the .mode file in the .dat dir will need to edited to add this command to it.
```

# **IMPSP-5131**

### **NAME**

IMPSP-5131

#### SUMMARY

%s '%s' has been marked dont\_touch. %s %s will not be considered for tie-cell %s

# **DESCRIPTION**

analog\_block a\_inst(.A(AVDD), .B(AVSS), ...);

```
addTieHiLo is able to honor the don't touch property, this is controlled by

"set_db add_tieoffs_honor_dont_touch {true|false}"

Example:
-----

In the design, there are four power nets: VDD, VSS, AVDD and AVSS. In the netlist, following connections are defined:
.in +4

module top ( ... );
...
.in
.in +8
```

```
digital block d inst(.A(1'b1), .B(1'b0), ...);
.in
.in +4
endmodule
.in
If user have manually connected the analog tie high/low pins to AVDD and AVSS, use following
flow to insert tie high/low cells for VDD and VSS without addTieHiLo inserting them for AVDD and
AVSS:
set dont touch [get lib cells TIEHI] false
set_dont_touch [get_lib_cells TIELO] false
set dont touch AVDD true
set dont touch AVSS true
setTieHiLoMode -cell {TIEHI TIELO} -honorDontTouch true
addTieHiLo
This will mark AVDD/AVSS as dont touch and tell addTieHiLo to honor the dont touch property.
The correct connections are shown in the resulting netlist:
.in +4
module top ( ... );
...
.in
.in +8
.TIELO LTIELO (.Y(LTIELO NET));
.TIEHI LTIEHI (.Y(LTIEHI NET));
analog_block a_inst (.B(AVSS), .A(AVDD), ...);
digital_block d_inst (.B(LTIELO_NET), .A(LTIEHI_NET), ...);
.in
.in +4
endmodule
```

.in

### NAME

**IMPSP-5134** 

### **SUMMARY**

Setting %s to %0.3f (microns) as a multiple of cell %s's techSite '%s' width of %0.3f microns

## **DESCRIPTION**

Placement grid is based on the size of unit tech site. When the specified value is not multiple times of tech site size, it must be automatically adjusted to make sure all instances are placed on placement grid.

Example:

-----

<CMD> add well taps -cell WELLTAP -cellInterval 33

\*\*WARN: (IMPSP-5134): Setting cellInterval to 32.900 microns as a multiple of cell WELLTAP's techSite 'core' width of 0.140 microns.

# **IMPSP-5140**

### **NAME**

IMPSP-5140

### SUMMARY

Global net connect rules have not been created. Added %sinsts would have no supply connectivity, and would fail DRC.

Error and Warning Messages

### DESCRIPTION

New instances created rely on Global-Net-Connect rules to determine which supply net to connect the power and ground pins. With missing GNC rules, the supply pins are left unconnected. When there are followpin stripes in design, the followpin wires will be shorting to unconnected supply pins on the instances. These instances will fail legality checking.

One way to add GNC rules is by using command connect\_global\_net.

For example,

.in +8

connect\_global\_net VDD -type pgpin -pin VDD connect\_global\_net VSS -type pgpin -pin VSS .in

# **IMPSP-5144**

#### NAME

**IMPSP-5144** 

#### SUMMARY

The specified value of -reportGap is less than the basic tech site width. You should use" "a value equal to or greater than the basic tech site width to avoid this message.

### **DESCRIPTION**

The command "check\_filler -reportGap" is used to check gaps with the specified gap size, especially for 1 site gaps.

As the placement grid is based on the tech site, the minimum -reportGap can be set to is the tech spec site width.

If the value of -reportGap is less than the basic tech site width, then the tool will continue but will

Error and Warning Messages

use the

basic tech site width to check the gaps instead, reporting this warning message.

Example:

-----

When running 'check\_filler -reportGap 0.10' for a design whose basic tech site is 0.14 micron, check\_filler will report this warning message and continue to check gaps using the value 0.14 instead.

# **IMPSP-5157**

### NAME

IMPSP-5157

### **SUMMARY**

Design has cells with user specified padding. This could result in gaps next to the instances of these cells.

### **DESCRIPTION**

This warning message is issued while running add\_fillers command in a design that has cells with user specified cell padding. Since the cell padding is going to remain in the flow after placement also in order to avoid this message and to fill the gaps the user can delete cell padding using delete\_cell\_padding command and rerun add\_fillers command.

Example:

-----

# **IMPSP-5164**

### NAME

**IMPSP-5164** 

#### **SUMMARY**

AON Tie cells insertion is not supported when createHierPort option is enabled.

## **DESCRIPTION**

when set\_db add\_tieoffs\_create\_hports true, addTiHiLo can connect the tie pin across hierarchical instance. In LP design, that means the tie cell can cross the domain boundary to drive the tie pin whose location is in other domain.

Current addTiHiLo can only insert tie cell to drive the pins in the same location domain.

Example:

-----

Add TiHiLo cells individually for each domain addTieHiLo -powerDomain PD1 addTieHiLo -powerDomain PD2 addTieHiLo -powerDomain PD3

# **IMPSP-5169**

## **NAME**

IMPSP-5169

## **SUMMARY**

No AON Tie-%s cell found for power domain %s.

## **DESCRIPTION**

Design does not have AON Tie cells for the specified power domain. Check if the libary has AON Tie cells and

if the AON Tie Cells are specified in the CPF for the power domain.

## **IMPSP-5170**

## **NAME**

IMPSP-5170

## **SUMMARY**

PowerDomain %s has no any module defined, stop %s in this powerdomain.

## **DESCRIPTION**

Tool uses the module belong to specific power domain as the hierarchy when inserting physical cells, such as add\_endcaps, add\_well\_taps, add\_fillers and add\_decaps. These physical cell insertion commands error out if there is no any module defined under the target power domain, users need to modify the power domain definition with module to avoid this issue.



-----

Incorrect CPF definition - leaf instances are specified to power domain PD\_A: create\_power\_domain -name PD\_A -instances {mod1/inst1 mod1/inst2 mod1/inst3 mod2/inst1 mod2/inst2 mod2/inst3}

Correcting CPF to avoid IMPSP-5170:

create\_power\_domain -name PD\_A -instances {mod1 mod2}

# **IMPSP-5178**

## NAME

**IMPSP-5178** 

#### **SUMMARY**

Endcap cells for %s don't have same site.

## **DESCRIPTION**

Endcap cells of the given type need to have the same techSite, as they share the row they will be placed in. As such, if site type is different than rows cannot be succesfully cap-ed on all required locations.

# **IMPSP-5216**

#### NAME

IMPSP-5216

### **SUMMARY**

A redundant edge type is found and will not be added.

## **DESCRIPTION**

The warning is given when there are duplicated edge types assigned to the same cell. For example, the same edge type are added twice to the same cell "SDFFQ", you will get this message.

# **IMPSP-5217**

### NAME

IMPSP-5217

#### **SUMMARY**

add\_fillers command is running on a postRoute database. It is recommended to be followed by eco\_route -target command to make the DRC clean.

## **DESCRIPTION**

When -enableLeglizer is set to true, there might be DRC left if running add\_fillers command on a postRoute DB.

You can call eco\_route command after add\_fillers to clean up the DRC,

or set setFillerMode -enableLeglizer to false to avoid this warning message.

## **IMPSP-5259**

## **NAME**

IMPSP-5259

## **SUMMARY**

Options '-virtual\_color\_cell' and '-virtual\_color\_map' are obsolete, and have been replaced by command 'specify\_cell\_virtual\_align'. These 'Mode' options still work in this release, but to ensure compatibility with future releases, updating your script is recommended.

## **DESCRIPTION**

Filler mode options for virtual\_color get applied during filler insertion. But to ensure that this virtual\_color is seen by all

Error and Warning Messages

placement commands (and API), use specify\_cell\_virtual\_align.

The replacement command specify\_cell\_virtual\_align, will ensure that other placement command, such as check\_place, detail\_place, place\_eco will also honor the virtual\_color.

See Also:
.in +4
report\_cell\_virtual\_align, delete\_cell\_virtual\_align.
.in

## **IMPSP-6014**

#### NAME

IMPSP-6014

## **SUMMARY**

I/O pin '%s' does not connect to placed Area I/O instance or hard macro and will be ignored for bump assignment. Most likely reason is: 1. The Area I/O instance or hard macro is not placed. 2. I/O pin does not connect to I/O instance or hard macro in Verilog netlist. Fix these issues and re-run assign bumps command again.

## **DESCRIPTION**

assign\_bumps command assigns the bumps closest to the I/O cells. For assigning I/O cells to bump, IO pads need to be with the Class type definition "PAD AREAIO"

| Example:             |
|----------------------|
|                      |
| MACRO iopad          |
| CLASS PAD AREAIO ;   |
| ORIGIN 0.000 0.000 ; |

Error and Warning Messages

SIZE 35.000 BY 246.000;

SYMMETRY x y r90;

SITE pad;

**PIN PAD** 

**PORT** 

**CLASS BUMP** 

a?|a?|a?|a?|a?|

If the CLASS is not defined as "AREAIO" then tool will give WARN: (IMPSP-6014) warning message.

Users need to check the LEF file to make sure that CLASS type for that cell is specified as CLASS PAD AREAIO.

## **IMPSP-7207**

## **NAME**

IMPSP-7207

### **SUMMARY**

Shifter '%s' has no connections outside its power domain.

## **DESCRIPTION**

This message represents the detection of a level shifter or isolation cell which is connected only to instances in the same power domain (disregarding any enable nets).

The cell in question may have been improperly inserted into the netlist, or may be a spare.

Use of the 'report\_power\_domains' command may be helpful in analyzing the connectivity of this cell.

Error and Warning Messages

The level shifter placement algorithm will skip this cell (i.e. not move it to the power domain boundary), and let it be handled through normal processes.

# **IMPSP-7208**

#### NAME

IMPSP-7208

### SUMMARY

Term '%s' of %s '%s' is outside its power domain.

## DESCRIPTION

This message represents the detection of a term that is connected by a net to a level shifter or isolation cell, but is physically outside the constraints of its expected power domain.

This may be caused by a failure in floorplanning or an earlier placement step, and analysis of the location of the reported instance or block is recommended.

# **IMPSP-9025**

### NAME

IMPSP-9025

## **SUMMARY**

No scan chain specified/traced.

#### DESCRIPTION

By default, scan chains are traced and reordered during place\_opt\_design and ccopt\_design if it is specified by scan DEF or create\_scan\_chain command. If there is no scan chain specification, placer will skip this step and report the warning message.

## **IMPSP-9042**

## **NAME**

IMPSP-9042

## **SUMMARY**

Scan chains were not defined, -place\_global\_ignore\_scan option will be ignored. Define the scan chains before using this option.

## **DESCRIPTION**

This warning occurs when setPlaceMode -place\_global\_ignore\_scan true is set (default is true) but no scan chains are defined. Run getPlaceMode -place\_global\_ignore\_scan to report its current setting. This option instructs place\_design to disregard scan connections while running placement but it requires you to define scan chains first. Otherwise, the option is ignored. You can define scan chains by importing a scan DEF file using read\_def or using the command create\_scan\_chain.



-----

The following command load scan specification from a DEF file:

read\_def mySCAN.def

The following command sets scan chain test\_si with a starting I/O pin name and a stopping pin name:

create\_scan\_chain test\_si -start test23 -stop test\_so

## **IMPSP-9053**

## NAME

**IMPSP-9053** 

### **SUMMARY**

Option -startRowNum assumes the frist row in design is '1', ignoring '%d'.

## **DESCRIPTION**

Option -startRowNum of command add\_well\_taps is used to specify the row number starting from the bottom or left side of the design on which the well-tap cells must be placed, which assumes the first row from the bottom as '1'. To avoid this message, the specified start row number must be equal or larger than '1'.

Example:

-----

<CMD> add\_well\_taps -cell FIIL1 -cellInterval 33 -startRowNum -1

\*\*WARN: (IMPSP-9053): Option -startRowNum assumes frist row in design is '1', ignoring '-1'.

## **IMPSP-9514**

## **NAME**

IMPSP-9514

### **SUMMARY**

Non-TimingDriven placement will be performed.

Error and Warning Messages

### DESCRIPTION

Placement is being run without taking timing into account. Placement of instances on timing critical paths may not be effective.

Example:

-----

To consider timing driven placmenet make sure constraints are loaded along with the following command:

.in +4

setPlaceMode -timingDriven true

.in

# **IMPSP-9516**

## NAME

IMPSP-9516

## **SUMMARY**

-prePlaceOpt is disabled when -incremental option is on.

## **DESCRIPTION**

place\_design -incremental works on an already placed design and hence prePlaceOpt (buffer tree deleteion) is disabled.

Example:

-----

To run Incremental place design on an already placed data:

place\_design -incremental

# **IMPSP-9528**

### NAME

**IMPSP-9528** 

#### **SUMMARY**

Command '%s' is obsolete and will be removed in future release, use '%s' to replace it.

## **DESCRIPTION**

The obsolete command still works in this release, but to avoid this warning and to ensure compatibility with future releases, please remove it from your script and use the recommended command to replace it.

Example:

-----

<CMD> %s

\*\*WARN: (IMPSYT-9528): Command '%s' is obsolete and will be removed in future release. The obsolete command still works in this release, but to avoid this warning and to ensure compatibility with future releases,

please remove the obsolete command from your script and use '%s' to replace it.

## **IMPSP-9542**

## **NAME**

**IMPSP-9542** 

## **SUMMARY**

check\_design found some critical issues with the design. Please fix error(s) identified before rerunning place opt design.

### DESCRIPTION

Review report generated by check\_design and fix the different errors before restarting place opt design.

## **IMPSP-15450**

### NAME

IMPSP-15450

## **SUMMARY**

Cannot recognize this line correctly: %s

## **DESCRIPTION**

Input row num should be greater than 0, and less than the row height of the cell.

The summation of left and right cpp should be less than or equal to the width of the cell.

# IMPSR-211

## **NAME**

IMPSR-211

### SUMMARY

Cannot find a bump named '%s' in Innovus DB.

## **DESCRIPTION**

The macro of bump instance is 'CLASS COVER BUMP', but the 'Object Type' of bump instance is not 'Bump Cell'. Or attempting to optimize non-bump's assignment by "place peripheral ios -

assign\_bumps", such as TSV, pad, ...

## **IMPSR-212**

#### NAME

IMPSR-212

#### SUMMARY

The bump shape is irregular, and not supported by global route. The bounding box of the bump is used in global route.

### DESCRIPTION

Global route only supports rectangle or octangle bumps without merging. And for octangle bumps, the internal angles must be 135 degree and the edges must be vertical, horizontal or diagonal. Otherwise, bounding boxes are used in global route to represent the bumps.

# IMPSR-215

## **NAME**

IMPSR-215

#### SUMMARY

The value of maximum resistance for diff pair nets %s and %s is not proper. The two nets is routed with fixed routing width.

## **DESCRIPTION**

route\_flip\_chip supports resistance driven diff pair routing in PIO mode. The value of maximum resistance for either net in one diff pair should be the same. Check the setting MAXRES for the diff pair nets in constraint file.

## NAME

IMPSR-216

### **SUMMARY**

The width range for diff pair nets %s and %s is not proper. The two nets is routed with fixed routing width.

#### **DESCRIPTION**

route\_flip\_chip supports resistance driven diff pair routing in PIO mode. The width range for either net in one diff pair should be the same. Check the setting WIDTHRANGE for the diff pair nets in constraint file.

# IMPSR-217

## **NAME**

IMPSR-217

### **SUMMARY**

The net group %s cannot be found in the design. The tool will ignore it.

## **DESCRIPTION**

route\_flip\_chip cannot find the net group specified by the keyword BUSGUIDE in the constraint file. Check the parameter of BUSGRUIDE for bus routing in constraint file, or create this net group by command create\_net\_group.

### NAME

IMPSR-218

#### **SUMMARY**

The nets in the net group %s are different between route\_flip\_chip constraint file and create\_net\_group. The tool will ignore net group %s.

### DESCRIPTION

All the nets in the net group define by route\_flip\_chip constraint file should be in the net list defined by create\_net\_group and vice versa. Check the setting BUMP/SHIELDNET for bus routing in constraint file, or set srouteCheckNetinNetGroup to false to disable this check in extra configure file.

# **IMPSR-219**

## **NAME**

IMPSR-219

### SUMMARY

route\_flip\_chip cannot find bus guide segments for the net group %s in the design. The tool will ignore net group %s.

## **DESCRIPTION**

route\_flip\_chip cannot find any bus guide for net group. Check the setting BUSGUIDE for bus routing in constraint file, or create proper bus guide for the net group.

### NAME

IMPSR-221

## **SUMMARY**

route\_flip\_chip cannot get the end points of bus guides for net group %s. The tool will ignore net group %s.

## **DESCRIPTION**

route\_flip\_chip fails to get the end points of bus guides. Normally this happens when the connected bus guids are ended by 45 degree bus guide, which is not supported. Try to add one orthogonal bus guide to the end point of the 45 degree bus guide.

# IMPSR-222

## **NAME**

IMPSR-222

## SUMMARY

route\_flip\_chip cannot get two proper end points of bus guides for net group %s. The tool will ignore net group %s.

## **DESCRIPTION**

route\_flip\_chip fails to get two proper end points of bus guides. Normally this happens when the connection styles of bus guides is too complex. Try to avoid T connection, and make sure that the connection between two bus guides are point-to-point connection, and the bus guides are ended on othogonal bus guides for two ends.

## NAME

IMPSR-223

### **SUMMARY**

Bus guides are touching the boundary box of bumps/pads in net group %s. The tool will ignore net group %s.

## **DESCRIPTION**

Bus guides are touching the boundary box of bumps/pads in net group. Try to move the bus guides out of the boundary box of bumps/pads.

# IMPSR-344

### NAME

IMPSR-344

## **SUMMARY**

The locations of bumps/pads in diff pair (%s %s) are too twisted for route\_flip\_chip. The two nets are routed as normal nets.

## **DESCRIPTION**

The connection line of two bump centers is crossing with that of two pad centers.

### NAME

IMPSR-345

### SUMMARY

The number of bumps/nets in net group %s is less than 3. The tool will ignore net group %s.

## **DESCRIPTION**

The bumps/nets in one net group should be no less than 3. Try differential pair routing for two nets. And one net cannot form a net group.

# IMPSR-346

## **NAME**

IMPSR-346

## **SUMMARY**

Cannot find bump %s specified in net group %s. The tool will ignore net group %s.

## **DESCRIPTION**

route\_flip\_chip cannot find the bump with the bump name in constraint file. Confirm the bump to be routed in net group.

### NAME

IMPSR-347

## **SUMMARY**

Cannot find shield net %s specified in net group %s. The tool will ignore net group %s.

## **DESCRIPTION**

route\_flip\_chip cannot find the shield net with the net name in constraint file. Confirm the shield net name in net group.

## IMPSR-348

## **NAME**

IMPSR-348

## **SUMMARY**

Bump %s in net group %s belongs to a multi-term net. The tool will ignore net group %s.

## **DESCRIPTION**

route\_flip\_chip cannot get the target pad for bump in multi-term net for bus routing. Try to use pair constraint, or bump property to specify the target pad for this bump.

## NAME

IMPSR-349

#### **SUMMARY**

In net group %s, Bump %s is not selected to route. The tool will ignore net group %s.

## **DESCRIPTION**

The bump is skipped in route\_flip\_chip. If using with option '-selected\_bumps', check if the bump is in the list of the specified bumps. If using with option '-nets', check if the net of the bump is in the list of the specified nets.

# IMPSR-794

#### NAME

IMPSR-794

### SUMMARY

On bump '%s', IO port in '%s' is not found or suitable for routing to net '%s'. Check the bump property to correct it.

## **DESCRIPTION**

The IO port is too small or narrow, blocked by obstruction, or has already been routed, or the port number does not exist, or there are typos on the bump property.

### NAME

IMPSR-1256

#### **SUMMARY**

Cannot find any CORE class pad pin of net %s. Change routing area or layer to include the expected pin, or check netlist, or change port class in the technology file.

### **DESCRIPTION**

This message is reported when routing pad pins. Pad pins are power pins on the pad which should connect to the core power grid or ring. By default, route\_special considers all power pins on the pads to connect to the power pad ring and not the core unless the pin's PORT definition is specified with CLASS CORE in the technology file. A power pin of a pad which is to drive the core power grid should be defined.

## **IMPSR-1972**

#### NAME

IMPSR-1972

### **SUMMARY**

\*\*\*[%.3f %.3f] in '%s': Can't be routed because '%s' is blocked by cell or routing blockages (obstructions) preventing from routing.

## **DESCRIPTION**

This message indicates the pin is blocked by cell or routing blockages (obstructions) preventing route\_flip\_chip from routing to them.

Zoom to the pin and observe what blockages are at the same layer as the pin or above.

Error and Warning Messages

The blockages need to be removed from around and on top of the pin so route\_flip\_chip can access it without creating a violation.

If the pin is blocked by a routing blockage, edit the blockage so the pin can be accessed.

If it is a cell blockage, you will need to update the LEF file or OA abstract view so the obstruction does not block the pin.

## **IMPSR-1974**

#### NAME

IMPSR-1974

### SUMMARY

%d port%s blocked by cell or routing blockages in M%d-M%d layer. Check the design if cell or routing blockages need be removed.

#### DESCRIPTION

This message indicates the pin is blocked by cell or routing blockages (obstructions) preventing route\_flip\_chip from routing to them.

Zoom to the pin and observe what blockages are at the same layer as the pin or above.

The blockages need to be removed from around and on top of the pin so route\_flip\_chip can access it without creating a violation.

If the pin is blocked by a routing blockage, edit the blockage so the pin can be accessed.

If it is a cell blockage, you will need to update the LEF file or OA abstract view so the obstruction does not block the pin.

## **IMPSR-2457**

#### NAME

**IMPSR-2457** 

Error and Warning Messages

### **SUMMARY**

There is overlap of RANGE rules for SPACING on layer %s, spacing %.3f for [%.3f %.3f] and spacing %.3f for [%.3f %.3f]. The range values should not overlap. The router will use spacing %.3f for routing width no less than %.3f.

### **DESCRIPTION**

The range values should not overlap if you specify multiple RANGE rules for SPACING.

## **IMPSR-2459**

## NAME

**IMPSR-2459** 

### **SUMMARY**

The geometry on layer %s in bump cell %s is too complicated for route\_flip\_chip. The tool will try to replace the geometries with its circumscribed octagon.

## **DESCRIPTION**

This may happen when there are too many complex geometries in bump pin. The circumscribed octagon can help route\_flip\_chip to improve routability, but may cause design rule violations around bump in final routing result. User can manually set 'setFlipChipMode -bump\_use\_oct\_shape false' to use the original geometries.

## **IMPSR-2617**

## **NAME**

IMPSR-2617

Error and Warning Messages

## **SUMMARY**

The spacing value %s in line %d is smaller than allowed MINSPACING in layer %s in the technology file.

## **DESCRIPTION**

When the spacing value in route\_flip\_chip constraint file is smaller than allowed MINSPACING in that layer in the technology file, MINSPACING will be used.

## **IMPSR-4006**

## NAME

IMPSR-4006

## **SUMMARY**

Failed to open extra config file %s to read.

## **DESCRIPTION**

The message occurs because there is no reading permission or the file does not exist.

## **IMPSYC-2**

## NAME

**IMPSYC-2** 

## **SUMMARY**

Timing information is not defined for cell %s; Check the timing library (.lib) file and make sure the timing information exists for the cell and you can run the %s command to verify if the timing library

has complete information after the design is loaded.

### DESCRIPTION

This is due to the timing information for cell %s is missing.

This warning could be shown even when the cell is physical cell

# **IMPSYC-179**

#### NAME

IMPSYC-179

#### SUMMARY

The %s name '%s' is not a legal verilog identifier. If the identifier has special characters, use escaped format which start with backslash '\' and end with one space character ' '.

## **DESCRIPTION**

This ERROR comes up with any command where instance/net name has special characters in it. Commands like addPowerSwitch, attachDiode.

1. Special character in the instance name:

attachDiode -diodeCell ANTENNA -pin xyz\_F\_1\_o\_reg[0] D

needs to be changed to

attachDiode -diodeCell ANTENNA -pin {xyz\_F\_1\_o\_reg\[2\] } D

2. Special character in the pin name:

attachDiode -diodeCell ANTENNA -pin hier.sub1/instance\_1 D[2]

needs to be changed to

attachDiode -diodeCell ANTENNA -pin hier.sub1/instance\_1 {D[2]}

## NAME

IMPSYC-194

## **SUMMARY**

Incorrect usage for command '%s'.

## **DESCRIPTION**

IMPSYC-194 is a common and generic error message for any command and may have numerous specific causes if the command has been incorrectly used. Check the man page of the command being reported in this error to know the correct usage of it.

# **IMPSYC-959**

#### NAME

IMPSYC-959

### **SUMMARY**

Inst '%s' in module '%s' has tie-high/low output pin '%s'. This can create a short circuit if the pin is not the driver of the power/ground net to be tied to, and the pin's output polarity is different from that of the power/ground net. Check the connectivity in the netlist.

## **DESCRIPTION**

This error indicates that a OUTPUT/INOUT pin is tied high/low i.e. pin is driving the power network which might result in a short.

#### Check:

-> If the pin is defined with USE POWER or USE GROUND in the LEF which means the pin is PG

Error and Warning Messages

pin and its connectivity should not be defined in Verilog. The globalNetConnect command connects PG pins to the specified global net, which is either a power or ground net.

- -> If the pin is a signal pin, properly define its DIRECTION in the LEF.
- -> To avoid this error, You can set the following prior to init design:

setCheckMode -vcellnetlist false

Note: Make sure that the sign-off LVS is run in your flow to verify the final power connections are correct.

## IMPSYC-1636

#### NAME

IMPSYC-1636

## **SUMMARY**

No library found for level shifter cell '%s' with input '%f' and output '%f' volts, placed in power domain '%s'. The first available library cell of the same name will be used, irrespective of input and output voltages.

#### DESCRIPTION

Why is this message issued during timing analysis?

Following are excerpts from the library showing a level shifter and associated pins and their voltage. If a level shifter with the appropriate voltages is not found the error above will be issued.

At the top of the file the voltage levels are defined using voltage\_map

statements:

```
voltage_map (VDD, 1.08);
voltage_map (ExtVDD, 0.9);
voltage_map (VSS, 0);
voltage_map (GND, 0);
```

Error and Warning Messages

```
voltage_map (ExtVSS, 0);
Example:
Within the cell definition define power pins and respective voltage names
within a pg_pin statement:
cell (LSHLX1 FROM) {
is level shifter: "true";
level_shifter_type : "HL";
area:0;
pg_pin (VSS) {
pg_type : primary_ground;
voltage_name: "VSS";
}
pg_pin (VDD) {
pg_type:primary_power;
std_cell_main_rail: true;
voltage name: "VDD";
}
pg_pin (ExtVDD) {
pg_type : backup_power;
voltage name: "ExtVDD";
Lastly, define the signal level and related power and ground pins for the input
and output pins:
pin (Y) {
output_signal_level : ExtVDD;
direction: output;
function: "A";
```

Error and Warning Messages

```
related_ground_pin: VSS;
related_power_pin: ExtVDD;
pin (A) {
input_signal_level: VDD;
direction: input;
related_ground_pin: VSS;
related_power_pin: VDD;
```

# **IMPSYC-1816**

## NAME

IMPSYC-1816

## **SUMMARY**

The connectivity of the net '%s' in saved routing file" "mismatches with the connectivity of the same net in memory.

## **DESCRIPTION**

While running restoreRoute or restoreDesign, the above message is issued when the connectivity of a net recorded in the routing file of the EDI System database (\*.route or \*.route.gz file) does not match the connectivity of the net in memory (usually read from the Verilog during init\_design or restoreDesign). Make sure the routing file correlates to the database in memory. If it does, try running the latest software release of EDI as this may be due to a software issue. If the error still is reported, please open a Case through http://support.cadence.com.

Overall, make sure you did not make any changes to the Verilog which are not reflected in the other database files. If you need to modify the Verilog file, you should then run one of the ECO Flows described in the EDI System User Guide.

### NAME

IMPSYC-1919

## **SUMMARY**

The connectivity mismatches to the routing data." "The wire at ( %d %d ) on net '%s' is associated to" "the instance pin '%s:%s" "which is on a different net '%s'.

### **DESCRIPTION**

This is a data integrity error. Review all previous steps to see how this is triggered and report it to Cadence.

## IMPSYC-1921

### NAME

IMPSYC-1921

### **SUMMARY**

The connectivity mismatches to the routing data." "The wire at ( %d %d ) on net '%s' is associated to" "the IO pin '%s'" "which is on a different net '%s'.

## **DESCRIPTION**

This is a data integrity error. Review all previous steps to see how this is triggered and report it to Cadence.

### NAME

IMPSYC-1922

#### **SUMMARY**

The connectivity mismatches to the routing data." "The wire at ( %d %d ) on net '%s' is associated to" "the instance pin '%s:%s" "which is not connected to any net.

## **DESCRIPTION**

This is a data integrity error. Review all previous steps to see how this is triggered and report it to Cadence.

## IMPSYC-1923

### NAME

IMPSYC-1923

## **SUMMARY**

The connectivity mismatches to the routing data." "The wire at ( %d %d ) on net '%s' is associated to" "the IO pin '%s'" "which is not connected to any net.

## **DESCRIPTION**

This is a data integrity error. Review all previous steps to see how this is triggered and report it to Cadence.

### NAME

IMPSYC-2100

#### SUMMARY

Instance %s added but could not find spare cell for it.

## **DESCRIPTION**

Possible reasons for not finding a spare cell are:

- 1. Either the spare instance or the unplaced instance or both have region/fence placement constraints and no spare instance could be found that does not cause a constraint violation. To fix remove the placement constraints on the spare instances or add new spare instances into the same region/fence hierarchy as the unplaced instances.
- 2. Spare instance having the same cell type as the unplaced instance is not available.

Check if set spare insts command has been used to specify the spare instances.

create\_spare\_module/place\_spare\_modules, read\_spare\_insts are some of the commands that could

also be used to insert spare instances in the design.

3. eco\_remap and eco\_swap\_spare\_cell commands could be used to map any remaining unplaced instances

after ecoPlace -useSpareCells to spare instances of different cell types.

### NAME

IMPSYC-3161

## **SUMMARY**

Ignoring the -syncRelativePath setting in the configuration file. The -syncRelativePath parameter of the set\_import\_mode command is set to true in ETS by default. All relative paths in the configuration file will be synchronized to the current working directory. To avoid this warning, remove the syncRelativePath setting from the configuration file.

#### DESCRIPTION

{This warning is displayed because the ETS software ignores the -syncRelativePath setting in the configuration file and uses the default value (true) for the -syncRelativePath parameter of the set\_import\_mode command. When the -syncRelativePath parameter of the set\_import\_mode command is set to true, all the relative paths in the configuration file are synchronized to the current working directory. As a result, the configuration file can be loaded from any directory without changing the current working directory to the directory in which the configuration file was saved. You can use the set\_import\_mode -syncRelativePath false command in ETS if you do not want to synchronize the relative paths in the configuration file to the current working directory. Use this command after invoking ETS and before reading the design. To avoid this warning, remove the -syncRelativePath setting in the configuration file.}

## IMPSYC-3166

## **NAME**

IMPSYC-3166

## **SUMMARY**

The use of '%s' with '%s' is not supported.

## DESCRIPTION

At most only one of these can be used at a given time; correct your configuration.

## IMPSYC-6114

## NAME

IMPSYC-6114

### SUMMARY

Could not add padding to given cell <%s>.

#### DESCRIPTION

Cell padding can only be added to standard cells of the library. Padding on hierarchical module, macro block, io pads, etc. is not supported.

# IMPSYC-6152

### NAME

IMPSYC-6152

## **SUMMARY**

Net %s is marked as unrouteable by NanoRoute." "There may be an internal error or issue with the input data that triggers" "this net to be set as open. Please check the net objects for issues.

## DESCRIPTION

If the pre route data contains issues, partial routes with FIXED vias, routes or other issues that will cause routing problems, NanoRoute sets the Nets attribute to skip the net and routes the other nets in the design. If the pre route is custom and complete the message can be ignored. If the preroute

Error and Warning Messages

needs to be completed by NanoRoute the FIXED segments and vias may need to be converted to routed status. If you need the partial preroutes to be locked the preroutes may need to be converted to special nets for completion by the router.

### Example:

convert\_routes\_to\_special \$net1

set\_route\_attributes -net \$net1 skip\_routing false
set\_db route\_with\_eco true
route eco

## IMPSYC-6164

#### NAME

IMPSYC-6164

### **SUMMARY**

Invalid padding value 0 is given, please correct usage with integer greater than 0.

## **DESCRIPTION**

To clear the specified padding for a cell or list of cells, please use command delete\_cell\_padding.

# **IMPSYC-6375**

## NAME

IMPSYC-6375

Error and Warning Messages

## SUMMARY

Can't read hier pg file '%s' because hier pg feature is not on. To turn on hier pg feature please set the variable 'upf hier pg port support'.

### DESCRIPTION

If the variable is already set in your script file, but you still get this message, please check the file root.init in your design hierarchy, may be the variable got set in this file.

## **IMPSYC-6376**

## **NAME**

IMPSYC-6376

#### SUMMARY

Can't save hier pg file '%s' because hier pg feature is not on. To turn on hier pg feature please set the variable 'upf hier pg port support'.

## **DESCRIPTION**

If the variable is already set in your script file, but you still get this message, please check the file root.init in your design hierarchy, may be the variable got set in this file.

## **IMPSYT-6260**

## **NAME**

IMPSYT-6260

### **SUMMARY**

An error occurred while loading file %s/%s.globals. Review the messages above for reasons why loading the file failed. This often occurs when global variables have become obsolete. These variables will be ignored and the rest of the file will still be processed. To avoid this error remove these obsolete variables from the file.

### DESCRIPTION

{This error will show if there is any error in the .globals file. It normally associates with GLOBAL errors.}

# **IMPSYT-6284**

### NAME

IMPSYT-6284

### SUMMARY

Failed to open file %s for read.

### **DESCRIPTION**

{This message is issued when the software is not able to open a file for read. This might happen due to file access permissions, or a transient NFS fault, or due to the file being accidentally deleted or corrupted.}

# IMPSYT-7221

#### NAME

IMPSYT-7221

### SUMMARY

read db failed: %s.globals file not found in '%s/%s/%s'.

### **DESCRIPTION**

{If the cellview is a derivative of the one created by write\_db -oa\_lib\_cell\_view,then use copyOaRestoreFiles to update the cellview from an earlier version. If the cellview was created by another method use File->Import Design or set the init\_ design variables (find\_global init\_\*) as needed and then invoke the init\_design command.}

# **IMPSYT-16038**

#### NAME

IMPSYT-16038

### **SUMMARY**

The specified file '%s' could not be found. Check your file system, correct the file name.

## **DESCRIPTION**

This error occurs when a missing file is encountered during design parsing.

The tool cannot find a file if:

- 1. The file path name is incorrect.
- 2. A variable which is used in the path name is not correctly specified.
- 3. The read permission to the file path is disabled.

# **IMPSYT-40503**

### NAME

**IMPSYT-40503** 

#### SUMMARY

Support for the loadConfig command and the configuration file based design import methodology for designs which are not configured as multi-mode/multi-corner (MMMC) has been discontinued in this release.

## **DESCRIPTION**

This flow is replaced by the init\_design based design import flow.

To import your design database to an 11.1 MMMC configuration, you should perform a write\_db using a 10.1 version of the software, and then perform a read\_db using version 11.1 of the software.

You should refer to the 'Importing Designs Saved in Previous Versions' section in the 'Importing and Exporting Designs' chapter in the EDI11 user guide for more detailed information.

# **IMPSYUTIL-96**

### **NAME**

**IMPSYUTIL-96** 

## **SUMMARY**

Cannot open (for %s) %s file: '%s'. The reason is: %s

### DESCRIPTION

This error is reported when assembling a design because the topDir database does not contain a DEF file. For option -topDir specifies the path to the top-level design created by saveDesign -def. This design directory should contain the Verilog netlist and DEF files.

Load the top design and do a defOut to save the DEF or run for the top level so that topDir contains the DEF.

# **IMPSYUTIL-106**

## **NAME**

**IMPSYUTIL-106** 

#### SUMMARY

Cannot allocate %ld bytes.

### DESCRIPTION

Failed in memory allocation. It is likely that the machine run out of virtual memory.

# **IMPTB-2**

### NAME

**IMPTB-2** 

### **SUMMARY**

Cannot complete command %s, not able to open %s for write, provide a file path which can be opened for write to complete execution.

# **DESCRIPTION**

Error and Warning Messages

The possible reasons you have this message might be:

- 1. You may not have necessary file operation permissions to create a file on current working directory.
- 2. There is a same-name file which you do not have write permission on it.
- 3. You may have run out of disk space.

#### Example:

Check whether you have permission to create a file on current working directory:

```
innovus 7> file writable [pwd]
```

1

Check whether you have a same-name file which you do not have write permission on it on current working directory:

```
set fileName innovus.log1
if {[file exists $fileName]} {
  puts [file writable $fileName]
} else {
  puts 0
}
```

Check if you have run out of disk space:

innovus 16> df -kH [pwd]

Filesystem Size Used Avail Use% Mounted on

/dir/subdirectory1/case/case11189 2.2T 2.0T 271G 88% /dir/subdirectory1/case/case11189

# **IMPTB-36**

### NAME

IMPTB-36

### **SUMMARY**

Error and Warning Messages

Partition name %s does not match a hierarchical instance or a black box and will be ignored.

## **DESCRIPTION**

The specified name does not match an uncommitted partition (hierarchical instance with a fence) or a black box (create floorplan block object).

Example:

create\_timing\_budget -partitions ptnA

Warning: Partition name ptnA does not match a hierarchical instance or a black box and will be ignored.

# **IMPTB-178**

### NAME

**IMPTB-178** 

### **SUMMARY**

Command set\_fixed\_budget cannot accept option "-from\_flops\_of" and "-to\_flops\_of" together.

## **DESCRIPTION**

set\_fixed\_budget command can only be applied on a path segment. Please use it with pins at either "-from" or "-to" option.

# **IMPTB-521**

### **NAME**

IMPTB-521

Error and Warning Messages

### **SUMMARY**

No SDC file found for analysis view %s. Make sure analysis views are properly constrained prior to running create timing budget.

### **DESCRIPTION**

Check if viewDefinition file has correct SDC files (not a physical only flow or absent timing constraints).

# **IMPTB-522**

### NAME

IMPTB-522

### **SUMMARY**

Partition %s's ports %s and %s are connected through verilog assign. Budgeting requires a physical pin inside partition in order to budget timing path inside partition.

# **DESCRIPTION**

Verilog assign statements can be removed using 'delete\_assigns -buffering' command before running create\_timing\_budget.

# IMPTCM-42

## **NAME**

IMPTCM-42

### **SUMMARY**

"%s" is not a legal option for command "%s". Check the option whether is an existed option through command -help.

### DESCRIPTION

This error is displayed when a command is entered with incorrect switch which is not supported by the command.

The message will also display the command and a list of switches which are legal to use for the command.

Review and use the command with the appropriate legal switch.

# **IMPTR-1107**

#### NAME

**IMPTR-1107** 

### **SUMMARY**

Cannot find net %s, which is shown in the routing guide.

## **DESCRIPTION**

When user set up trial route guides for certain nets by using "setTrialRouteMode -routeGuide <filename>", if a net or nets in the guide can not be found in the design, the warning message will be issued.

Related command is saveRouteGuide.

Example:

For example, in the netGuide.file below, the net "xyz" is defined but does not exist, routeGuideNet xyz

Error and Warning Messages

wire 413.49 27.72 413.49 17.64 V 0.5 L 4

wire 413.49 17.64 413.49 12.04 V 0.5 L 4

wire 413.49 17.64 420.75 17.64 H 0.5 L 3

endRouteGuideNet

route\_trial will issue the warning message.

# **IMPTR-1109**

### NAME

IMPTR-1109

### **SUMMARY**

Guide wires for net %s at line %d will be ignored because the net is prerouted/ignored.

### **DESCRIPTION**

When route guides are used for certain nets and these nets are already prerouted, or they are to be ignored ("setAttribute -skip\_routing true"), this WARN message will appear during route\_trial if "setTrialRouteMode -routeGuide <filename>" has these nets defined.

#### Example:

The clock net cclk is prerouted and this net is in route guide file as below,

routeGuideNet cclk\_\_L1\_N1

wire 324.39 243.88 324.39 274.68 V 0.5 L 4

wire 324.39 243.88 348.81 243.88 H 0.5 L 3

wire 324.39 274.68 324.39 279.72 V 0.5 L 4

wire 324.39 279.72 288.75 279.72 H 0.5 L 3

wire 348.81 243.88 350.79 243.88 H 0.5 L 1

wire 288.75 279.72 288.09 279.72 H 0.5 L 1

Error and Warning Messages

#### endRouteGuideNet

The message would be issued as,

\*\*WARN: (INNTR-1109): Guide wires for net cclk\_\_L1\_N1 at line #% will be ignored because the net is prerouted or ignored.

# **IMPTR-2108**

### **NAME**

**IMPTR-2108** 

### SUMMARY

For layer M%d, the gaps of %d out of %d tracks are narrower than %0.3fum (space %0.3f + width %0.3f).

### **DESCRIPTION**

The message occurs when gaps of track(s) of a layer are narrower than minimum allowed value (space + width) from the default routing rule. Those tracks might be initialized by a technology LEF which has values smaller than current one. Please make sure you have loaded the correct technology LEF or regenerate tracks to avoid this message.

### Example:

The following commands generate new routing tracks:

\tinnovus> generateTracks

The following command generates tracks with a horizontal offset of 0.13, a horizontal pitch of 0.26, a vertical off set of 0.14, and a vertical pitch of 0.28 on layer m2:

\tinnovus> generateTracks -m2HOffset 0.13 m2HPitch 0.26 m2VOffset 0.14 -m2VPitch 0.28

# **IMPTR-2322**

### NAME

**IMPTR-2322** 

#### **SUMMARY**

There are %d unplaced instances that will not be routed. Place all instances in the design before routing. TrialRoute will continue.

### **DESCRIPTION**

This message pops-up while running &'route\_trial&' command if the design has any un-placed instances. The design will still be routed issuing this warning message.

### Example:

In order to fix this warning message user needs to check if there are any unplaced instances in the design prior to running route\_trial command. The unplaced instances can be reported by running &'checkPlace checkPlace.rpt&' and verifying checkPlace.rpt file to find out unplaced instances and fixing this issue.

# **IMPTR-2325**

### **NAME**

**IMPTR-2325** 

### **SUMMARY**

There are %d nets connecting a pad term to a fterm without geometry and these nets will not be routed. A pad term is a pin of a pad logically connected to a top level module port (fterm). Type 'set trPrintIgnoredPadNets limit>' prior to route\_trial to have it report each net up to limit>. Review the list of nets and verify they do not require a physical route between the pad pin and fterm. Top level

Error and Warning Messages

fterms connecting to pad pins typically do not require a physical route because the pad pin will connect to signals external to the design.

### DESCRIPTION

This is referring to the top level ports that connect to the PAD pin of the IO pad. Since these signals connect outside of the chip there is no port geometry to route to. For IO pins directly connected to IO pads, Innovus System implicitly considers the pin of the IO pad as an IO pin. Typically, you can ignore this warning.

Use &'set trPrintlgnoredPadNets < limit>&' prior to route trial to report each net up to < limit>.

Review the list of nets and verify they do not require a physical route between the pad pin and fterm. Top level fterms connecting to pad pins typically do not require a physical route because the pad pin will connect to signals external to the design.

### Example:

You can set the following to have the warning list the nets it is ignoring:

\tset trPrintIgnoredPadNets 100

It will print up to 100 nets as:

PAD NET <net> is ignored.

Note:

The ignored net info can only be seen in innovus.logy file and not in the innovus.log file.

# **IMPTR-7111**

#### NAME

IMPTR-7111

#### SUMMARY

There is no track for routing layer %s. Since the layer is not used, route\_trial will continue.

## **DESCRIPTION**

This message pops-up in the design if the user tries to run route\_trial with first layer use turned on and there are no M1 tracks available to route.

### Example:

In order to fix this issue user needs to define M1 tracks and then run route\_trial after setting use\_metal1\_for\_routes attribute true.

# **IMPTR-7122**

### NAME

IMPTR-7122

### **SUMMARY**

There is no selected net in file "%s" and route trial will continue.

## **DESCRIPTION**

This message will pop-up when the user tries to set a file for selected nets first attribute and there are no nets specified in the mentioned file.

### Example:

In order to avoid this warning message the user needs to specify the nets he wanted to route one on each line in a file. This file can be inputted using route nets only and then he can run &'route\_trial&' command to route specific nets.

# **IMPTR-8007**

#### NAME

**IMPTR-8007** 

### **SUMMARY**

The "-useNanoRoute" option cannot be used for this design as it contains %s, and is therefore disabled. Regular route trial will be invoked.

### **DESCRIPTION**

This message pops-up when the user tries to run route\_trial using NR global Route flow and the design contains partition and/or BB.

### Example:

In order to avoid this warning message if the design has partition and/or BB NR global Route flow cannot be used, user needs to turn-off

"-useNanoRoute false" before invoking &'route\_trial&' command.

# **IMPTR-8015**

### **NAME**

IMPTR-8015

### **SUMMARY**

route\_trial does not currently support option "%s" in this mode. Please reset use nano route attribute if you require this option.

# **DESCRIPTION**

This message pops-up when the user runs route\_trial in NRGR flow with skipped tracks.

# **IMPTS-16**

### NAME

IMPTS-16

### **SUMMARY**

Inconsistency detected in the time units specified among the timing libraries being used. Default system time unit of 1ns will be used. Use the '%s' command to set a specific time unit.

### **DESCRIPTION**

This error is flagged during timing analysis when timing libraries with different time units are read into the software.

All timing library data is interpreted according to the native units of each individual library. When the library units differ across different libraries, this message is issued and all the time units are interpreted and reported with the default time unit.

However, you can use the '%s' command to set a specific time unit for the system. The system time unit will be used for reporting as well interpreting the constraints, which are either sourced from SDC files or entered interactively.

# **IMPTS-17**

### **NAME**

IMPTS-17

## **SUMMARY**

Inconsistency detected in the capacitance units specified among the timing libraries being used. Default system capacitance unit of 1pF will be used. Use the '%s' command to set a specific capacitance unit.

### DESCRIPTION

This error is flagged during timing analysis when timing libraries with different capacitance units are read into the software.

All timing library data is interpreted according to the native units of each individual library. When the library units differ across different libraries, this message is issued and all the capacitance units are interpreted and reported with the default capacitance unit.

However, you can use the '%s' command to set a specific capacitance unit for the system. The system capacitance unit will be for reporting as well as interpreting constraints, which are either sourced from SDC files or entered interactively.

# **IMPTS-282**

### NAME

IMPTS-282

### **SUMMARY**

Cell '%s' is not a level shifter cell but has 'input\_signal\_level' and 'output\_signal\_level' specified on pins, or it has different related\_power\_pin specified on input and output pins. To mark this cell as level shifter, use 'is\_level\_shifter' attribute.

#### DESCRIPTION

This cell either has different related\_power\_pin defined for input and output pins, as per new liberty syntax, or it has 'input\_signal\_level' and 'output\_signal\_level' specified on pins, as per old liberty format. This can be specified for level\_shifter\_cells only. For a level shifter cell 'is\_level\_shifter' attribute is required.

# **IMPTS-302**

#### NAME

IMPTS-302

Error and Warning Messages

### **SUMMARY**

Min timing libraries are not specified, while max timing libraries are specified in configuration file. This may cause issues in hold analysis. Use rda\_Input(ui\_timelib) instead of rda\_Input(ui\_timelib,max) for timing library specification, or use setTimingLibrary command to set min timing libraries. By default max timing libraries will be used for hold analysis.

### **DESCRIPTION**

For a non-MMMC setup it is mandatory to provide both min and max libraries. During timing analysis the max libraries are used during setup/late analysis and min libraries are used during early/hold analysis. When the min libraries are missing, the software will only use the max libraries for early/hold analysis, this may cause inaccurate timing results. It is, therefore, recommended that you provide both max and min libraries in the configuration file.

# **IMPTS-313**

### **NAME**

IMPTS-313

### SUMMARY

Cell '%s' is missing in current active analysis view. No library found in MMMC library set corresponding to the cell. This can cause problem during optimization flow. The cell will therefore be marked as 'dont use' during optimization.

### DESCRIPTION

This message is issued when the cell is not defined for current active analysis view. Library is not present in library set corresponding to this cell for the active analysis view. This can cause problem during optimization flow. The cell will therefore be marked as 'dont\_use' during optimization.

# **IMPTS-403**

### NAME

IMPTS-403

### **SUMMARY**

Delay calculation was forced to extrapolate table data outside of the characterized range. In some cases, extrapolation can reduce the accuracy of the delay calculation. You can enable more detailed reporting of these cases by enabling the command 'set\_db delaycal\_report\_out\_bound true'.

### DESCRIPTION

This warning message is issued during Delay Calculation when the input transition or output load are falling beyond the library specified delay/slew table. This causes extrapolation of table values and may result in inaccurate reported values from Delay Calculation. It is recommended that you provide libraries for which the input transition/output capacitance of the design are within the library table boundaries. You can obtain a detailed report of outside range table boundaries by using the 'setDelayCalMode -reportOutBound true' command.

# IMPTS-414

### **NAME**

IMPTS-414

### **SUMMARY**

There is mismatch in pin direction for the pin '%s' of cell '%s' specified in LEF or Verilog, and the timing library. The timing library value will be used.

# **DESCRIPTION**

Error and Warning Messages

This message is issued when there is mismatch in the pin direction defined for cell between LEF/verilog and timing library. The timing library value will be used.

# **IMPTS-415**

### NAME

IMPTS-415

### **SUMMARY**

Cell '%s' is not defined in all timing analysis view. This cell should be defined in all analysis views. Check the library binding of instances in active views using the command 'check\_instance\_library\_in\_views'.

### DESCRIPTION

This message is issued when the cell is not present in all timing analysis view. Check the library binding of instances in active views using the command 'check\_instance\_library\_in\_views'.

# **IMPTS-423**

### NAME

IMPTS-423

## **SUMMARY**

No library found for instance '%s', cell '%s', in powerdomain '%s', of view '%s'

### **DESCRIPTION**

This message is issued when the library is missing for an instance in a power domain for an analysis view.

# **IMPTS-429**

### NAME

**IMPTS-429** 

### **SUMMARY**

The library specified at path '%s' with set\_instance\_library command is not loaded in the session. This command is ignored. Use 'update\_library\_set' command to add this library to any active library set and re-issue set instance library command.

### **DESCRIPTION**

The library specified with command 'set\_instance\_library' must be an active library loaded in the session before this command is issued. Use 'update\_library\_set' command to add this library to any active library set and re-issue set instance library command.

# **IMPTS-451**

## **NAME**

IMPTS-451

### **SUMMARY**

No matching library found in specified list for cell '%s' of instance '%s'. The set\_instance\_library command will be ignored for this instance.

### **DESCRIPTION**

This message is issued when specified library list does not have any library containing the cell for an instance. In such cases, command is ignored only for the instance(s) for which library cells are not found.

# **IMPTS-452**

### NAME

IMPTS-452

## **SUMMARY**

No matching instance/hinstance found for '%s'.

## **DESCRIPTION**

This message is issued when instance or hinstance specified is not found in the design. In such cases, command is ignored only for invalid instance/hinstance.

# **IMPTS-455**

## **NAME**

IMPTS-455

## **SUMMARY**

Design loading aborted due to library inconsistency. Refer to %s message(s) above for more details. Correct the library inconsistency and re-load.

# **DESCRIPTION**

This message is issued when any library inconsistency(pin/cell mismatch across libraries) is found. In such cases design will be aborted.

# **IMPVAC-0**

### NAME

**IMPVAC-0** 

### **SUMMARY**

Skipping net %s as it has no defined frequency or a defined frequency of 0Hz. Check your design, or use verifyACLimitSetFreq/dbSetNetFrequency to specify the net frequency.

### **DESCRIPTION**

Use 'verifyACLimitSetFreq -help' or 'dbSetNetFrequency -help' to get more usage for setting the net frequency.

# **IMPVAC-96**

### NAME

**IMPVAC-96** 

### **SUMMARY**

No EM rule is found in QRC tech file. Please check QRC tech file if it doesn't contain EM rule or incorrect layer stacking information.

### **DESCRIPTION**

Use 'get\_rc\_corner <rc\_corner\_name> -qrc\_tech' to get the qrc tech file and check if it matches to the design.

# **IMPVAC-131**

### NAME

IMPVAC-131

#### **SUMMARY**

NET %s has no wire cap.

## **DESCRIPTION**

Check if net %s is annotated in your parasitic file or if you had issues while reading such file.

You can run "report\_annotated\_parasitics -nets "..."" giving net's names to see if net is back-annotated.

Or run report\_annotated\_parasitics after reading parasitics file for a complete status report.

# **IMPVCM-7**

### NAME

IMPVCM-7

### **SUMMARY**

Bad data in the QRC tech file or layer mapping file. Check your QRC tech setting.

### **DESCRIPTION**

Use 'get\_rc\_corner <rc\_corner\_name> -qx\_tech\_file' to get the qrc tech file and check if it matches to the design.

# **IMPVFC-3**

### NAME

**IMPVFC-3** 

## **SUMMARY**

Verify Connectivity stopped: Number of errors exceeds the limit %d

## **DESCRIPTION**

The defulat error number is 1000, please use "check\_connectivity -error" to specify more error number.

For example, "check\_connectivity -error 100000".

# **IMPVFC-16**

### **NAME**

**IMPVFC-16** 

## **SUMMARY**

%s is not attached to any terminal.

## **DESCRIPTION**

The message is issued by VerifyConnectivity when a net is not connected to any terminal.

# **IMPVFC-92**

### NAME

IMPVFC-92

#### SUMMARY

Pieces of the net are not connected together

### **DESCRIPTION**

This message is reported by check\_connectivity when two metal pieces of a signal net wire segments are overlap each other and one among them is Floating Metal. This can be a valid scenario and the message to alert the user to cross check whether this is intended. If the user aware of the Floating Metal and would like to ignore such message/violation use following option. check\_connectivity -ignore\_floating\_metal

# **IMPVFC-93**

### **NAME**

IMPVFC-93

## **SUMMARY**

Bump %s has not bump\_conn\_target property.

# **DESCRIPTION**

This message is caused by that Bump %s doesn't have bump\_conn\_target property. If the bump is not assigned, first use assign\_bumps to assign a net to this bump. If the bump is assigned, use create\_bump\_connect\_target\_constraint to add the property to bump.

# **IMPVFC-200**

### NAME

IMPVFC-200

#### SUMMARY

Design must be in memory before running 'check\_power\_vias'. Use read\_db before call this command.

### **DESCRIPTION**

The design has not been restored in memory before call 'check\_power\_vias', please use use 'read db' or 'init design' to reatore the design in memory.

For example, use 'man read\_db' or 'man init\_design' to get more information how to restore design in memory.

# **IMPVFC-250**

### NAME

IMPVFC-250

### **SUMMARY**

Design must be in memory before running 'check\_wire\_gaps'. Use read\_db before call this command.

#### **DESCRIPTION**

The design has not been restored in memory before call 'check\_wire\_gaps', please use use 'read\_db' or 'init\_design' to reatore the design in memory.

For example, use 'man read\_db' or 'man init\_design' to get more information how to restore design

in memory.

# **IMPVFC-266**

### **NAME**

IMPVFC-266

#### SUMMARY

Design must be in memory before running 'check\_tieoffs'. Use read\_db before call this command.

### **DESCRIPTION**

The design has not been restored in memory before call 'check\_tieoffs', please use use 'read\_db' or 'init design' to reatore the design in memory.

For example, use 'man read\_db' or 'man init\_design' to get more information how to restore design in memory.

# **IMPVFG-216**

### NAME

IMPVFG-216

### **SUMMARY**

The invalid setting of setVerifyGeometryMode -layer will be ignored, since setVerifyGeometryMode -offSnapGrid option is false.

# **DESCRIPTION**

The layer is only used for offGrid check. If you need limit the layer range for other check, please use layerRange option. For example, verifyGeometry -layerRange {M1 M3}.

# **IMPVL-159**

#### NAME

IMPVL-159

### SUMMARY

Pin '%s' of cell '%s' is defined in LEF but not in the timing library.

## **DESCRIPTION**

This message indicates, there are pins defined in the LEF abstract but not in the respective timing library files. In the example shown below, the pins that are missing in the timing library files are power/ground pins. This might cause Innovus not to recognize the buffer, inverter and delay cells properly.

\*\*WARN: (IMPVL-159): Pin 'gnd' of cell 'BUFX2' is defined in LEF but not in the timing library.

# IMPVL-209

### NAME

IMPVL-209

### **SUMMARY**

In Verilog file '%s', check line %d near the text %s for the issue: '%s'. Update the text accordingly.

## **DESCRIPTION**

This message reports the location of the text causing a warning or error situation in the input netlist file, which is briefly described by the last argument text. Update the source text accordingly to resolve the issue.

# IMPVL-327

### NAME

IMPVL-327

### SUMMARY

Module %s has already been defined. Overwrite the previous one.

### **DESCRIPTION**

The message occurs because EDI found a module conflicts with a same-name module which has been declared earlier. To resolve the conflict, EDI replace the old module definition with the new one. To avoid this message, please remove the duplicated module definition from your verilog netlist.

# IMPVL-346

#### NAME

IMPVL-346

### **SUMMARY**

Module '%s' is instantiated in the netlist, but is not defined in the LEF files. Since there is no real cell definition for such a cell, it will be treated as %s.

### **DESCRIPTION**

The abstract view (LEF) for the macro was not defined but the instance is being instantiated in the netlist. This will cause the macro to be treated as black box or dummy cell.

To fix the problem, specify all the macro LEF files along with the timing .lib files through the init\_lef\_file list in the design.globals file and the library sets in the viewDefinition.tcl file respectively

that are used in the netlist.

# IMPVL-349

### **NAME**

IMPVL-349

#### SUMMARY

In module '%s', for instance '%s' of '%s', implicit port connections (by position) are not allowed because module '%s' is not defined in the netlist. Either provide the module definition in the netlist, or use explicit port connections (by name) for the instance.

### **DESCRIPTION**

A Verilog netlist is being read into EDI System, but it fails with the above message. This netlist can be read successfully by NC-Verilog but EDI System is rejecting it because it uses connection-by-position.

One workaround is to provide module stubs for whatever cells use connection by position. This Verilog stubs module is required in order to define the pin ordering for the module in case the implicit connections in the top level netlist are done.

# IMPVL-356

### NAME

IMPVL-356

## **SUMMARY**

The macro cell '%s' is defined in LEF, but the pin '%s' used in the netlist is not defined in LEF. Check and correct the pin name or define the pin in LEF file.

### DESCRIPTION

The message indicates that a pin is specified in a macro instantiation in the Verilog, but is not defined in the cell's LEF definition. The proper way to resolve this error is to correct the Verilog netlist or LEF so they are corresponding by checking for typos or inconsistencies in the name (lowercase vs. uppercase, different bus bit characters used, etc.)

If the netlist is in its early stages and still in development, and you just want to bypass these errors until the netlist matures, you can set the following hidden variables prior to loading the design:

set ::db::AllowSoftMatching 1 set ::db::AllowNewLefPorts 1

The AllowSoftMatching variable allows soft matching of ports. For example, it would match '\\A[0]', a scalar, to A[0], a bus bit, and would match 'a' to 'A'. The AllowNewLefPort allows undefined ports in the instantiations of LEF-defined macros.

# IMPVL-366

### NAME

IMPVL-366

#### **SUMMARY**

The macro cell '%s' is LEF-defined, but the bus port '%s' used in the netlist is not defined in LEF. Check and correct the port name, or define the bus port in LEF file.

### **DESCRIPTION**

This message indicates that the bus port is specified in a LEF macro instantiation in the Verilog, but is not defined in the cell's LEF definition. The proper way to resolve this error is to correct the Verilog netlist or LEF so they are corresponding by checking for typos or inconsistencies in the name (lowercase vs. uppercase, different bus bit characters used, etc.). If the netlist is in its early stages and still in development, and you just want to bypass these errors until the in development, and you just want to bypass these errors until the loading the design:

set ::db::AllowSoftMatching 1

set ::db::AllowNewLefPorts 1

Error and Warning Messages

The AllowSoftMatching variable allows soft matching of ports. For example, it would match "\A[0]", a scalar, to "A[0]", a bus bit, and would match "a" to "A".

The AllowNewLefPort variable allows undefined ports in the instantiations of LEF-defined macros.

# IMPVL-377

#### NAME

IMPVL-377

#### SUMMARY

Matching port %s of instance %s in module %s to port %s of cell %s by case insensitivity. Check the input data files to ensure the correct case. Fix any case mismatches and re-run.

#### DESCRIPTION

The macro LEF has port is defined as scan\_out[0] ... scan\_out[29] which is not a bit blasted syntax. So there is the mismatch between Verilog and LEF.

Soft matching the bit-blasted scalars in the netlist is getting interpreted as the LEF-defined bus bits. That's why you are getting the bussed saveNetlistresult.

To retain the netlist bit-blasted scalars, you need to edit the LEF bus bits into bit-blasted scalars as below.

scan\_out\\[0\\] .. scan\_out\\[29\\]

# IMPVL-503

### **NAME**

IMPVL-503

### **SUMMARY**

Logical pg nets are not connected to global pg nets.

Error and Warning Messages

### DESCRIPTION

This message is issued when there are missing power and/or ground connections in the design. Please make sure that logical power/ground connections are properly defined using the connect global net command.

# IMPVL-520

#### NAME

IMPVL-520

### **SUMMARY**

%s pin '%s' of instance '%s' is not connected to a power or ground net. Use globalNetConnect to connect it to a power or ground net. In a CPF-based flow, you can also use a create global connection command in the CPF to specify the connection.

## **DESCRIPTION**

The warning indicates that a power or ground pin (identified by USE POWER or USE GROUND in the LEF) is not connected to a global power or ground net. In a CPF based flow make sure you have a create\_global\_connection command in the CPF to connect this instance pin to a global power/ground net. In a non-CPF based flow use globalNetConnect to specify the connection. Otherwise, this pin will be unconnected in the exported Verilog.

# IMPVL-904

### **NAME**

IMPVL-904

# **SUMMARY**

Can't set top cell to "%s" because it does not exist. Exiting!

Error and Warning Messages

### DESCRIPTION

This message is triggered when the module name specified by read\_netlist -top <top module name> can not be found in the imported netlist.

During design import, Innovus can auto-detect the top level module. However, if there are multiple modules in the netlist that are not instantiated in other modules, then it is ambiguous what the top level module is. For that purpose, it should be specified using read\_netlist -top <top\_module\_name>.

# **IMPVL-909**

### NAME

IMPVL-909

### SUMMARY

Failed to flatten the design.

## **DESCRIPTION**

This message indicates some issues occur during flatten design. Please check previous ERRORs before IMPVL-909 to get more details.

# **IMPVPA-1**

## **NAME**

**IMPVPA-1** 

## **SUMMARY**

Verify Process Antenna stopped:

Error and Warning Messages

### DESCRIPTION

Verify Process Antenna stopped abnormally, please check the license, memory loading for possible root cause.

# **IMPVPA-22**

#### NAME

IMPVPA-22

### **SUMMARY**

check\_process\_antenna failed to run because no process antenna information found for this design. Import the process antenna library data and run check\_process\_antenna again.

#### DESCRIPTION

This error is reported because check\_process\_antenna does not have the needed information to properly check for process antenna violations. To check for process antenna violations you need to define the antenna parameters in your technology LEF or Open Access (OA) technology. For more information see the chapter Calculating and Fixing Process Antenna Violations in the LEF/DEF Language Reference.

# **IMPVPA-55**

### **NAME**

**IMPVPA-55** 

### **SUMMARY**

Option "-leffile" for command check\_process\_antenna is obsolete. Use 'lefOut -5.5 | -5.6 fileName' instead. The obsolete option still works in this release, but to avoid this warning and to ensure compatibility with future releases, remove "-leffile" from your script.

### DESCRIPTION

lefOut supports antanna information dump out, please use lef 'lefOut -5.5 | -5.6 fileName' to write out antenna information after "check\_process\_antenna". -leffile option is obsolete and will be retired in next release.

For example, please use 'man lefOut" to get help how to use lefOut to write out lef file.

# NRDB-18

#### NAME

NRDB-18

### **SUMMARY**

The binary Extended Cap Table file version (%f) is incompatible with the current version (%s)

### **DESCRIPTION**

The binary Extended Cap Table file version is incompatible with the current version.

Regenerate captable using write\_cap\_table command. Refer to the text command reference document on how to generate captable using write\_cap\_table command.

# NRDB-37

#### NAME

NRDB-37

### **SUMMARY**

The number of %s exceeds the limit %d. Remove the excess definitions before proceeding.

# **DESCRIPTION**

Error and Warning Messages

NanoRoute cannot proceed any further without reducing the number of LAYERs, NONDEFAULTRULES, VIARULES or VIAs identified in the ERROR message. Fixing this error requires removing excess definitions from the technology file and/or imported design files.

## NRDB-51

### **NAME**

NRDB-51

#### SUMMARY

%s %s has no instance pin or special wire in its connectivity definition. %s with the same name will be routed but will not be connected to the empty %s.

#### DESCRIPTION

The root cause of this issue is that the net connectivity definition is incomplete.

It may have the net name in the special net section but no instance pin or wire. If the net has connectivity in the regular net section it will have no target in the special net section and warn of the inconsistancey. One of the possible reason could be manual editing done by user.

- Please corect the input data DEF/OA.
- To avoid this warning and route the net you can do the following:
- 1) convert\_special\_to\_routes -nets test/net1
- 2) Turn-off "-skip\_routing" if exists through "set\_route\_attributes" command
- 3) Now do a selected net route\_design\_eco

## NRDB-87

#### **NAME**

NRDB-87

Error and Warning Messages

#### **SUMMARY**

%s %s is partially routed in non-ECO mode and may be re-routed. If exiting wires are to be preserved, set the route\_design\_with\_eco option to true.

#### **DESCRIPTION**

This warning indicates a net is only partially routed and that if you want to preserve the pre-routed segments you should set "set\_db route\_design\_with\_eco true". Otherwise, NanoRoute is free to reroute the net entirely based on the best solution it finds for the net. If you do not mind the net being re-routed you can ignore this warning.

### **NRDB-158**

#### NAME

NRDB-158

#### SUMMARY

Missing via from %s %s to %s %s in %s %s. Add the missing via or remove all vias from %s %s so that NR can use the vias from the default %s.

#### DESCRIPTION

In an NonDefaultRule, it is optional to specify which vias the rule should use during routing. If no vias are defined then router will use the DEFAULT via's for the NonDefaultRule routing.

If NonDefaultRule has vias defined between some layers but not all, then this error is reported.

For example, if NonDefaultRule has vias defined between Metal1 and Metal2 but not between Metal2 and Metal3, this error is reported, you need to define or specify vias between each layer. See the NONDEFAULTRULE LEF syntax for more details on defining or specifying the vias to use.

#### NAME

NRDB-164

#### **SUMMARY**

The number of layers between bottom routing layer (%d) and top routing layer (%d) is less than 2. Nanoroute cannot route with less than two routing layers.

### **DESCRIPTION**

The number of layers between bottom routing layer and top routing layer is less than 2. Nanoroute cannot route with less than two routing layers. It requires at least two routing layers in order to route.

For example, NanoRoute need at least two routing layers:

```
set_db route_design_top_routing_layer 4
set_db route_design_bottom_routing_layer 3
route_design
or
```

set\_route\_attributes -net reset -top\_preferred\_routing\_layer 4 -bottom\_preferred\_routing\_layer 3 route design

# **NRDB-166**

### **NAME**

**NRDB-166** 

### **SUMMARY**

Boundary for %s %s is not properly defined. Correct the SIZE of the corresponding MACRO in the

library.

### DESCRIPTION

Check the library if the size of stdcell/block is defined properly. If LEF format is used, make sure the SIZE statement exists in the MACRO definition, and the width/height values are not zero.

# **NRDB-319**

### NAME

**NRDB-319** 

#### **SUMMARY**

MINIMUMCUT rule specifying %d (> %d) cuts for %s %s is ignored. Only up to %d is supported right now. NOTE TO RND : Please confirm if NR can support only MINIMUMCUT 8;

### **DESCRIPTION**

Nanoroute cannot drop more than 8 cut vias, and hence cannot support below rule.

MINIMUMCUT 9 WIDTH 0.xxx;

For example,

NanoRoute issues this message and leaves mincut violations when the following rule is specified in the technology LEF:

MINIMUMCUT 9 WIDTH 0.770 WITHIN 0.39 FROMBELOW;

# **NRDB-331**

### **NAME**

**NRDB-331** 

#### **SUMMARY**

LAYER OVERLAP cannot he defined in between layer definition in the LEF. An OVERLAP layer should be defined before or after other layers. Correct this in technology LEF before continuing.

### **DESCRIPTION**

Layer "OVERLAP" cannot be defined in between the routing layers. It should be defined before or after defining the routing layers in the LEF file.

For example, Define LAYER OVERLAP before other LAYER definition in the LEF:

LAYER OVERLAP

**\tTYPE OVERLAP** 

**END OVERLAP** 

LAYER M1

**\tTYPE ROUTING** 

• • •

**END LAYER M1** 

..

or define LAYER OVERLAP at the end of all routing LAYER definitions:

LAYER M7

**\tTYPE ROUTING** 

- - -

END M7

LAYER OVERLAP

**\tTYPE OVERLAP** 

**END OVERLAP** 

#### NAME

**NRDB-605** 

#### SUMMARY

Cannot set net attribute %s to %s for %s %s, as the net has pre-routed wires. Delete the pre-routed wires or convert them to SPECIAL wires, and then retry.

#### **DESCRIPTION**

NanoRoute does not support setting the rule of a net if the net has already been partially or fully routed. To set any attribute on a net, the prerouted wires must be deleted or converted to special wires.

For example:

```
convert_routes_to_special -nets $n
select_routes -nets $n
select_vias -nets $n
edit_update_route_status -to FIXED
set_route_attributes -nets $n -route_rule CTS_RULE
```

# **NRDB-608**

#### NAME

**NRDB-608** 

#### **SUMMARY**

Cannot find special net %s for attribute %s. To reset an attribute to its default value specify the value "default".

#### DESCRIPTION

Cannot find special net default for attribute -shield\_net To reset an attribute to its default value specify the value "default" with some exceptions (see below).

#### For example:

\tset route attributes -nets netName -route rule default

\tset route attributes -net netName -preferred extra space default

#### Exceptions:

1. The option -shield\_net has a default of "none" which may cause confusion. So for -shield\_net you must specify "none" to return it to its default value:

\tset route attributes -net netName -shield net none

- 2. You have a net with -top\_preferred\_routing\_layer set to 7 and -bottom\_preferred\_routing\_layer set to 6. You cannot reset -top\_preferred\_routing\_layer first because its default value is 1 and the top preferred layer is not allowed to be less than or equal to the bottom preferred layer. You need to reset the bottom preferred layer first.
- 3. You cannot reset the non-default rule (NDR) on a routed wire. You must first delete the routing for the wire then re-route it after changing its rule.

## **NRDB-609**

#### NAME

**NRDB-609** 

#### SUMMARY

Cannot set attribute %s to %s on a net, since the value is not valid for this attribute. Specify a valid value and then retry.

#### DESCRIPTION

Net attributes cannot accept an arbitrary value. Each net attribute has a set of acceptable values. Type set\_route\_attributes -help for detailed information.

#### NAME

**NRDB-628** 

#### **SUMMARY**

Found non-default rules %s and %s in %s %s. Currently, only one default rule is supported on a net. Correct this configuration to ontinue .

#### DESCRIPTION

Non-default rule (NDR) is applied to nets using set\_route\_attributes -nets netName -route\_rule <ruleName>. You cannot have multiple non-default rule on a single net which need to be routed.

A non-default rule can be modified on a net using update\_route\_rule as long as the net is not routed. An error is reported if you try to modify a NONDEFAULTRULE of a routed net.

For example,

In order to change the non-default rule of a routed net you must delete the routing of the net, change the rule, then re-route the net.

Ex:

delete routes -net netName

set route attributes -nets netName -route rule newRule

set\_db route\_design\_selected net only true

select\_net netName

route design

If you have partially prerouted portions of the net, these sections must be defined as special nets. Use the command convert\_routes\_to\_special to convert these prerouted portions to special nets:

convert routes to special -nets netName

One exception to the above is if a net is already routed, you can use edit\_update\_route\_rule to change the non-default rule applied to the wire segments of the net. edit\_update\_route\_rule does not change the non-default rule attribute of the net, so if the net is re-routed or ECO routed, it will be routed with the widths and spacings of the original non-default rule applied to it.

Error and Warning Messages

edit\_update\_route\_rule should only be used if you don't intend to do any more routing. Example: edit\_update\_route\_rule -net netName -from rule1 -to rule2

# **NRDB-629**

#### **NAME**

**NRDB-629** 

### **SUMMARY**

NanoRoute cannot route PIN %s of INST %s for NET %s. The PIN does not have physical geometries. NR will ignore the PIN as if it does not exist in the NET. To fix the problem, add physical geometries to the PIN in the library.

#### DESCRIPTION

NanoRoute cannot route a PIN if it does not have physical geometries. Make sure the PIN of the corresponding MACRO has geometries defined.

For example:

```
EG:
```

\t\tPORT

```
MACRO < CELL_NAME>
\tCLASS CORE;
\tORIGIN 0 0;
\tSIZE < n.nn> BY < n.nn>;
\tSYMMETRY X Y;
\tSITE < site_name>;
\tPIN < pin_name>
\t\tDIRECTION INOUT;
\t\tUSE POWER;
```

Error and Warning Messages

\t\t\LAYER <\tayer>;
\t\t\tRECT <\tr>
\t\t\tRECT <\tr>
\t\tEND

# **NRDB-631**

#### NAME

**NRDB-631** 

#### **SUMMARY**

%s %s has more than one top-level logical pin which has no physical port (pin geometries) or has not been placed. Correct the pins before continue.

#### **DESCRIPTION**

A top level-pin is logical if it's not placed or it has no physical port (pin geometries. If a net has more than one such logical pin, NanoRoute will not route the design but error out. Create a physical pin geometries to such nets

# **NRDB-676**

### NAME

**NRDB-676** 

### **SUMMARY**

NET %s is marked as fully routed but NanoRoute detects that PIN %s of INST %s is not connected to the net.

### **DESCRIPTION**

Error and Warning Messages

Each net has a set of flags to indicate its statuses. One of them is a flag to indicate if a net is fully routed. If this flag says a net is fully routed, but NanoRoute traverses every pin in the net and finds some pin is not connected to the net, this warning will be issued.

This issue could happen when a tie-net pin is tied to the special net by special vias/wires. The flag is set based on regular routing information, and it is possible that the pin does not exist in the regular routing information imported from reference DB. NanoRoute is aware of this mismatch issue, and performs a integrity check to detect it.

To fix the issue, check the warning pin if it is covered by STRIPE metal and connected by special vias. You can delete the special vias and set option setAddStripeMode to skip dropping via on this type of pins. Please reference command manual of setAddStripeMode and add\_stripes. The severity of this warning is not high.

# **NRDB-682**

#### NAME

**NRDB-682** 

#### SUMMARY

Connectivity is broken at PIN %s of INST %s connects to NET %s at location %s on LAYER %s. The location is not inside the pin geometry extraction.

#### **DESCRIPTION**

This could be due to moved wires or cells from design optimization.

If the user edited wires or if opt\_design move cells the connectivity may be broken and need rerouting.

NanoRoute is capable of removing the problematic wires and reroute the PIN correctly.

If the wires are FIXED, you need to unfix them manually before routing.

#### NAME

**NRDB-728** 

#### **SUMMARY**

%s %s in %s %s does not have antenna diff area.

#### **DESCRIPTION**

This warning is reported when antenna fixing is enabled (set\_db route\_design\_detail\_fix\_antenna true) and an output or bi-directional pin is missing a value for AntennaDiffArea in the LEF. AntennaDiffArea defines the diffusion area for this pin. This value is then used when calculating the Process Antenna Effects (PAE) on the net connected to this pin. AntennaDiffArea defines the diffusion area connected to a net. Diffusion discharges a net and lessens the process antenna effect. If AntennaDiffArea is not defined then NanoRoute may perform unnecessary antenna fixing using layer hopping and diode insertion which would not be needed if AntennaDiffArea was properly defined for the pin.

If AntennaGateArea is not defined for input pins in LEF then it shows the warning for antenna gate area.

In a summary if you simply want to stop this warning you can add ANTENNAGATEAREA 0; to the input pin. While 0 is the default value if no statement is given, there is a difference between default, and "the gate area is really 0". Same as for output pin. Put ANTENNADIFFAREA 0; for LEF output pins without any diff area. In case of inout pin you have to add both ANTENNAGATEAREA and ANTENNADIFFAREA to 0.

# **NRDB-733**

#### **NAME**

**NRDB-733** 

#### SUMMARY

%s %s in %s %s does not have physical port.

#### **DESCRIPTION**

This warning indicates this pin does not have a physical shape defined properly in the LEF for MACRO or PAD cells.

The possible causes are:

- The pin does not have a RECT or POLY statement in the LEF to define its geometry.
- Another reason is the pin may be defined as USE POWER or GROUND. NanoRoute does not route power pins.

For example:

MACRO INVXL

...

PIN A

**DIRECTION INPUT;** 

USE POWER;

**PORT** 

LAYER metal6;

RECT 104.000 1549.940 104.800 1553.420; # Physical definition of pin END A If a pin defined as a power or ground pin, and has SHAPE ABUTMENT or FEEDTHRU defined for it, then NanoRoute will treat the pin as a physical obstruction. If the power/ground pin is missing the SHAPE attribute then NanoRoute treats it as a logical pin and will report these warnings.

# **NRDB-741**

#### NAME

**NRDB-741** 

Error and Warning Messages

#### SUMMARY

Found shorts between two different ports on pin %s of cell\_view %s. Loop detection and weak connectivity checking will be skipped for this pin. If loop is not an issue, you can disregard this message. Otherwise, pin geometries need to be corrected.

#### DESCRIPTION

This warning is issued when the geometries defined in separate PORT statements for a PIN in the LEF short together or create a loop.

When a PIN has multiple PORT statements it means the geometries within each PORT statement are weakly connected. So they typically should not overlap or touch. If they touch they are considered strongly connected and should be within the same PORT statement.

NanoRoute runs special checks to avoid loops. When it encounters geometries in different PORT statements which short together, it will disable this loop checking for this pin and issue the warning above. You should review the PIN definition in the LEF and correct it as needed.

For example the pin below has 4 PORT statements which create a loop:

PIN A
DIRECTION INPUT;
PORT
LAYER Metal1;
RECT 0 0 10 1;
END
PORT
LAYER Metal1;
RECT 0 0 1 10;
END
FND A

#### NAME

**NRDB-778** 

#### **SUMMARY**

No multicut vias which meet all area rules for LAYER %s are defined in RULE %s. When a LEF MINIMUMCUT rule is defined for a layer, you must define multicut vias for the layer in the LEF file. Edit your LEF file and read it in again.

### **DESCRIPTION**

When a LEF MINIMUMCUT rule is defined for a layer, you must define multicut vias for the layer in the LEF file

For example,

The following minimum cut rule indicates that vias with 2 cuts are required,

PROPERTY LEF58 MINIMUMCUT

"MINIMUMCUT 2 WIDTH 0.09 WITHIN 0.05 AREA 2.0;";

## **NRDB-855**

### **NAME**

**NRDB-855** 

### **SUMMARY**

Illegal wire segment on NET %s near %s on LAYER %s. The shape is off %s manufacturing grid (%s), and must be corrected. Change the shape from FIXED to ROUTED status to allow NanoRoute to correct the issue.

#### DESCRIPTION

If a design has illegal wires/vias that are off manufacturing grid, Routing will delete the segments to correct the issue for sign-off verification. If they are of status "FIXED" NanoRoute can not change the segments. Please correct or remove the shapes or change their status to ROUTED so NanoRoute can correct the issue.

# **NRDB-874**

#### NAME

**NRDB-874** 

#### SUMMARY

There %s %d dangling wire%s/via%s in the fully routed NET %s. NanoRoute will correct the dangling wires/vias that are not of FIXED status.

### **DESCRIPTION**

A dangling wire has one or more endpoints that are not connected to pins or other wires.

NanoRoute will check if there are any dangling wires that are not FIXED in the net if a net has been touched.

Common scenarios that introduce the dangling wires are:

- \t1) Some instances are IPOed, but wires are marked FIXED
- \t2) The nets are eco-routed, and some of the FIXED wires become dangling
- \t3) Some wires status are changed and the design rerouted.

Note The wires in the frozen layers will not be deleted since the layers are locked.

The warning is given for informational purposes.

#### NAME

**NRDB-897** 

#### **SUMMARY**

The same MINSTEP ... MAXEDGES ... MINBETWEENLENGTH ... rule is specified more than once for layer %s.

### **DESCRIPTION**

{DETAILMESSAGE]

# **NRDB-898**

### **NAME**

**NRDB-898** 

### **SUMMARY**

More than one MINSTEP ... MAXEDGES ... MINADJACENTLENGTH (MINBETWEENLENGTH) ... rule are specified for layer %s.

### **DESCRIPTION**

{DETAILMESSAGE]

#### NAME

**NRDB-899** 

### **SUMMARY**

More than one MINSTEP ... MAXEDGES 0 rule are specified, MINSTEP s% MAXEDGES 0 will be used for layer %s.

### **DESCRIPTION**

{DETAILMESSAGE]

# **NRDB-900**

### **NAME**

**NRDB-900** 

### **SUMMARY**

The same MINSTEP s% MAXEDGES 1 rule is specified more than once for layer %s

### **DESCRIPTION**

{DETAILMESSAGE]

### NAME

**NRDB-912** 

#### **SUMMARY**

Internal error. Report this to Cadence. Pin (%f %f) of layer %d from net %s does not have boundary access in route region (%f %f %f). The net is now set as open net. You can try to delete this net and re-do the routing to see if this problem can be avoided with a different routing pattern.

### **DESCRIPTION**

There is an internal error from the software or the data base and the net will be set to open.

If you receive this message, download and install the latest software version from http://downloads.cadence.com. If the warning still occurs, please open a case through http://support.cadence.com so the cause can be determined.

This message should not be ignored. To save a test case for Cadence use:

\tsaveTestCase -name NRDB-912

As a workaround you can try deleting the net and re-routing it.

\tdelete routes -nets netName

\tselect net netName

\tset db route design selected net only true

\troute design

\tset db route design selected net only false

# **NRDB-944**

#### NAME

**NRDB-944** 

### **SUMMARY**

The cut shape in VIA %s doesn't match any predefined cut dimension. Only the cuts that are defined in CUTCLASS can be used in VIA definition. %s

#### **DESCRIPTION**

This error occurs when Nanoroute finds a VIA definition which does not meet the defined CUTCLASS definitions.

To avoid the error you must either;

- 1) Define a new CUTCLASS for this via,
- 2) Remove the via
- 3) Edit the via cut size to match one of the cut classes.

## **NRDB-954**

### **NAME**

**NRDB-954** 

#### **SUMMARY**

Invalid option value route\_design\_top\_routing\_layer %d. It is in conflict with already existing routed wires on layer %d. The option must specify a layer equal to or above the top-most layer for existing routes.

### DESCRIPTION

Pre-routed wires are not allowed above the route design top routing layer limit.

Please change the layer limit or remove the wires.

Alternatively you can relax the hard limit and add a preferred layer to all nets with set route attributes.

#### NAME

**NRDB-955** 

#### **SUMMARY**

Invalid option value route\_design\_bottom\_routing\_layer %d. It is in conflict with already existing routed wires on layer %d. The option must specify a layer equal to or below the bottom-most layer for existing routes.

### **DESCRIPTION**

The design has pre existing routed or custom routed nets with a layer below the bottom routing layer set for detail route.

- 1) You can set all nets to prefer to stay off the layer
- 2) You can set "skip\_routing" attribute on nets which are routed below your Bottom layer.
- 3) If you dont want routing below a certain layer you may want to delete the wires on those layers and let the router complete using the layer range requested.
- 4) Allow the the lower layer for the routing range.

For example,

set\_route\_attributes -net <net\_name> -skip\_routing true

# **NRDB-965**

### **NAME**

**NRDB-965** 

#### SUMMARY

VIA GROUP %s in rule %s doesn't match any predefined via group. Only the via group that are

Error and Warning Messages

defined in VIAGROUP can be used. %s

#### DESCRIPTION

This error occurs when Nanoroute finds a VIAGROUP definition which does not meet the defined CUTCLASS definitions.

To avoid the error you must either;

- 1) Define a new VIAGROUP for this group,
- 2) Remove the rule
- 3) Edit the via group name to match one of the via group.

# **NRDB-976**

#### NAME

**NRDB-976** 

#### **SUMMARY**

The TRACK STEP %.4f for preferred direction tracks is smaller than the PITCH %.4f for %s %s. This will cause routability problems for NanoRoute.

#### **DESCRIPTION**

If track resolution is too fine and results in lots of tracks, it will affect routing runtime. Also, if adjacent tracks cannot satisfy PICTH requirement, spacing violations cannot be prevented naturally, causing more DRC.

The issue is usually caused by a DEF file loaded by read\_def. To fix the issue, use generateTracks in Innovus or modify tracks in the DEF file.

#### NAME

NRDB-1007

#### **SUMMARY**

Design has advanced design rules which require the Advanced Node license. NanoRoute failed to check out a Advanced Node license.

### **DESCRIPTION**

DRC rules for 32 and below process nodes require the Advanced Node (encan) license. A encan license must be checked out if these rules exist in the library. Every major NanoRoute command will try to check out a encan license, unless a previous command has checked it out already. If fails, NanoRoute will stop.

The failure may happen when no Advanced Node license is installed on site, or all licenses are used up by other people.

## NRDB-2005

#### NAME

NRDB-2005

### **SUMMARY**

%s %s has special wires but no definitions for instance pins or top level pins. This will cause routability problems later.

### **DESCRIPTION**

The router will flag false violations between unconnected pins and the special net wires, please ensure that all pins are connected to their special net wires.

#### NAME

NRDB-2016

### **SUMMARY**

VIA %s will be corrected in routing as it is same as VIA %s.

### **DESCRIPTION**

This warning is issued by the generated routing vias flow either by NanoRoute or write\_via\_defs, if an NDR generated via geometry matches an existing via, the NDR will reuse the default rule via. The generated via will be removed as it is same as the default via and a warning is issued to inform the user.

# NRDB-2026

### **NAME**

NRDB-2026

#### **SUMMARY**

Design has top and bottom routing layers as %s %s, Some nets in the design have top and bottom preferred routing layer as %s %s. Top and bottom preferred routing layers should be within top and bottom routing layer range. Fix this before continuing.

### DESCRIPTION

Design has top and bottom routing layers, some nets in the design have top and bottom preferred routing layer and the preferred routing layer effort is medium or high. Top and bottom preferred routing layers of a net should be within top and bottom routing layer range.

Error and Warning Messages

For example, if design has top routing layer as M7, then preferred routing layer on a net can be M7 or lower layers but not M8:

set\_db design\_top\_routing\_layer 7

set\_route\_attributes -net net1 -top\_preferred\_routing\_layer 7 -bottom\_preferred\_routing\_layer 6

## NRDB-2040

#### **NAME**

NRDB-2040

### **SUMMARY**

Rule %s doesn't specify any vias that satisfy all of the area rules for layer %s

#### **DESCRIPTION**

Modern processes require each piece of metal to have a minimum area. This is defined in the LEF LAYER definition using the AREA keyword. For example:

LAYER M2

...

AREA 0.5;

...

END M2

It's important you have at least one via definition whose bottom metal layer meets the minimum area rule. Otherwise, NanoRoute cannot meet the minimum area rule when stacking vias. For example:

#The M2 rectangle for the following via is not large enough to meet the minimum area rule. It's area is 0.7 \* 0.7 = 0.49 which is less than 0.5.

VIA VIA23 DEFAULT

LAYER M2:

RECT -0.35 -0.35 0.35 0.35;

LAYER CUT23;

Error and Warning Messages

RECT -0.25 -0.25 0.25 0.25;

LAYER M3;

RECT -0.35 -0.35 0.35 0.35;

**END VIA23** 

#The M2 rectangle for the following via does meet the minimum area rule. It's area is 0.9 \* 0.7 = 0.63 which is greater than 0.5.

VIA VIA23 v DEFAULT

LAYER M2;

RECT -0.35 -0.45 0.35 0.45;

LAYER CUT23;

RECT -0.25 -0.25 0.25 0.25;

LAYER M3;

RECT -0.45 -0.35 0.45 0.35;

**END VIA23** 

Note not all vias need to meet the minimum area rule but you must have at least one or else the NRDB-2040 warning is issued and you will likely have a lot of minimum area violations when NanoRoute completes.

# **NRDB-2048**

#### NAME

NRDB-2048

### **SUMMARY**

More than one MINSTEP...MAXEDGES 1 NOADJACENTEOL... rules are defined for %s %s. Keep the first one.

#### DESCRIPTION

{DETAILMESSAGE]

#### NAME

NRDB-2050

### **SUMMARY**

More than one MINSTEP...MAXEDGES 1 NOBETWEENEOL... rules are defined for %s %s. Keep the first one.

#### **DESCRIPTION**

{DETAILMESSAGE]

# NRDB-2062

#### **NAME**

NRDB-2062

### **SUMMARY**

Net %s is fully connected and it has off-grid wires/vias. NanoRoute will set it as skip\_routing and ignore it during routing/verifying

### **DESCRIPTION**

This Warning is triggered by inconsistent usage of, set\_db route\_design\_detail\_on\_grid\_only {wire layer:layer} set db route design detail on grid only {via layer:layer}

Error and Warning Messages

NR would mark the input full routed nets as 'skip\_routing' true if there are any wires/via off-grid for the option check - set\_db route\_design\_detail\_on\_grid\_only {wire Mx:My via Vx:Vy}

For example,

If you route the clock nets without on-grid constraint, and then using below setting for data net routing or ECO routing in the flow, you will get this warning message.

set\_db route\_design\_selected\_net\_only true
set\_db route\_design\_detail\_on\_grid\_only {wire 2:6 via 3:6}

# NRDB-2081

#### NAME

NRDB-2081

#### SUMMARY

INST %s of CELL %s may not have on-grid via access.

#### DESCRIPTION

If the metal pins of this instance are off-grid, NanoRoute may not be able to drop on-grid via to access those PINs with "set db route design detail on grid only true

# NRDB-2085

### NAME

NRDB-2085

#### SUMMARY

Pin access impeded near Instance %s and Instance %s. Please inspect the area near the pin for any obstacle.

#### **DESCRIPTION**

This pin may be difficult to access and cost extra runtime, impact timing, and fail to route cleanly.

Please inspect the area near the pin for

- 1) Power routing near pin
- 2) Obstruction near pin
- 3) Pins near this pin
- 4) Overlapping instances and pins

# **NRDB-2106**

### NAME

NRDB-2106

#### SUMMARY

Ignoring layer %s MINIMUMCUT rule with WIDTH (%f) <= the layer's MINWIDTH (%f).

#### **DESCRIPTION**

The MINIMUMCUT rule is applied only to wide wires greater than the specified width. To force multi-cut vias globally on narrrow wires, use the following mode setting to restrict the usage of a particular cut via:

\t\tset db route design db via weight "<via name prefix>\*" -1

#### NAME

NRDB-2111

#### **SUMMARY**

Found overlapping instances %s %s. This may result in unnecessary runtime, added violations, timing issues, and fail sign-off verification. Run check\_place to display the placement violations and use route design -placementCheck to prevent routing which placement issues.

### **DESCRIPTION**

The design has overlapping cells. This is not always a disaster but can have undetected substraight violations as well as overlapping instance pins. The router will work diligently but not be able to resolve violations when routing to overlapping pins. You should not continue with placement violations. Please run check\_place and inspect the design visually and resolve all placement issues before proceeding to routing.

For example:

route design -placementCheck # fix any placement issues route design -placementCheck

or

check\_place # fix any placement issues

route design

# NRDR-4

#### NAME

NRDR-4

### **SUMMARY**

Error and Warning Messages

Turning off power domain constraint for %s %s in region %s to avoid creating open net. Please check the power domain specification for the given net.

#### **DESCRIPTION**

set\_db route\_design\_honor\_power\_domain true With this option set, if a net connects to pins belonging to the same power domain, NanoRoute tries to route this net within that power domain. If this is not possible, NanoRoute completes the routing and issues the above warning to alert the user to check the routing of the listed nets.

# NRDR-12

#### NAME

NRDR-12

### **SUMMARY**

The width of LAYER %s in RULE %s is not defined. Define the missing width before proceeding.

### **DESCRIPTION**

In some cases, some NONDEFAULTRULEs may be incomplete, and some layers are missing in the rule. Those non-default rules may be from manually crafted scripts or third-party tools. Make sure all layers are well defined in the non-default rule.

## NRDR-13

### NAME

NRDR-13

### **SUMMARY**

Some nets are not global routed. Detail routing cannot be run.

#### DESCRIPTION

The above warnings can be seen during route\_detail for nets which are already routed and check\_connectivity shows no opens but they have a FIXED segment and a trunk routing net attribute.

NanoRoute does not support trunk routing for nets with FIXED wires. Changing the pre routed segment to ROUTED or removing the nets trunk routing attribute or deleting the pre route will solve the issue.

You may also be limiting the layer rang during an ECO route such that the route can not be completed. Check the range of Bottom, Top limits and -route only layers option.

For example,

select net FOOBAR/FECTS CLONE N7

check\_connectivity -selected

Found no problems or warnings.

Solution example:

select\_net FECTS\_CLONE\_N7

set db route design selected net only true

select routes -nets FECTS CLONE N7

select vias -nets FECTS CLONE N7

edit update route status -to ROUTED

## NRDR-30

#### NAME

NRDR-30

#### SUMMARY

Detail routing is stopped due to too many DRC violations.

### **DESCRIPTION**

Error and Warning Messages

This warning occurs when NanoRoute sees an abnormal number of DRC violations during initial routing. It issues this warning and then stops so you can debug the violations to determine their cause. To override this automatic stop you can set the drouteAutoStop option to false

Note: Since this can add significant run time you should only override this setting when you're confident. NanoRoute will be able to resolve the violations and you have investigate the initial violations and are pursuing remedies to the violation.

set\_db route\_design\_detail\_auto\_stop false

There are several reasons NanoRoute may initial violations and stop:

- 1) Congestion Review the global route congestion map to identify hot spots visually and reduce the congestion in this area by reducing the placement density using partial placement blockages or modifying the floorplan.
- 2) Pin access problems Are the majority of violations on M1 and M2? If so, this can indicate pin access problems on standard cell pins or a Tracking problem, or a power rail issue. Review the violations at these pins and determine why they are occurring. For example, blockage is too close to the pin, pin is off the routing track or a proper via is not defined which can be dropped to the pin.
- 3) Pins under power stripes Are the violations occurring when trying to route to standard cells placed under stripes? If so, use setPrerouteAsObs to treat these stripes as placement blockages. For example, the following treats strips on M1, M2 and M3 as placement blockages:

setPrerouteAsObs {1 2 3}

If you standard cells pin on M2 being placed under M3 stripes you can set the following instead. This will avoid placing M2 pins under M3 stripes but allow M1 standard cell pins to be place under the M3 stripes:

setPlaceMode -checkPinLayerForAccess { 1 2 }

- 4) Routing layers too limited Make sure you have not set the max routing layer too low.
- 5) Other library or design issues Review warnings at the beginning of the NanoRoute run which may indicate problems

## **NRDR-123**

### **NAME**

**NRDR-123** 

Error and Warning Messages

#### **SUMMARY**

Some nets are not detail routed. Post-route operations (via\_swapping, minimize detour, wire widening, spreading, or matching) cannot be done. If possible, normal detail routing will be done.

#### **DESCRIPTION**

Post-route operations cannot be performed unless all the signal nets are completely routed. Disable post-route options and then route the remaining nets using the route\_design or route\_eco command. Only use route\_eco if less than 10% of the signal nets are unrouted. Once all the nets are routed you can then run post-route operations. The unrouted net can also be skipped using the net attribute setting if there is some reason it is to remain incomplete.

# **NRDR-126**

#### NAME

**NRDR-126** 

### **SUMMARY**

Post-routing optimization is disabled because of too many DRC violations

#### **DESCRIPTION**

This warning occurs when NanoRoute sees too many violations in the post routing optimization stage. To avoid this warning and force NanoRoute to continue "set\_db route\_design\_detail\_auto\_stop false" before routing.

Note: You should only override this setting when you're confident NanoRoute will be able to resolve the violations. Otherwise, review the violations to determine the cause. It can be due to congestion, pin access problems, bad design rules, improper via definitions, track missalignment etc. Ignoring the violations causing the auto stop can lead to long runtime, timing problems, and the routing may not complete.

# **NRDR-129**

#### NAME

**NRDR-129** 

#### **SUMMARY**

Cannot do post-route optimization (minimize detour, wire widening, spreading, or matching) using command '%s', use 'route detail' command instead. If possible, normal detail routing will be done.

### **DESCRIPTION**

Generally, you get this warning message when you do incremental route\_global\_detail and don't reset post-route wire optimization options. When post-route wire optimization is being run (i.e. wire widening, spreading) you should set the appropriate "set\_db route\_design\_detail\_post\_route\_\*" options then run route\_detail or route\_design -wireOpt. If you run route\_global\_detail or just route\_design this warning will be reported.

## **NRDR-175**

#### NAME

**NRDR-175** 

### **SUMMARY**

Routing must start from drouteStartIteration 0 when the routing state is unknown or external routing is imported.

### **DESCRIPTION**

Iterations can be separated 0,1,2,3,4, but you are not allowed to use any other command that will change the design routing unless you start from iteration 0 for the next route detail command.

For example,

Error and Warning Messages

```
globalRoute

write_db groute

set_db route_design_detail_end_iteration 0

route_detail

write_db droute_0

setNanoRouteMode -drouteStartIteration 1

set_db route_design_detail_end_iteration 1

route_detail

write_db droute_1

# If the users modifies teh clock net or introduced other pre routes the iteration must be returned to 0

# For large changes starting from globalroute is recommended..

setNanoRouteMode -drouteStartIteration 0

set db route design detail end iteration default
```

## **NRDR-240**

#### NAME

**NRDR-240** 

route detail

#### SUMMARY

Deleting shielding during routing and optimization.

### DESCRIPTION

Shielding will be temporarily removed during routing and routing optimization commands, eg. via swapping, wire widening, wire spreading, and then the nets will be re-shielded after the operation.

To keep the shielding users can set the shielded net to be fixed or its attribute to skip routing however the shielding may interfere with the success of the ECO route or optimization requested. In some cases the ECO can fail if the resources are insufficient so it is recommended to allow the

methodology to remove and re add the shielding automatically.

## **NRDR-328**

### **NAME**

NRDR-328

#### SUMMARY

Some nets are not detail routed. route\_fix\_signoff\_drc command to fix signoff DRC violation cannot be done.

## **DESCRIPTION**

Signoff DRC violation fixing cannot be performed unless all the signal nets are completely routed. Perform detail route first to route all nets using route\_design command. Once all the nets are routed you can then run route\_fix\_signoff\_drc. The unrouted net can also be skipped using the net attribute setting if there is some reason it is to remain incomplete.

## NRDR-334

### **NAME**

NRDR-334

## **SUMMARY**

Unable to run 'route\_eco -target' command because insufficient eco routing information is available. Regular 'route\_eco' command will be executed instead.

#### DESCRIPTION

One possible reason that can cause this is when a fully routed design from DEF file is imported. The design must be loaded from a saved DB (from the original routing step) before 'route\_eco -

target' command can be executed.

## NREX-32

#### NAME

NREX-32

#### **SUMMARY**

The dielectric layer has wrong RANGE values 'RANGE %If %If'. It should start from high value of %f.

### **DESCRIPTION**

The range value error may be due to a resolution mismatch between the routing technology file and the dielectric layers in the PCS file.

For example, if the LEF Database unit value is 1000, then all values in the PCS file should be rounded to the nearest 0.001. In the PCS file.

## NRFL-215

## **NAME**

NRFL-215

### **SUMMARY**

DATBASE UNIT is not set in the first technology file. Using 1000 DATABASE UNITS per MICRON.

## **DESCRIPTION**

DATBASE UNIT is not set in the first technology file.

The DATBASE UNIT will be set to 1000 DATABASE UNITS per MICRON

Error and Warning Messages

This can occur when the manufacturing grid is defined prior to the units in the technology LEF file.

For example:

\tMANUFACTURINGGRID 0.005;

\t\tUNITS

\t\tDATABASE MICRONS 2000;

**\tEND UNITS** 

To fix the above issue, In the LEF file you must specify the statements in the following order:

\tUNITS

\t\tDATABASE MICRONS 2000;

**\tEND UNITS** 

\tMANUFACTURINGGRID 0.005;

## NRFL-217

## **NAME**

NRFL-217

#### **SUMMARY**

Too many table entries (> %d). Please check the table with line %s in file

### **DESCRIPTION**

This message means the table at the specified line has two many values. This can occur for example with AntennaDiffAreaRatio that are defined with Piece-Wise Linear (PWL) functions. In this example the PWL table might contain more than 100 lines which is the limit. To resolve this issue, values must be removed to reduce the number to be less than 100.

# **NRFL-374**

### NAME

NRFL-374

#### SUMMARY

%sSpacing table is not monotonically increasing. Layer %s spacing table entry %f is less than the previous entry %f.

### **DESCRIPTION**

This error can occur when the spacing rules in the technology file are not increasing in order.

Spacing needs to increase like 1,2,3,4,5 not 1,2,4,3,5.

Please check the spacing table values in the technology file.

## NRGR-21

#### NAME

NRGR-21

#### SUMMARY

Selected nets are already detail routed or no nets are selected.

### **DESCRIPTION**

Routing with set\_db route\_design\_selected\_net\_only true or selecting route selected nets from the GUI will route only the selected nets. If no nets are selected, NanoRoute can not route and will issues this warning message.

This can happen if selected nets were routed and the design was then saved before setting the above mode to false.

Error and Warning Messages

see get db route design selected net only

To route, either select unrouted nets or set set\_db route\_design\_selected\_net\_only false.

## NRGR-59

#### NAME

NRGR-59

### **SUMMARY**

Pin %s of instance %s (cell %s) is not accessible. NanoRoute will continue but the pin is not accessible and will result in an open net. To correct this problem please check the manufacturing grid, placement and pin shape.

### DESCRIPTION

The pin was drawn using a different manufacturing grid from the one defined in the LEF technology file.

Please check the pin shape and the technology files database units and manufacturing grid to make sure the pin shape can be describe or that the technology is set to the correct resolution for the foundry.

DATABASE MICRONS 1000;

MANUFACTURINGGRID 0.005;

## **NRGR-145**

#### NAME

**NRGR-145** 

#### **SUMMARY**

Gcell grid area %s does not cover inst("%s") pin("%s") @ %s.

Error and Warning Messages

#### DESCRIPTION

Tracks and Gcells must cover the design. If data was read in with incomplete Gcell or Track definitions the design will not be routable.

Please fix the imported data or use generateTracks to rebuild the definitions for this design.

For example:

generateTracks

# **NRGR-164**

#### NAME

NRGR-164

#### **SUMMARY**

This design is over congested and will have routability problem. Correct the placement to fix congestion problem.

### DESCRIPTION

You can check the globalRoute congestion map to find the congested areas. If the congested areas are all over the design, you may redo the floorplan. If the floorplan cannot be resized, check if the routing track can be optimized on the congested layer from the Congestion Analysis Table shown in log. If the congested areas are located in some small area which we called hotspot, you may optimized the placement.

# **NRGR-190**

### **NAME**

**NRGR-190** 

#### **SUMMARY**

Cannot find routing solution for net %s within bus guide. The net will be open. This problem may be caused by discontinuous bus guide path. Bus Guides need to contain a path from pin to pin defined by a group of 3-D guiding rectangles. Check the continuity of the layers and rectangles between the set of pins of the net to be guided.

#### **DESCRIPTION**

This message is reported when bus guides are not continuous in guiding the nets path.

- \t1. The bus guide should be continuous overlapping layers and rectangular shapes
- \t2. The bus guide should overlap driver and receiver pins completely
- \t3. The bus guides should follow the preferred routing direction.
- \t4. The top and bottom routing layer of "set\_db" should cover the specified bus guide layers.

For example:

create\_bus\_guide -netGroup my\_grp \
-centerLine 492.365 1174.930 492.365 1276.975 \ -width 1.000 -layer 3:3
set\_db route\_design\_top\_routing\_layer 4 set\_db route\_design\_bottom\_routing\_layer 0
route\_design

## **NRGR-228**

#### NAME

NRGR-228

#### **SUMMARY**

The net %s has can not be routed. Fixed wire and routePGPinSignalRoute is not sported with ecoroute.

### **DESCRIPTION**

Error and Warning Messages

NanoRoute issues the warning above when user requests eco routing on secondary power/ground pins using routePGPinSignalRoute that have fixed net segments.

For example:

Below commands will change the status of a net and its vias to routed. See the example below:

select\_routes -type Signal -nets VDD

select vias -nets VDD

edit\_update\_route\_status -to ROUTED

# **NRGR-261**

### NAME

**NRGR-261** 

#### **SUMMARY**

Internal error with Global Route Setup up. Report to Cadence representative.

#### DESCRIPTION

This message is reported when the gcell size is larger than the variables which store the hcell x and y index.

\t1.

## NRIG-34

#### NAME

NRIG-34

## **SUMMARY**

Power/Ground pin %s of instance %s is not connected to any power/ground net. Use command

Error and Warning Messages

connect global net to connect the power/ground pin to a power/ground net.

#### DESCRIPTION

The instance has pins defined with USE POWER or USE GROUND in the LEF But the pins do not have a net associated for connectivity. Check the power and ground pins for this instance and verify you have specified a connect\_global\_net command to connect them.

If you do not want the pins connected, you can ignore this warning.

If the instanceName is PIN this means an IO power pin on the block does not have a net specified.

## NRIG-43

#### NAME

NRIG-43

### **SUMMARY**

Cannot have special via %s at location %s in signal net %s. Removing routing segment for %s %s.

### DESCRIPTION

If add\_route\_via\_defs was used the vias are stored in the DEF and imported but may not be sufficent without either LEF vias or regenerating a full via set.

To resolve this issues please use: set\_db add\_route\_vias\_auto true

Setting the above command before importing the design will save the variable in the .mode file.

If you have a third party DEF, it's recommended that you import the design into innovus, set the above variable and save the DB from innovus and exit. Now again open a new Innovus session and restore the saved innovus DB.

## NRIG-74

### NAME

NRIG-74

### **SUMMARY**

Found pre-routed non default rules %s and %s in %s %s. Currently only one non default rule is supported. Net will be skipped and may be open. Enable set\_db route design detail use lef pin taper rule to allow pin taper rules.

### **DESCRIPTION**

When such nets are hand routed with two NDR's and the connecting instance got moved or buffer is added during the course of timing eco at postroute stage, By default nanoRoute does not support more than one NDR, so the Net will be skipped and the net attribute set to avoid routing. Use set\_route\_attributes -net %d skip\_routing false for NanoRoute to check and route the net next time.

Please change the Net to use a single NDR and then reset the skip attribute on the net and reroute or re-ecoRoute to resolve open nets.

For example, to convert two NDR to an single NDR and reset skip route on such nets and then do route eco

convert\_routes\_to\_special \$net1
set\_route\_attributes -net \$net1 -non\_default\_rule NDR1
convert\_special\_to\_routes \$net1
set\_route\_attributes -net \$net1 skip\_routing false
set\_db route\_design\_with\_eco true
route\_eco
check\_connectivity -net \$net

## NRIG-77

#### NAME

NRIG-77

### **SUMMARY**

Found placement violations. Please investigate and correct before routing. Routing with placement violations can cause long runtime and may be irresolvable. Use route\_design -placement\_check to stop on violations. Use route\_design -no\_placement\_check to skip the check.

### **DESCRIPTION**

The message is reported to alert user that the design has placement violations like cell overlaps, pin access issues etc...

Run check place to catch the violations and fix them before routing

# NRIG-96

### NAME

NRIG-96

### **SUMMARY**

Selected single pass global detail route "-global\_detail". Clock eco and post optimizations will not be run. See "man NRIG-96" for more details.

#### **DESCRIPTION**

Use option "-global\_detail" to run multiple iterations of routing with user specified net selections and routing options. The following examples will mimic pre-11.13 behavior.

To run pre-clock eco plus global detail route:

Error and Warning Messages

innovus 1> route design

Note that if high effort flow is enabled, post optimizations will be executed. If this is not desired, then disable the high effort flow:

innovus 1> set\_db design\_flow\_effort none

innovus 2> route design

To run post route optimizations in non high effort flows:

innovus 1> route\_design

innovus 2> route design -via opt -wire opt

# **NRIG-117**

### **NAME**

**NRIG-117** 

#### SUMMARY

Cannot have special via %s at location %s in signal net %s. This routing segment is fixed, so net will be skipped.

#### DESCRIPTION

If add\_route\_via\_defs was used the vias are stored in the DEF and imported but may not be sufficent without either LEF vias or regenerating a full via set.

To resolve this issues please use: set\_db add\_route\_vias\_auto true

Setting the above command before importing the design will save the variable in the .mode file.

If you have a third party DEF, it's recommended that you import the design into innovus, set the above variable and save the DB from innovus and exit. Now again open a new Innovus session and restore the saved innovus DB.

## NRTM-24

#### NAME

NRTM-24

### **SUMMARY**

Read error in timing file %s.

## **DESCRIPTION**

This message is reported when .tif file is corrupted or not fully generated.

Possible causes is truncated file due to disk space issue etc.

# **PRL-0389**

## **NAME**

PRL-0389

## **SUMMARY**

Could not create a new process for %s.

#### **DESCRIPTION**

fork cannot allocate sufficient memory to copy the parent's page tables and allocate a task structure for the child. Release more memory to rerun it. Or it was not possible to create a new process because the caller's RLIMIT\_NPROC resource limit was encountered. Terminate some processes to rerun it.

# **PRL-0390**

### NAME

PRL-0390

#### SUMMARY

Could not create a new process for %s.

## **DESCRIPTION**

fork failed to allocate the necessary kernel structures because memory is tight. Release more memory to rerun it.

## PTNASMD-90

### **NAME**

PTNASMD-90

## **SUMMARY**

Pin %s of abutted partition %s could not be assigned. Could not find a feasible slot for the pin. Create more feasible location before for pin assignment by inserting feedthrough buffers using add\_partition\_feedthrus command or allowing more layers for assigning pins or using set\_db assign\_pins\_strict\_abutment false or using set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true for relaxing this check.

## **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1 In abutted designs, pins of following type can not be placed on common edges between two

adjoining partitions.

.in +2

- A. Pins of net not connected to adjacent partition (fences of the two partitions being connected are not touching each other in create floorplan).
- B. Pins of nets having connections to two or more partitions any pin belonging to net of above type will have to route over an unconnected partition and result in illegal routing.

Feedthrough step is required to get rid of pins which connect non-adjacent partitions or multiple partitions, by changing netlist and making all pins connect to only one pin on adjacent partition to make the routing of net feasible/legal

C. Floating pins

.in

#2. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

- #3. Use set\_db assign\_pins\_strict\_abutment false to relax abutment violations checks for placing multi partition pin of a net, non neighbor pins of a net and floating pins on abutted edges.
- #4. Use set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true to relax abutment violations checks for placing floating pins on abutted edges.

#### Example:

-----

eg. if pins are not assigned for a net which has more than two partition pins to connect use add\_partition\_feedthrus command to change netlist to have new nets added and older net modified in way that, now nets only connect two pins of adjacent partitions only.

# PTNASMD-100

### NAME

PTNASMD-100

#### SUMMARY

The net %s is not connected to any terminal. This net will not be considered for feedthrough buffer insertion. Correct the netlist to get this net considered for feedthrough buffer insertion.

#### **DESCRIPTION**

An unconnected net will not be considered for feedthrough insertion. The net should be connected to an output port and an input port to be considered for feedthrough insertion.

## PTNASMD-233

### **NAME**

PTNASMD-233

## **SUMMARY**

No legal free slots available for %s of partition %s. Create additional slots using create\_partition command or by removing blockage before pin assignment.

## **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

Error and Warning Messages

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

## PTNASMD-426

### NAME

PTNASMD-426

#### SUMMARY

Adjusting partition %s core to left from %f to %f because specified core spacing value is not multiple of placement grid.

#### DESCRIPTION

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.



-----

<CMD> create\_partition -hinst uCORE/uPKTSS/uPKTSS\_PPCS\_PMA\_SYS -core\_spacing {2.7 2.7 1.9 1.9} -reserved\_layer {1 2 3 4 5 6 7 8} -route\_halo 1.9 -route\_halo\_top\_layer 7 - route\_halo\_bottom\_layer 1 -place\_halo {2.7 2.7 1.9 1.9} -rail\_width 0.1 -min\_pitch\_left 3 -

Error and Warning Messages

min\_pitch\_right 3 -min\_pitch\_top 3 -min\_pitch\_bottom 3 -pin\_layer\_top {3 5} -pin\_layer\_bottom {3 5} -pin\_layer\_right {4 6}

Creating partition PKTSS\_PPCS\_PMA\_SYS.

- \*\*WARN: (IMPPTN-426): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to left from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-427): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to right from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-428): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to top from 2.700000 to 2.850000.
- \*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

Placement grid is at 0.135 x-direction, 0.095 y-direction.

## PTNASMD-427

### NAME

PTNASMD-427

### SUMMARY

Adjusting partition %s core to right from %f to %f because specified core spacing value is not multiple of placement grid.

### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

| Exampl | e: |
|--------|----|
|        |    |

March 2020 774 Product Version 20.10

\*\*WARN: (IMPPTN-427): Adjusting partition lbrx top 0 core to right from 0.000000 to 0.100000.

## PTNASMD-428

## **NAME**

PTNASMD-428

#### SUMMARY

Adjusting partition %s core to top from %f to %f because specified core spacing value is not multiple of placement grid.

#### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

\_\_\_\_\_

\*\*WARN: (IMPPTN-428): Adjusting partition lbrx\_top\_0 core to top from 0.000000 to 3.680000.

## PTNASMD-429

#### NAME

PTNASMD-429

#### SUMMARY

Adjusting partition %s core to bottom from %f to %f because specified core spacing value is not multiple of placement grid.

### DESCRIPTION

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

\*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

## PTNASMD-555

#### NAME

PTNASMD-555

### **SUMMARY**

A feasible legal location was not found for %d (out of %d) pins. Consequently, the following pins could not be assigned:

## **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

A. By removing blockages

B. By removing PG stripes

C. Allow more layers for pin assignment

.in

.in +4

Error and Warning Messages

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

# PTNASMD-624

#### NAME

PTNASMD-624

#### SUMMARY

add\_partition\_feedthrus could not find a path for net '%s' to reach '%s'. If the -topoFile option is being used, the topology specified for this net is incomplete.

### **DESCRIPTION**

In case automatic feedthrough insertion is being done, it means that a path to some of the terminals could not be found. If the routeBased option is used, the routing may be incomplete. For the case the topology file is used an explanation follows.

Tool issues above warning during add\_partition\_feedthrus command step, when topology file provided with -topoFile is used to guide the tool for creating the feedthrough in a specified partition for multi-fanout nets. You will get above warning if the topology file did not define for all the terminals for a multi-fanout net. Always follow the convention from\_pin to to\_pin for writing the topology file.

#### Example:

| If the net goes to three partition A, B and C and you want to make a part of the net from A to D tl | hen |
|-----------------------------------------------------------------------------------------------------|-----|
| to C, then you can use the following approach to write the topology file.                           |     |

net n123

hinst-hinst A D;

hinst-hinst D C;

Error and Warning Messages

hinst-hinst A B;

end net

So, here all the combinations are covered where the net goes, instead of defining the A-D-C.

## PTNASMD-646

#### NAME

PTNASMD-646

#### **SUMMARY**

add\_partition\_feedthrus is trying to find a feedthrough path for net %s. It could not find a path to partition or terminal [%s]. Partitions connected to this net may not be adjacent to each other.

#### DESCRIPTION

Automatic feedthrough insertion derives the feedthrough topology using the placement. It assumes a channel-less design. The possibility of routing through channels is considered minimal. In this design a path to a partition or terminal connected to the above mentioned net could not be found without avoiding the channels.

## PTNASMD-647

### **NAME**

PTNASMD-647

### **SUMMARY**

add\_partition\_feedthrus skipping net [%s] because a path to some of the partitions or terminals could not be found. It might not be necessary to insert feedthrough buffers for this net. If you wish to insert feedthrough buffers for this net, then use the topology file for guided feedthrough buffer insertion or use the -routeBased option after routing the net.

Error and Warning Messages

### **DESCRIPTION**

add\_partition\_feedthrus assumes the design to be channel-less and partitions to be in the line of sight for feedthrough path to pass from one partition to another. In case of channel based designs where this is not true, the named net is ignored. In case feedthrough insertion is required for the net, either route the design and used add\_partition\_feedthrus -routeBased or define the path for the net in a topology file and use add\_partition\_feedthrus -topoFile <filename>

Example:
----route\_early\_global
add\_partition\_feedthrus -routeBased
Or
add\_partition\_feedthrus -topoFile <filename>

# PTNASMD-652

### NAME

PTNASMD-652

### **SUMMARY**

The push\_down\_buffer command cannot create an instance with name [%s%s]. An instance with this name already exists in the design. Using default prefix and name [%s] for this instance.

#### DESCRIPTION

This message is issued if the push\_down\_buffer uses the prefix provided with the -prefix option and the resulting name has a conflict with an existing instance name. No action needs to be taken as it will make another name with the default prefix.

# PTNASMD-716

#### NAME

PTNASMD-716

#### SUMMARY

Partition %s constraint missing. Specify a Guide, Region, Fence constraint on the partition or place the blackbox instance.

### **DESCRIPTION**

While committing partitions 1. Blackboxes should be placed inside core 2. Partitions fences must be core

# PTNASMD-780

#### NAME

PTNASMD-780

#### SUMMARY

Selected pin assignment: could not assign %d (out of %d) pins because feasible legal location was not found for following pins, need legal locations for pin to be assigned.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

Error and Warning Messages

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## PTNASMD-882

#### NAME

PTNASMD-882

#### SUMMARY

The add\_partition\_feedthrus command was invoked with the -routeBased option, but the design has not yet been routed. The add\_partition\_feedthrus command will skip the nets that are not routed. Route the design using route\_early\_global for these nets to be considered for feedthrough insertion.

### DESCRIPTION

The add\_partition\_feedthrus command invoked with the -routeBased option requires routing for the net to find a path based on which it will insert the feedthrough ports.

The net reported is not routed so it gets ignored. Route the design prior to running this command. The route\_early\_global command can be used to route the design.

Otherwise add\_partition\_feedthrus should be invoked without using the -routeBased option in which case the command will try to find a path for the net based on the create\_floorplan and placement (placement based feedthrough insertion).

Error and Warning Messages

| Example:                          |    |
|-----------------------------------|----|
|                                   |    |
| route_early_global                |    |
| add partition feedthrus -routeBas | ed |

# PTNASMD-946

### **NAME**

PTNASMD-946

### **SUMMARY**

Pin named [%s] does not exist in cell [%s]. Ignoring the pin. Check and correct the pin name.

## **DESCRIPTION**

Pin name specified for the specified partition does not exist. Check the pin name and partition name and correct accordingly. Problem could be case sensitivity. Command requires exact name which is case sensitive or incorrect manipulation of "alphabet I or numeric 1" "likewise "alphabet o and numeric 0"

Example:

-----

Pin name could be "isCaseSensitive" but pin name supplied could be "iscasesensitive

# PTNASMD-1211

## **NAME**

PTNASMD-1211

Error and Warning Messages

#### **SUMMARY**

Specified layer [%s] is not within the allowed pin layer range [%s] and [%s] of the partition %s. Respecify a valid pin layer value or change the partition definition to allow this pin layer and rerun the command again.

#### DESCRIPTION

Specified layer is not within the allowed pin layer range of the specified partition. Use the Partition->Specify Partition GUI to view the current specified allowed layers. Edit the current allowed pin layers of the partition to include this specified pin layer or re-specify pin layer and rerun the command again.

## **PTNASMD-1250**

### NAME

PTNASMD-1250

### **SUMMARY**

Pin placement has been enabled on metal layer 1.

## **DESCRIPTION**

You have this message because you have enabled metal layer 1 for pin placement. However, metal layer 1 is generally reserved for follow pins. Make sure follow pins are already routed, to ensure that the pins do not block follow pins creation.



# PTNASMD-1520

#### NAME

PTNASMD-1520

#### SUMMARY

Pin '%s' of %s '%s' cannot be placed at the constrained location [%0.2f %0.2f] due to a blocked pin slot close to the location. Placing the pin at location [%0.2f %0.2f].

#### DESCRIPTION

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## PTNASMD-1521

### NAME

PTNASMD-1521

## **SUMMARY**

Unable to get any valid location for the constrained pin [%s] at location [%0.2f %0.2f].

## **DESCRIPTION**

Pin slot can be blocked because of the following reasons

\t 1. pin blockages

Error and Warning Messages

- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## PTNASMD-1550

#### NAME

PTNASMD-1550

### **SUMMARY**

Cell [%s] cannot be specified as a black box because the design does not have any instance associated with this cell or instance may create nested blackBox. Ensure the design has an instance referenced to this cell or specify correct name of cell and rerun %s again.

### **DESCRIPTION**

Specified cell cannot be defined as a black box because the design does not have any instance that is referenced to this cell or instance may create nested blackBox. Ensure there is at least one instance that is associated with this cell and rerun the command again.

# PTNASMD-1669

### **NAME**

PTNASMD-1669

### **SUMMARY**

Ptn %s does not have any reserved slots for assigning ptn pins. Check the allowed layers for the partition and make sure that layers based on preferred routing tracks are reserved.

#### DESCRIPTION

This warning message is issued while assigning pins on a partition using the Innovus GUI with Partition => Assign Pin... or when using the assign\_partition\_pins Tcl command.

The create\_floorplan likely contains a problem with routing tracks and/or pin layer definitions. The problem can be debugged graphically using: Partition => Specify Partition

Select the offending partition and review the Partition Pin Layer Used section. Make sure the layers defined for pins are included in the Layers Reserved For Partition. Corrections may be made and applied with this form. Check the min max layer allowed though get\_db another reason could be presence of route blockage or PG on partition edge blocking the routing tracks.

Next, confirm there are preferred routing tracks defined for the pin layers using the Layer Control => Track => Pref Track and the Wire&Via layer defined for the pins. If the tracks are incorrect, they may be regenerated using the "generateTracks" Tcl command.

#### Example:

get pin constraint -cell c -side all -layer

Constraint on partition c:

Allowed layer on side [top]: 246

Allowed layer on side [left]: 35

Allowed layer on side [bottom]: 246

Allowed layer on side [right]: 35

get db design bottom routing layer design top routing layer

design bottom routing layer 2 # string, default=""

design top routing layer 15 # string, default=""

{design\_bottom\_routing\_layer 2} {design\_top\_routing\_layer 15}

Look for the Tracks in a section with: Track:

While corrections can be made to the tmp.fp file and reloaded with the "read\_floorplan tmp.fp" Tcl command, it is generally easier to do make changes with the Innovus GUI.

# PTNASMD-1671

#### NAME

PTNASMD-1671

#### SUMMARY

The option %s cannot be used for updating pin attribute. Correct the command options and run the command again.

### **DESCRIPTION**

Specified option cannot be used for just updating pin attribute. This option is used with other options for assigning pin location. Check the reference manual for the legal specified options. Then correct the command options and rerun the editPin command again.

# PTNASMD-1699

### **NAME**

PTNASMD-1699

#### SUMMARY

Selective-pin-assignment by specifying just partition name(s) to command assign\_partition\_pins is obsolete and will be removed in future releases. The old usage still works in this release, but to avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with "assign partition pins-partitions-pins".

### **DESCRIPTION**

To avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with 'assign\_partition\_pins -partitions <ptnName> -pins <pinName>'

Example:

Error and Warning Messages

-----

\* The following command assign pins name starting with "in" of partition "A" and pins name starting with "out" of partition "B"

assign partition pins -partitions {A} -pins {in\*} -partitions {B} -pins {out\*}

\* The following command accept a file pinLst.txt that contains the list of pins to be placed for partition A and partition B.

assign\_partition\_pins -partitions A -partitions B -pin\_file pinLst.txt

## PTNASMD-1704

#### NAME

PTNASMD-1704

### **SUMMARY**

The options [-row] and [-bringBackRow] are obsolete. Rows are brought back automatically, without using any of these options. To avoid this warning and ensure compatibility with future releases, update your script to not use any of these options.

### **DESCRIPTION**

This messages is issued when obsolete options are used. Using these options will have no impact in this case.

Example:

-----

eg. use uncommit\_partitions

## PTNASMD-1717

## **NAME**

PTNASMD-1717

## **SUMMARY**

The specifyPartition command will be obsolete in the next release. Use the create\_partition command to define the partitions.

### **DESCRIPTION**

The message occurs because you are using 'specifyPartition' which is obsoletelease use the 'create\_partition' command to define the partitions.

```
Example:
The following example defines a partition:
create_partition \
-hinst ctr inst \
-core spacing 0.56 0.56 0.0 0.0 \
-rail width 0.0 \
-min_pitch_left 2 \
-min pitch right 2 \
-min pitch top 2 \
-min_pitch_bottom 2 \
-reserved_layer {1 2 3 4} \
-pin layer top {2 4} \
-pin_layer_left {3} \
-pin_layer_bottom {2 4} \
-pin layer right {3} \
-place halo 1.0 1.0 1.0 1.0 \
-route halo 1.0 \
-route_halo_top_layer 7 \
-route halo bottom layer 1
```

## PTNASMD-1755

#### NAME

PTNASMD-1755

### **SUMMARY**

Pin [%s] of %s [%s] connected to net [%s] is [%s] at location (%8.3f, %8.3f) on layer %1d %s.

### **DESCRIPTION**

Message reports specific error/violation on a partition pin.

Example of ABUTMENT violation on a pin:

-----

Pin [pin\_1] of partition [ptn\_1] connected to net [net\_1] is [PLACED] at location (210.452, 540.160) on layer 8 has ABUTMENT violation WITH partition chip.

In above example error/violation is being reported for partition "ptn\_1" pin's "pin\_1" which is connected to net "net\_1" and is placed at location "210.452, 540.160" on layer "8" having assignment status as "placed". Pin has abutment (is placed on adjoining boundary of "ptn\_1" and "chip") violation with partition named "chip". Ideally the pin pair of two adjoining (abutting) partitions should be placed on same track on edge of partition boundaries, touching each other (abutting).

Abutment violation could be because of following two reasons:

- 1. Net has multi-partition-pins. Since all other pins of different partitions cannot be placed at same location (no electrical connection through any overlap of physical shape), so it is reported as abutment violation.
- 2. "pin\_1" pin of net "net\_1" is not connected to any pin of adjoining (abutted) partition "chip".

List other violations on pin:

- pin min-width violation
- pin min-depth violation
- pin missing metal shape violation

- pin min-area violation
- pin-color violation
- pin not on routing track (or ndr-rule-routing-track) violation
- pin not on fence violation
- pin spacing (drc and spacing constraints) violation
- pin not on allowed layer violation
- For nested partition it checks for child fence area violation
- pin outside pin-guide or bus-guide violation
- Pin associated pin-group or net-group violation

## PTNASMD-1802

### NAME

PTNASMD-1802

### **SUMMARY**

Route layer setting through routing modes [set\_db %s <value>] or [set\_db %s <value>] setting will not be honored. Set the value using setDesignMode command [set\_db %s <value>] and run the command again.

### **DESCRIPTION**

This message is reported related to IO pin routing if there are any IO pins falls above maxRouteLayer. Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer, and user would like to set min/max layer of pin that is different from route\_early\_global. Innovus checks for this issue and generate the message as user may forget to set min/max layer of pin when it differs from route\_early\_global.



-----

Because of the following reason the ENCPTN-1802 is reported.

Error and Warning Messages

Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer.

Use "set\_db design\_top\_routing\_layer < layer>" to placing IO pins, to avoid this problem.

## PTNASMD-3207

#### NAME

PTNASMD-3207

#### SUMMARY

The hierarchical-PG net %s is connected to an instance term %s inside the partition hinst %s. However, it is not connected to any PG port of the partition hinst. This is erroneous data. As a consequence, instance term %s will become unconnected. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside the partition, and run the command again.

### **DESCRIPTION**

Reason of such incorrect PG net connection is generally introduced by either incorrect UPF or incorrect GNC rule. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside partition. Or, if this connection is not needed inside the partition hinst, then ensure that the net does not connect to any of the PG terms inside the partition hinst.

## PTNFEED-90

### **NAME**

PTNFEED-90

#### SUMMARY

Pin %s of abutted partition %s could not be assigned. Could not find a feasible slot for the pin. Create more feasible location before for pin assignment by inserting feedthrough buffers using add\_partition\_feedthrus command or allowing more layers for assigning pins or using set\_db assign\_pins\_strict\_abutment false or using set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true for relaxing this check.

#### DESCRIPTION

In order to resolve this issue, do the following before pin assignment:

#1 In abutted designs, pins of following type can not be placed on common edges between two adjoining partitions.

.in +2

- A. Pins of net not connected to adjacent partition (fences of the two partitions being connected are not touching each other in create floorplan).
- B. Pins of nets having connections to two or more partitions any pin belonging to net of above type will have to route over an unconnected partition and result in illegal routing.

Feedthrough step is required to get rid of pins which connect non-adjacent partitions or multiple partitions, by changing netlist and making all pins connect to only one pin on adjacent partition to make the routing of net feasible/legal

C. Floating pins

.in

#2. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

i. By using the create\_partition command to allow more layers

Error and Warning Messages

- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset pin constraints command

.in

- #3. Use set\_db assign\_pins\_strict\_abutment false to relax abutment violations checks for placing multi partition pin of a net, non neighbor pins of a net and floating pins on abutted edges.
- #4. Use set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true to relax abutment violations checks for placing floating pins on abutted edges.

#### Example:

-----

eg. if pins are not assigned for a net which has more than two partition pins to connect use add\_partition\_feedthrus command to change netlist to have new nets added and older net modified in way that, now nets only connect two pins of adjacent partitions only.

## PTNFEED-100

#### NAME

PTNFEED-100

#### **SUMMARY**

The net %s is not connected to any terminal. This net will not be considered for feedthrough buffer insertion. Correct the netlist to get this net considered for feedthrough buffer insertion.

### **DESCRIPTION**

An unconnected net will not be considered for feedthrough insertion. The net should be connected to an output port and an input port to be considered for feedthrough insertion.

### NAME

PTNFEED-233

#### SUMMARY

No legal free slots available for %s of partition %s. Create additional slots using create\_partition command or by removing blockage before pin assignment.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset pin constraints command

.in

#### NAME

PTNFEED-426

#### SUMMARY

Adjusting partition %s core to left from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

#### Example:

-----

<CMD> create\_partition -hinst uCORE/uPKTSS/uPKTSS\_PPCS\_PMA\_SYS -core\_spacing {2.7 2.7 1.9 1.9} -reserved\_layer {1 2 3 4 5 6 7 8} -route\_halo 1.9 -route\_halo\_top\_layer 7 - route\_halo\_bottom\_layer 1 -place\_halo {2.7 2.7 1.9 1.9} -rail\_width 0.1 -min\_pitch\_left 3 - min\_pitch\_right 3 -min\_pitch\_top 3 -min\_pitch\_bottom 3 -pin\_layer\_top {3 5} -pin\_layer\_bottom {3 5} -pin\_layer\_left {4 6} -pin\_layer\_right {4 6}

Creating partition PKTSS\_PPCS\_PMA\_SYS.

- \*\*WARN: (IMPPTN-426): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to left from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-427): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to right from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-428): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to top from 2.700000 to 2.850000.
- \*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

Placement grid is at 0.135 x-direction, 0.095 y-direction.

#### NAME

PTNFEED-427

#### SUMMARY

Adjusting partition %s core to right from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

## PTNFEED-428

### **NAME**

PTNFEED-428

### **SUMMARY**

Adjusting partition %s core to top from %f to %f because specified core spacing value is not multiple of placement grid.

<sup>\*\*</sup>WARN: (IMPPTN-427): Adjusting partition lbrx\_top\_0 core to right from 0.000000 to 0.100000.

Error and Warning Messages

#### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

\*\*WARN: (IMPPTN-428): Adjusting partition lbrx\_top\_0 core to top from 0.000000 to 3.680000.

## PTNFEED-429

#### NAME

PTNFEED-429

#### **SUMMARY**

Adjusting partition %s core to bottom from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

<sup>\*\*</sup>WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

#### NAME

PTNFEED-555

#### SUMMARY

A feasible legal location was not found for %d (out of %d) pins. Consequently, the following pins could not be assigned:

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

#### NAME

PTNFEED-624

#### SUMMARY

add partition feedthrus could not find a path for net '%s' to reach '%s'. If the -topoFile option is being used, the topology specified for this net is incomplete.

### **DESCRIPTION**

In case automatic feedthrough insertion is being done, it means that a path to some of the terminals could not be found. If the routeBased option is used, the routing may be incomplete. For the case the topology file is used an explanation follows.

Tool issues above warning during add partition feedthrus command step, when topology file provided with -topoFile is used to guide the tool for creating the feedthrough in a specified partition for multi-fanout nets. You will get above warning if the topology file did not define for all the terminals for a multi-fanout net. Always follow the convention from pin to to pin for writing the topology file.

#### Example:

If the net goes to three partition A, B and C and you want to make a part of the net from A to D then to C, then you can use the following approach to write the topology file.

net n123 hinst-hinst A D; hinst-hinst D C;

hinst-hinst A B:

end net

So, here all the combinations are covered where the net goes, instead of defining the A-D-C.

#### NAME

PTNFEED-646

#### SUMMARY

add\_partition\_feedthrus is trying to find a feedthrough path for net %s. It could not find a path to partition or terminal [%s]. Partitions connected to this net may not be adjacent to each other.

### **DESCRIPTION**

Automatic feedthrough insertion derives the feedthrough topology using the placement. It assumes a channel-less design. The possibility of routing through channels is considered minimal. In this design a path to a partition or terminal connected to the above mentioned net could not be found without avoiding the channels.

# PTNFEED-647

#### **NAME**

PTNFEED-647

#### **SUMMARY**

add\_partition\_feedthrus skipping net [%s] because a path to some of the partitions or terminals could not be found. It might not be necessary to insert feedthrough buffers for this net. If you wish to insert feedthrough buffers for this net, then use the topology file for guided feedthrough buffer insertion or use the -routeBased option after routing the net.

### **DESCRIPTION**

add\_partition\_feedthrus assumes the design to be channel-less and partitions to be in the line of sight for feedthrough path to pass from one partition to another. In case of channel based designs

Error and Warning Messages

where this is not true, the named net is ignored. In case feedthrough insertion is required for the net, either route the design and used add\_partition\_feedthrus -routeBased or define the path for the net in a topology file and use add\_partition\_feedthrus -topoFile <filename>

Example:
----route\_early\_global
add\_partition\_feedthrus -routeBased
Or
add\_partition\_feedthrus -topoFile <filename>

## PTNFEED-652

#### NAME

PTNFEED-652

### **SUMMARY**

The push\_down\_buffer command cannot create an instance with name [%s%s]. An instance with this name already exists in the design. Using default prefix and name [%s] for this instance.

### **DESCRIPTION**

This message is issued if the push\_down\_buffer uses the prefix provided with the -prefix option and the resulting name has a conflict with an existing instance name. No action needs to be taken as it will make another name with the default prefix.

# PTNFEED-716

#### **NAME**

PTNFEED-716

#### SUMMARY

Partition %s constraint missing. Specify a Guide, Region, Fence constraint on the partition or place the blackbox instance.

#### **DESCRIPTION**

While committing partitions 1. Blackboxes should be placed inside core 2. Partitions fences must be core

# PTNFEED-780

#### NAME

PTNFEED-780

### **SUMMARY**

Selected pin assignment: could not assign %d (out of %d) pins because feasible legal location was not found for following pins, need legal locations for pin to be assigned.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

A. By removing blockages

B. By removing PG stripes

C. Allow more layers for pin assignment

.in

.in +4

Error and Warning Messages

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## PTNFEED-882

#### NAME

PTNFEED-882

#### **SUMMARY**

The add\_partition\_feedthrus command was invoked with the -routeBased option, but the design has not yet been routed. The add\_partition\_feedthrus command will skip the nets that are not routed. Route the design using route\_early\_global for these nets to be considered for feedthrough insertion.

#### **DESCRIPTION**

The add\_partition\_feedthrus command invoked with the -routeBased option requires routing for the net to find a path based on which it will insert the feedthrough ports.

The net reported is not routed so it gets ignored. Route the design prior to running this command. The route early global command can be used to route the design.

Otherwise add\_partition\_feedthrus should be invoked without using the -routeBased option in which case the command will try to find a path for the net based on the create\_floorplan and placement (placement based feedthrough insertion).



### NAME

PTNFEED-946

#### **SUMMARY**

Pin named [%s] does not exist in cell [%s]. Ignoring the pin. Check and correct the pin name.

#### **DESCRIPTION**

Pin name specified for the specified partition does not exist. Check the pin name and partition name and correct accordingly. Problem could be case sensitivity. Command requires exact name which is case sensitive or incorrect manipulation of "alphabet I or numeric 1" "likewise "alphabet o and numeric 0"

Example:

-----

Pin name could be "isCaseSensitive" but pin name supplied could be "iscasesensitive

# PTNFEED-1211

### **NAME**

PTNFEED-1211

### **SUMMARY**

Specified layer [%s] is not within the allowed pin layer range [%s] and [%s] of the partition %s. Respecify a valid pin layer value or change the partition definition to allow this pin layer and rerun the command again.

### **DESCRIPTION**

Specified layer is not within the allowed pin layer range of the specified partition. Use the Partition->Specify Partition GUI to view the current specified allowed layers. Edit the current allowed pin layers of the partition to include this specified pin layer or re-specify pin layer and rerun the command again.

# PTNFEED-1250

#### NAME

PTNFEED-1250

#### **SUMMARY**

Pin placement has been enabled on metal layer 1.

### **DESCRIPTION**

You have this message because you have enabled metal layer 1 for pin placement. However, metal layer 1 is generally reserved for follow pins. Make sure follow pins are already routed, to ensure that the pins do not block follow pins creation.

Example:

-----

set\_db design\_bottom\_routing\_layer 1 enables pins in M1

## PTNFEED-1520

### **NAME**

PTNFEED-1520

### **SUMMARY**

Pin '%s' of %s '%s' cannot be placed at the constrained location [%0.2f %0.2f] due to a blocked pin slot close to the location. Placing the pin at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## PTNFEED-1521

### **NAME**

PTNFEED-1521

### **SUMMARY**

Unable to get any valid location for the constrained pin [%s] at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

# PTNFEED-1550

#### NAME

PTNFEED-1550

#### **SUMMARY**

Cell [%s] cannot be specified as a black box because the design does not have any instance associated with this cell or instance may create nested blackBox. Ensure the design has an instance referenced to this cell or specify correct name of cell and rerun %s again.

#### DESCRIPTION

Specified cell cannot be defined as a black box because the design does not have any instance that is referenced to this cell or instance may create nested blackBox. Ensure there is at least one instance that is associated with this cell and rerun the command again.

## PTNFEED-1669

#### NAME

PTNFEED-1669

#### SUMMARY

Ptn %s does not have any reserved slots for assigning ptn pins. Check the allowed layers for the partition and make sure that layers based on preferred routing tracks are reserved.

#### **DESCRIPTION**

This warning message is issued while assigning pins on a partition using the Innovus GUI with Partition => Assign Pin... or when using the assign\_partition\_pins Tcl command.

The create\_floorplan likely contains a problem with routing tracks and/or pin layer definitions. The problem can be debugged graphically using: Partition => Specify Partition

Select the offending partition and review the Partition Pin Layer Used section. Make sure the layers defined for pins are included in the Layers Reserved For Partition. Corrections may be made and applied with this form. Check the min max layer allowed though get\_db another reason could be presence of route blockage or PG on partition edge blocking the routing tracks.

Next, confirm there are preferred routing tracks defined for the pin layers using the Layer Control =>

Error and Warning Messages

Track => Pref Track and the Wire&Via layer defined for the pins. If the tracks are incorrect, they may be regenerated using the "generateTracks" Tcl command.

### Example:

get\_pin\_constraint -cell c -side all -layer

Constraint on partition c:

Allowed layer on side [top]: 246

Allowed layer on side [left]: 35

Allowed layer on side [bottom]: 2 4 6

Allowed layer on side [right]: 35

get db design bottom routing layer design top routing layer

design bottom routing layer 2 # string, default=""

design top routing layer 15 # string, default=""

{design bottom routing layer 2} {design top routing layer 15}

Look for the Tracks in a section with: Track:

While corrections can be made to the tmp.fp file and reloaded with the "read\_floorplan tmp.fp" Tcl command, it is generally easier to do make changes with the Innovus GUI.

## PTNFEED-1671

#### NAME

PTNFEED-1671

#### SUMMARY

The option %s cannot be used for updating pin attribute. Correct the command options and run the command again.

### **DESCRIPTION**

Specified option cannot be used for just updating pin attribute. This option is used with other options for assigning pin location. Check the reference manual for the legal specified options. Then

correct the command options and rerun the editPin command again.

## PTNFEED-1699

#### NAME

PTNFEED-1699

#### SUMMARY

Selective-pin-assignment by specifying just partition name(s) to command assign\_partition\_pins is obsolete and will be removed in future releases. The old usage still works in this release, but to avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with "assign\_partition\_pins -partitions -pins".

#### DESCRIPTION

To avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with 'assign\_partition\_pins -partitions <ptnName> -pins <pinName>'

### Example:

-----

\* The following command assign pins name starting with "in" of partition "A" and pins name starting with "out" of partition "B"

assign\_partition\_pins -partitions {A} -pins {in\*} -partitions {B} -pins {out\*}

\* The following command accept a file pinLst.txt that contains the list of pins to be placed for partition A and partition B.

assign\_partition\_pins -partitions A -partitions B -pin\_file pinLst.txt

## PTNFEED-1704

#### NAME

PTNFEED-1704

#### **SUMMARY**

The options [-row] and [-bringBackRow] are obsolete. Rows are brought back automatically, without using any of these options. To avoid this warning and ensure compatibility with future releases, update your script to not use any of these options.

#### **DESCRIPTION**

This messages is issued when obsolete options are used. Using these options will have no impact in this case.

Example:
----eg. use uncommit\_partitions

# PTNFEED-1717

#### **NAME**

PTNFEED-1717

### **SUMMARY**

The specifyPartition command will be obsolete in the next release. Use the create\_partition command to define the partitions.

### **DESCRIPTION**

The message occurs because you are using 'specifyPartition' which is obsoletelease use the 'create\_partition' command to define the partitions.

| Example:                                   |
|--------------------------------------------|
|                                            |
| The following example defines a partition: |
| create_partition \                         |
| hinst ctr_inst \                           |

```
-core_spacing 0.56 0.56 0.0 0.0 \\
-rail_width 0.0 \\
-min_pitch_left 2 \\
-min_pitch_right 2 \\
-min_pitch_top 2 \\
-min_pitch_bottom 2 \\
-reserved_layer {1 2 3 4} \\
-pin_layer_top {2 4} \\
-pin_layer_left {3} \\
-pin_layer_bottom {2 4} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_late 1.0 1.0 1.0 1.0 \\
-route_halo_top_layer 7 \\
-route_halo_bottom_layer 1
```

#### NAME

PTNFEED-1755

### **SUMMARY**

Pin [%s] of %s [%s] connected to net [%s] is [%s] at location (%8.3f, %8.3f) on layer %1d %s.

### **DESCRIPTION**

Message reports specific error/violation on a partition pin.

Error and Warning Messages

#### Example of ABUTMENT violation on a pin:

-----

Pin [pin\_1] of partition [ptn\_1] connected to net [net\_1] is [PLACED] at location (210.452, 540.160) on layer 8 has ABUTMENT violation WITH partition chip.

In above example error/violation is being reported for partition "ptn\_1" pin's "pin\_1" which is connected to net "net\_1" and is placed at location "210.452, 540.160" on layer "8" having assignment status as "placed". Pin has abutment (is placed on adjoining boundary of "ptn\_1" and "chip") violation with partition named "chip". Ideally the pin pair of two adjoining (abutting) partitions should be placed on same track on edge of partition boundaries, touching each other (abutting).

Abutment violation could be because of following two reasons:

- 1. Net has multi-partition-pins. Since all other pins of different partitions cannot be placed at same location (no electrical connection through any overlap of physical shape), so it is reported as abutment violation.
- 2. "pin\_1" pin of net "net\_1" is not connected to any pin of adjoining (abutted) partition "chip".

List other violations on pin:

- pin min-width violation
- pin min-depth violation
- pin missing metal shape violation
- pin min-area violation
- pin-color violation
- pin not on routing track (or ndr-rule-routing-track) violation
- pin not on fence violation
- pin spacing (drc and spacing constraints) violation
- pin not on allowed layer violation
- For nested partition it checks for child fence area violation
- pin outside pin-guide or bus-guide violation
- Pin associated pin-group or net-group violation

#### NAME

PTNFEED-1802

#### SUMMARY

Route layer setting through routing modes [set\_db %s <value>] or [set\_db %s <value>] setting will not be honored. Set the value using setDesignMode command [set\_db %s <value>] and run the command again.

### **DESCRIPTION**

This message is reported related to IO pin routing if there are any IO pins falls above maxRouteLayer. Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer, and user would like to set min/max layer of pin that is different from route\_early\_global. Innovus checks for this issue and generate the message as user may forget to set min/max layer of pin when it differs from route\_early\_global.



-----

Because of the following reason the ENCPTN-1802 is reported.

Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer.

Use "set\_db design\_top\_routing\_layer <layer>" to placing IO pins, to avoid this problem.

## PTNFEED-3207

### **NAME**

PTNFEED-3207

#### **SUMMARY**

The hierarchical-PG net %s is connected to an instance term %s inside the partition hinst %s. However, it is not connected to any PG port of the partition hinst. This is erroneous data. As a consequence, instance term %s will become unconnected. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside the partition, and run the command again.

#### DESCRIPTION

Reason of such incorrect PG net connection is generally introduced by either incorrect UPF or incorrect GNC rule. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside partition. Or, if this connection is not needed inside the partition hinst, then ensure that the net does not connect to any of the PG terms inside the partition hinst.

## PTNPART-90

### **NAME**

PTNPART-90

#### **SUMMARY**

Pin %s of abutted partition %s could not be assigned. Could not find a feasible slot for the pin. Create more feasible location before for pin assignment by inserting feedthrough buffers using add\_partition\_feedthrus command or allowing more layers for assigning pins or using set\_db assign\_pins\_strict\_abutment false or using set\_db assign\_pins\_allow\_unconnected in abutted edge true for relaxing this check.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1 In abutted designs, pins of following type can not be placed on common edges between two adjoining partitions.

Error and Warning Messages

.in +2

- A. Pins of net not connected to adjacent partition (fences of the two partitions being connected are not touching each other in create\_floorplan).
- B. Pins of nets having connections to two or more partitions any pin belonging to net of above type will have to route over an unconnected partition and result in illegal routing.

Feedthrough step is required to get rid of pins which connect non-adjacent partitions or multiple partitions, by changing netlist and making all pins connect to only one pin on adjacent partition to make the routing of net feasible/legal

C. Floating pins

.in

#2. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

- #3. Use set\_db assign\_pins\_strict\_abutment false to relax abutment violations checks for placing multi partition pin of a net, non neighbor pins of a net and floating pins on abutted edges.
- #4. Use set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true to relax abutment violations checks for placing floating pins on abutted edges.

| _ |    |     |   |    |
|---|----|-----|---|----|
| ᆮ | хa | m   | _ |    |
| г | XН | 111 |   | ₽. |

-----

eg. if pins are not assigned for a net which has more than two partition pins to connect use add\_partition\_feedthrus command to change netlist to have new nets added and older net modified in way that, now nets only connect two pins of adjacent partitions only.

# PTNPART-100

#### NAME

PTNPART-100

#### SUMMARY

The net %s is not connected to any terminal. This net will not be considered for feedthrough buffer insertion. Correct the netlist to get this net considered for feedthrough buffer insertion.

### **DESCRIPTION**

An unconnected net will not be considered for feedthrough insertion. The net should be connected to an output port and an input port to be considered for feedthrough insertion.

## PTNPART-233

### NAME

PTNPART-233

#### **SUMMARY**

No legal free slots available for %s of partition %s. Create additional slots using create\_partition command or by removing blockage before pin assignment.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

Error and Warning Messages

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

## PTNPART-426

#### **NAME**

PTNPART-426

### **SUMMARY**

Adjusting partition %s core to left from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

<CMD> create\_partition -hinst uCORE/uPKTSS/uPKTSS\_PPCS\_PMA\_SYS -core\_spacing {2.7 2.7 1.9 1.9} -reserved\_layer {1 2 3 4 5 6 7 8} -route\_halo 1.9 -route\_halo\_top\_layer 7 - route\_halo\_bottom\_layer 1 -place\_halo {2.7 2.7 1.9 1.9} -rail\_width 0.1 -min\_pitch\_left 3 - min\_pitch\_right 3 -min\_pitch\_top 3 -min\_pitch\_bottom 3 -pin\_layer\_top {3 5} -pin\_layer\_bottom {3 5} -pin\_layer\_left {4 6} -pin\_layer\_right {4 6}

Error and Warning Messages

Creating partition PKTSS\_PPCS\_PMA\_SYS.

- \*\*WARN: (IMPPTN-426): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to left from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-427): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to right from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-428): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to top from 2.700000 to 2.850000.
- \*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

Placement grid is at 0.135 x-direction, 0.095 y-direction.

## PTNPART-427

#### NAME

PTNPART-427

#### **SUMMARY**

Adjusting partition %s core to right from %f to %f because specified core spacing value is not multiple of placement grid.

#### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

<sup>\*\*</sup>WARN: (IMPPTN-427): Adjusting partition lbrx\_top\_0 core to right from 0.000000 to 0.100000.

## PTNPART-428

### NAME

PTNPART-428

#### SUMMARY

Adjusting partition %s core to top from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

## PTNPART-429

### **NAME**

PTNPART-429

### **SUMMARY**

Adjusting partition %s core to bottom from %f to %f because specified core spacing value is not multiple of placement grid.

<sup>\*\*</sup>WARN: (IMPPTN-428): Adjusting partition lbrx\_top\_0 core to top from 0.000000 to 3.680000.

#### DESCRIPTION

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

\*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

## PTNPART-555

#### NAME

PTNPART-555

#### **SUMMARY**

A feasible legal location was not found for %d (out of %d) pins. Consequently, the following pins could not be assigned:

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

A. By removing blockages

B. By removing PG stripes

C. Allow more layers for pin assignment

.in

.in +4

Error and Warning Messages

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## PTNPART-624

#### NAME

PTNPART-624

#### SUMMARY

add\_partition\_feedthrus could not find a path for net '%s' to reach '%s'. If the -topoFile option is being used, the topology specified for this net is incomplete.

### **DESCRIPTION**

In case automatic feedthrough insertion is being done, it means that a path to some of the terminals could not be found. If the routeBased option is used, the routing may be incomplete. For the case the topology file is used an explanation follows.

Tool issues above warning during add\_partition\_feedthrus command step, when topology file provided with -topoFile is used to guide the tool for creating the feedthrough in a specified partition for multi-fanout nets. You will get above warning if the topology file did not define for all the terminals for a multi-fanout net. Always follow the convention from\_pin to to\_pin for writing the topology file.

#### Example:

If the net goes to three partition A, B and C and you want to make a part of the net from A to D then to C, then you can use the following approach to write the topology file.

net n123

hinst-hinst A D;

hinst-hinst D C;

Error and Warning Messages

hinst-hinst A B;

end net

So, here all the combinations are covered where the net goes, instead of defining the A-D-C.

## PTNPART-646

#### NAME

PTNPART-646

#### **SUMMARY**

add\_partition\_feedthrus is trying to find a feedthrough path for net %s. It could not find a path to partition or terminal [%s]. Partitions connected to this net may not be adjacent to each other.

#### DESCRIPTION

Automatic feedthrough insertion derives the feedthrough topology using the placement. It assumes a channel-less design. The possibility of routing through channels is considered minimal. In this design a path to a partition or terminal connected to the above mentioned net could not be found without avoiding the channels.

## PTNPART-647

### **NAME**

PTNPART-647

### **SUMMARY**

add\_partition\_feedthrus skipping net [%s] because a path to some of the partitions or terminals could not be found. It might not be necessary to insert feedthrough buffers for this net. If you wish to insert feedthrough buffers for this net, then use the topology file for guided feedthrough buffer insertion or use the -routeBased option after routing the net.

Error and Warning Messages

#### DESCRIPTION

add\_partition\_feedthrus assumes the design to be channel-less and partitions to be in the line of sight for feedthrough path to pass from one partition to another. In case of channel based designs where this is not true, the named net is ignored. In case feedthrough insertion is required for the net, either route the design and used add\_partition\_feedthrus -routeBased or define the path for the net in a topology file and use add\_partition\_feedthrus -topoFile <filename>

Example:
----route\_early\_global
add\_partition\_feedthrus -routeBased
Or
add\_partition\_feedthrus -topoFile <filename>

# PTNPART-652

#### NAME

PTNPART-652

### **SUMMARY**

The push\_down\_buffer command cannot create an instance with name [%s%s]. An instance with this name already exists in the design. Using default prefix and name [%s] for this instance.

#### DESCRIPTION

This message is issued if the push\_down\_buffer uses the prefix provided with the -prefix option and the resulting name has a conflict with an existing instance name. No action needs to be taken as it will make another name with the default prefix.

# PTNPART-716

### NAME

PTNPART-716

#### SUMMARY

Partition %s constraint missing. Specify a Guide, Region, Fence constraint on the partition or place the blackbox instance.

### **DESCRIPTION**

While committing partitions 1. Blackboxes should be placed inside core 2. Partitions fences must be core

## PTNPART-780

#### NAME

PTNPART-780

#### SUMMARY

Selected pin assignment: could not assign %d (out of %d) pins because feasible legal location was not found for following pins, need legal locations for pin to be assigned.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add partition feedthrus command.

## PTNPART-882

#### NAME

PTNPART-882

#### SUMMARY

The add\_partition\_feedthrus command was invoked with the -routeBased option, but the design has not yet been routed. The add\_partition\_feedthrus command will skip the nets that are not routed. Route the design using route\_early\_global for these nets to be considered for feedthrough insertion.

### DESCRIPTION

The add\_partition\_feedthrus command invoked with the -routeBased option requires routing for the net to find a path based on which it will insert the feedthrough ports.

The net reported is not routed so it gets ignored. Route the design prior to running this command. The route\_early\_global command can be used to route the design.

Otherwise add\_partition\_feedthrus should be invoked without using the -routeBased option in which case the command will try to find a path for the net based on the create\_floorplan and placement (placement based feedthrough insertion).

Error and Warning Messages

| Example:                            |
|-------------------------------------|
|                                     |
| route_early_global                  |
| add partition feedthrus -routeBased |

# PTNPART-946

#### **NAME**

PTNPART-946

### **SUMMARY**

Pin named [%s] does not exist in cell [%s]. Ignoring the pin. Check and correct the pin name.

### **DESCRIPTION**

Pin name specified for the specified partition does not exist. Check the pin name and partition name and correct accordingly. Problem could be case sensitivity. Command requires exact name which is case sensitive or incorrect manipulation of "alphabet I or numeric 1" "likewise "alphabet o and numeric 0"

Example:

-----

Pin name could be "isCaseSensitive" but pin name supplied could be "iscasesensitive

# PTNPART-1211

### **NAME**

PTNPART-1211

Error and Warning Messages

#### **SUMMARY**

Specified layer [%s] is not within the allowed pin layer range [%s] and [%s] of the partition %s. Respecify a valid pin layer value or change the partition definition to allow this pin layer and rerun the command again.

#### DESCRIPTION

Specified layer is not within the allowed pin layer range of the specified partition. Use the Partition->Specify Partition GUI to view the current specified allowed layers. Edit the current allowed pin layers of the partition to include this specified pin layer or re-specify pin layer and rerun the command again.

## PTNPART-1250

#### NAME

PTNPART-1250

### **SUMMARY**

Pin placement has been enabled on metal layer 1.

### **DESCRIPTION**

You have this message because you have enabled metal layer 1 for pin placement. However, metal layer 1 is generally reserved for follow pins. Make sure follow pins are already routed, to ensure that the pins do not block follow pins creation.



# **PTNPART-1520**

#### NAME

PTNPART-1520

### **SUMMARY**

Pin '%s' of %s '%s' cannot be placed at the constrained location [%0.2f %0.2f] due to a blocked pin slot close to the location. Placing the pin at location [%0.2f %0.2f].

#### DESCRIPTION

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## PTNPART-1521

#### NAME

PTNPART-1521

### **SUMMARY**

Unable to get any valid location for the constrained pin [%s] at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

\t 1. pin blockages

- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## PTNPART-1550

#### NAME

PTNPART-1550

#### **SUMMARY**

Cell [%s] cannot be specified as a black box because the design does not have any instance associated with this cell or instance may create nested blackBox. Ensure the design has an instance referenced to this cell or specify correct name of cell and rerun %s again.

### **DESCRIPTION**

Specified cell cannot be defined as a black box because the design does not have any instance that is referenced to this cell or instance may create nested blackBox. Ensure there is at least one instance that is associated with this cell and rerun the command again.

# **PTNPART-1669**

### **NAME**

PTNPART-1669

#### **SUMMARY**

Ptn %s does not have any reserved slots for assigning ptn pins. Check the allowed layers for the partition and make sure that layers based on preferred routing tracks are reserved.

#### DESCRIPTION

This warning message is issued while assigning pins on a partition using the Innovus GUI with Partition => Assign Pin... or when using the assign partition pins Tcl command.

The create\_floorplan likely contains a problem with routing tracks and/or pin layer definitions. The problem can be debugged graphically using: Partition => Specify Partition

Select the offending partition and review the Partition Pin Layer Used section. Make sure the layers defined for pins are included in the Layers Reserved For Partition. Corrections may be made and applied with this form. Check the min max layer allowed though get\_db another reason could be presence of route blockage or PG on partition edge blocking the routing tracks.

Next, confirm there are preferred routing tracks defined for the pin layers using the Layer Control => Track => Pref Track and the Wire&Via layer defined for the pins. If the tracks are incorrect, they may be regenerated using the "generateTracks" Tcl command.

#### Example:

get pin constraint -cell c -side all -layer

Constraint on partition c:

Allowed layer on side [top]: 246

Allowed layer on side [left]: 35

Allowed layer on side [bottom]: 246

Allowed layer on side [right]: 35

get db design bottom routing layer design top routing layer

design bottom routing layer 2 # string, default=""

design top routing layer 15 # string, default=""

{design\_bottom\_routing\_layer 2} {design\_top\_routing\_layer 15}

Look for the Tracks in a section with: Track:

While corrections can be made to the tmp.fp file and reloaded with the "read\_floorplan tmp.fp" Tcl command, it is generally easier to do make changes with the Innovus GUI.

## PTNPART-1671

#### NAME

PTNPART-1671

#### SUMMARY

The option %s cannot be used for updating pin attribute. Correct the command options and run the command again.

#### DESCRIPTION

Specified option cannot be used for just updating pin attribute. This option is used with other options for assigning pin location. Check the reference manual for the legal specified options. Then correct the command options and rerun the editPin command again.

# **PTNPART-1699**

### **NAME**

PTNPART-1699

#### SUMMARY

Selective-pin-assignment by specifying just partition name(s) to command assign\_partition\_pins is obsolete and will be removed in future releases. The old usage still works in this release, but to avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with "assign partition pins-partitions-pins".

### **DESCRIPTION**

To avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with 'assign\_partition\_pins -partitions <ptnName> -pins <pinName>'

Example:

Error and Warning Messages

-----

\* The following command assign pins name starting with "in" of partition "A" and pins name starting with "out" of partition "B"

assign partition pins -partitions {A} -pins {in\*} -partitions {B} -pins {out\*}

\* The following command accept a file pinLst.txt that contains the list of pins to be placed for partition A and partition B.

assign\_partition\_pins -partitions A -partitions B -pin\_file pinLst.txt

## PTNPART-1704

#### NAME

PTNPART-1704

#### **SUMMARY**

The options [-row] and [-bringBackRow] are obsolete. Rows are brought back automatically, without using any of these options. To avoid this warning and ensure compatibility with future releases, update your script to not use any of these options.

#### DESCRIPTION

This messages is issued when obsolete options are used. Using these options will have no impact in this case.

Example:

-----

eg. use uncommit partitions

## PTNPART-1717

### **NAME**

PTNPART-1717

### **SUMMARY**

The specifyPartition command will be obsolete in the next release. Use the create\_partition command to define the partitions.

#### **DESCRIPTION**

The message occurs because you are using 'specifyPartition' which is obsoletelease use the 'create\_partition' command to define the partitions.

```
Example:
The following example defines a partition:
create_partition \
-hinst ctr_inst \
-core spacing 0.56 0.56 0.0 0.0 \
-rail width 0.0 \
-min_pitch_left 2 \
-min pitch right 2 \
-min pitch top 2 \
-min_pitch_bottom 2 \
-reserved_layer {1 2 3 4} \
-pin layer top {2 4} \
-pin_layer_left {3} \
-pin_layer_bottom {2 4} \
-pin layer right {3} \
-place halo 1.0 1.0 1.0 1.0 \
-route halo 1.0 \
-route_halo_top_layer 7 \
-route halo bottom layer 1
```

## PTNPART-1755

#### NAME

PTNPART-1755

#### SUMMARY

Pin [%s] of %s [%s] connected to net [%s] is [%s] at location (%8.3f, %8.3f) on layer %1d %s.

### **DESCRIPTION**

Message reports specific error/violation on a partition pin.

Example of ABUTMENT violation on a pin:

-----

Pin [pin\_1] of partition [ptn\_1] connected to net [net\_1] is [PLACED] at location (210.452, 540.160) on layer 8 has ABUTMENT violation WITH partition chip.

In above example error/violation is being reported for partition "ptn\_1" pin's "pin\_1" which is connected to net "net\_1" and is placed at location "210.452, 540.160" on layer "8" having assignment status as "placed". Pin has abutment (is placed on adjoining boundary of "ptn\_1" and "chip") violation with partition named "chip". Ideally the pin pair of two adjoining (abutting) partitions should be placed on same track on edge of partition boundaries, touching each other (abutting).

Abutment violation could be because of following two reasons:

- 1. Net has multi-partition-pins. Since all other pins of different partitions cannot be placed at same location (no electrical connection through any overlap of physical shape), so it is reported as abutment violation.
- 2. "pin 1" pin of net "net 1" is not connected to any pin of adjoining (abutted) partition "chip".

List other violations on pin:

- pin min-width violation
- pin min-depth violation
- pin missing metal shape violation

- pin min-area violation
- pin-color violation
- pin not on routing track (or ndr-rule-routing-track) violation
- pin not on fence violation
- pin spacing (drc and spacing constraints) violation
- pin not on allowed layer violation
- For nested partition it checks for child fence area violation
- pin outside pin-guide or bus-guide violation
- Pin associated pin-group or net-group violation

## PTNPART-1802

#### **NAME**

PTNPART-1802

#### SUMMARY

Route layer setting through routing modes [set\_db %s <value>] or [set\_db %s <value>] setting will not be honored. Set the value using setDesignMode command [set\_db %s <value>] and run the command again.

#### **DESCRIPTION**

This message is reported related to IO pin routing if there are any IO pins falls above maxRouteLayer. Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer, and user would like to set min/max layer of pin that is different from route\_early\_global. Innovus checks for this issue and generate the message as user may forget to set min/max layer of pin when it differs from route\_early\_global.



-----

Because of the following reason the ENCPTN-1802 is reported.

Error and Warning Messages

Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer.

Use "set db design top routing layer < layer>" to placing IO pins, to avoid this problem.

## PTNPART-3207

#### NAME

PTNPART-3207

#### SUMMARY

The hierarchical-PG net %s is connected to an instance term %s inside the partition hinst %s. However, it is not connected to any PG port of the partition hinst. This is erroneous data. As a consequence, instance term %s will become unconnected. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside the partition, and run the command again.

### **DESCRIPTION**

Reason of such incorrect PG net connection is generally introduced by either incorrect UPF or incorrect GNC rule. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside partition. Or, if this connection is not needed inside the partition hinst, then ensure that the net does not connect to any of the PG terms inside the partition hinst.

## PTNPIN-90

#### NAME

PTNPIN-90

#### SUMMARY

Pin %s of abutted partition %s could not be assigned. Could not find a feasible slot for the pin. Create more feasible location before for pin assignment by inserting feedthrough buffers using add\_partition\_feedthrus command or allowing more layers for assigning pins or using set\_db assign\_pins\_strict\_abutment false or using set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true for relaxing this check.

#### DESCRIPTION

In order to resolve this issue, do the following before pin assignment:

#1 In abutted designs, pins of following type can not be placed on common edges between two adjoining partitions.

.in +2

A. Pins of net not connected to adjacent partition (fences of the two partitions being connected are not touching each other in create\_floorplan).

B. Pins of nets having connections to two or more partitions any pin belonging to net of above type will have to route over an unconnected partition and result in illegal routing.

Feedthrough step is required to get rid of pins which connect non-adjacent partitions or multiple partitions, by changing netlist and making all pins connect to only one pin on adjacent partition to make the routing of net feasible/legal

C. Floating pins

.in

#2. Create additional location for pins

.in +2

A. By removing blockages

B. By removing PG stripes

C. Allow more layers for pin assignment

.in

.in +4

i. By using the create\_partition command to allow more layers

Error and Warning Messages

- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset pin constraints command

.in

- #3. Use set\_db assign\_pins\_strict\_abutment false to relax abutment violations checks for placing multi partition pin of a net, non neighbor pins of a net and floating pins on abutted edges.
- #4. Use set\_db assign\_pins\_allow\_unconnected\_in\_abutted\_edge true to relax abutment violations checks for placing floating pins on abutted edges.

#### Example:

-----

eg. if pins are not assigned for a net which has more than two partition pins to connect use add\_partition\_feedthrus command to change netlist to have new nets added and older net modified in way that, now nets only connect two pins of adjacent partitions only.

## PTNPIN-100

#### NAME

PTNPIN-100

#### **SUMMARY**

The net %s is not connected to any terminal. This net will not be considered for feedthrough buffer insertion. Correct the netlist to get this net considered for feedthrough buffer insertion.

### **DESCRIPTION**

An unconnected net will not be considered for feedthrough insertion. The net should be connected to an output port and an input port to be considered for feedthrough insertion.

### NAME

PTNPIN-233

#### **SUMMARY**

No legal free slots available for %s of partition %s. Create additional slots using create\_partition command or by removing blockage before pin assignment.

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

#### NAME

PTNPIN-426

#### **SUMMARY**

Adjusting partition %s core to left from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

#### Example:

-----

<CMD> create\_partition -hinst uCORE/uPKTSS/uPKTSS\_PPCS\_PMA\_SYS -core\_spacing {2.7 2.7 1.9 1.9} -reserved\_layer {1 2 3 4 5 6 7 8} -route\_halo 1.9 -route\_halo\_top\_layer 7 - route\_halo\_bottom\_layer 1 -place\_halo {2.7 2.7 1.9 1.9} -rail\_width 0.1 -min\_pitch\_left 3 - min\_pitch\_right 3 -min\_pitch\_top 3 -min\_pitch\_bottom 3 -pin\_layer\_top {3 5} -pin\_layer\_bottom {3 5} -pin\_layer\_left {4 6} -pin\_layer\_right {4 6}

Creating partition PKTSS\_PPCS\_PMA\_SYS.

- \*\*WARN: (IMPPTN-426): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to left from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-427): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to right from 1.900000 to 2.025000.
- \*\*WARN: (IMPPTN-428): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to top from 2.700000 to 2.850000.
- \*\*WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

Placement grid is at 0.135 x-direction, 0.095 y-direction.

### NAME

PTNPIN-427

#### SUMMARY

Adjusting partition %s core to right from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

\t Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

## PTNPIN-428

### **NAME**

PTNPIN-428

## **SUMMARY**

Adjusting partition %s core to top from %f to %f because specified core spacing value is not multiple of placement grid.

<sup>\*\*</sup>WARN: (IMPPTN-427): Adjusting partition lbrx\_top\_0 core to right from 0.000000 to 0.100000.

Error and Warning Messages

#### DESCRIPTION

During partitioning, the warnings above are issued. How does Innovus determine these adjustments?

Innovus snaps the partition coreBox (area where rows are created and placement can be done) boundary to the placement grid. The remaining difference between coreBox and partition box is adjusted in core to right, core to top values.

Example:

-----

\*\*WARN: (IMPPTN-428): Adjusting partition lbrx\_top\_0 core to top from 0.000000 to 3.680000.

## PTNPIN-429

#### NAME

PTNPIN-429

#### **SUMMARY**

Adjusting partition %s core to bottom from %f to %f because specified core spacing value is not multiple of placement grid.

### **DESCRIPTION**

This is happening because the core spacing values specified (I/O to core distance of partition block) are not multiple of placement grid. Same issue for IMPPTN-427, IMPPTN-428 and IMPPTN-429 based or the side.

Example:

-----

<sup>\*\*</sup>WARN: (IMPPTN-429): Adjusting partition PKTSS\_PPCS\_PMA\_SYS core to bottom from 2.700000 to 2.850000.

#### NAME

PTNPIN-555

#### SUMMARY

A feasible legal location was not found for %d (out of %d) pins. Consequently, the following pins could not be assigned:

### **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

- A. By removing blockages
- B. By removing PG stripes
- C. Allow more layers for pin assignment

.in

.in +4

- i. By using the create\_partition command to allow more layers
- ii. By choosing higher layer for set\_db design\_top\_routing\_layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

**Error and Warning Messages** 

## PTNPIN-624

#### NAME

PTNPIN-624

#### SUMMARY

add partition feedthrus could not find a path for net '%s' to reach '%s'. If the -topoFile option is being used, the topology specified for this net is incomplete.

### **DESCRIPTION**

In case automatic feedthrough insertion is being done, it means that a path to some of the terminals could not be found. If the routeBased option is used, the routing may be incomplete. For the case the topology file is used an explanation follows.

Tool issues above warning during add partition feedthrus command step, when topology file provided with -topoFile is used to guide the tool for creating the feedthrough in a specified partition for multi-fanout nets. You will get above warning if the topology file did not define for all the terminals for a multi-fanout net. Always follow the convention from pin to to pin for writing the topology file.

#### Example:

If the net goes to three partition A, B and C and you want to make a part of the net from A to D then to C, then you can use the following approach to write the topology file.

net n123 hinst-hinst A D;

hinst-hinst D C;

hinst-hinst A B:

end net

So, here all the combinations are covered where the net goes, instead of defining the A-D-C.

#### NAME

PTNPIN-646

#### **SUMMARY**

add\_partition\_feedthrus is trying to find a feedthrough path for net %s. It could not find a path to partition or terminal [%s]. Partitions connected to this net may not be adjacent to each other.

#### DESCRIPTION

Automatic feedthrough insertion derives the feedthrough topology using the placement. It assumes a channel-less design. The possibility of routing through channels is considered minimal. In this design a path to a partition or terminal connected to the above mentioned net could not be found without avoiding the channels.

## PTNPIN-647

#### NAME

PTNPIN-647

#### SUMMARY

add\_partition\_feedthrus skipping net [%s] because a path to some of the partitions or terminals could not be found. It might not be necessary to insert feedthrough buffers for this net. If you wish to insert feedthrough buffers for this net, then use the topology file for guided feedthrough buffer insertion or use the -routeBased option after routing the net.

### **DESCRIPTION**

add\_partition\_feedthrus assumes the design to be channel-less and partitions to be in the line of sight for feedthrough path to pass from one partition to another. In case of channel based designs

Error and Warning Messages

where this is not true, the named net is ignored. In case feedthrough insertion is required for the net, either route the design and used add\_partition\_feedthrus -routeBased or define the path for the net in a topology file and use add\_partition\_feedthrus -topoFile <filename>

Example:
----route\_early\_global
add\_partition\_feedthrus -routeBased
Or
add\_partition\_feedthrus -topoFile <filename>

## PTNPIN-652

#### NAME

PTNPIN-652

### **SUMMARY**

The push\_down\_buffer command cannot create an instance with name [%s%s]. An instance with this name already exists in the design. Using default prefix and name [%s] for this instance.

### **DESCRIPTION**

This message is issued if the push\_down\_buffer uses the prefix provided with the -prefix option and the resulting name has a conflict with an existing instance name. No action needs to be taken as it will make another name with the default prefix.

## PTNPIN-716

### NAME

PTNPIN-716

#### SUMMARY

Partition %s constraint missing. Specify a Guide, Region, Fence constraint on the partition or place the blackbox instance.

#### DESCRIPTION

While committing partitions 1. Blackboxes should be placed inside core 2. Partitions fences must be core

## **PTNPIN-780**

#### NAME

PTNPIN-780

### **SUMMARY**

Selected pin assignment: could not assign %d (out of %d) pins because feasible legal location was not found for following pins, need legal locations for pin to be assigned.

## **DESCRIPTION**

In order to resolve this issue, do the following before pin assignment:

#1. Create additional location for pins

.in +2

A. By removing blockages

B. By removing PG stripes

C. Allow more layers for pin assignment

.in

.in +4

Error and Warning Messages

- i. By using the create partition command to allow more layers
- ii. By choosing higher layer for set db design top routing layer
- iii. By removing constraints on the pin using reset\_pin\_constraints command

.in

2. Insert feedthrough buffers using the add\_partition\_feedthrus command.

## **PTNPIN-882**

#### NAME

PTNPIN-882

#### SUMMARY

The add\_partition\_feedthrus command was invoked with the -routeBased option, but the design has not yet been routed. The add\_partition\_feedthrus command will skip the nets that are not routed. Route the design using route\_early\_global for these nets to be considered for feedthrough insertion.

#### DESCRIPTION

The add\_partition\_feedthrus command invoked with the -routeBased option requires routing for the net to find a path based on which it will insert the feedthrough ports.

The net reported is not routed so it gets ignored. Route the design prior to running this command. The route\_early\_global command can be used to route the design.

Otherwise add\_partition\_feedthrus should be invoked without using the -routeBased option in which case the command will try to find a path for the net based on the create\_floorplan and placement (placement based feedthrough insertion).



#### NAME

PTNPIN-946

#### **SUMMARY**

Pin named [%s] does not exist in cell [%s]. Ignoring the pin. Check and correct the pin name.

#### **DESCRIPTION**

Pin name specified for the specified partition does not exist. Check the pin name and partition name and correct accordingly. Problem could be case sensitivity. Command requires exact name which is case sensitive or incorrect manipulation of "alphabet I or numeric 1" "likewise "alphabet o and numeric 0"

Example:

-----

Pin name could be "isCaseSensitive" but pin name supplied could be "iscasesensitive

## **PTNPIN-1211**

### **NAME**

PTNPIN-1211

### **SUMMARY**

Specified layer [%s] is not within the allowed pin layer range [%s] and [%s] of the partition %s. Respecify a valid pin layer value or change the partition definition to allow this pin layer and rerun the command again.

## **DESCRIPTION**

Error and Warning Messages

Specified layer is not within the allowed pin layer range of the specified partition. Use the Partition->Specify Partition GUI to view the current specified allowed layers. Edit the current allowed pin layers of the partition to include this specified pin layer or re-specify pin layer and rerun the command again.

# **PTNPIN-1250**

#### NAME

PTNPIN-1250

#### **SUMMARY**

Pin placement has been enabled on metal layer 1.

### **DESCRIPTION**

You have this message because you have enabled metal layer 1 for pin placement. However, metal layer 1 is generally reserved for follow pins. Make sure follow pins are already routed, to ensure that the pins do not block follow pins creation.

Example:

-----

set\_db design\_bottom\_routing\_layer 1 enables pins in M1

## **PTNPIN-1520**

### **NAME**

**PTNPIN-1520** 

### **SUMMARY**

Pin '%s' of %s '%s' cannot be placed at the constrained location [%0.2f %0.2f] due to a blocked pin slot close to the location. Placing the pin at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## **PTNPIN-1521**

### **NAME**

PTNPIN-1521

### **SUMMARY**

Unable to get any valid location for the constrained pin [%s] at location [%0.2f %0.2f].

### **DESCRIPTION**

Pin slot can be blocked because of the following reasons

- \t 1. pin blockages
- \t 2. routing blockages
- \t 3. Power ground routing
- \t 4. availability of layers to put pins

## **PTNPIN-1550**

#### NAME

**PTNPIN-1550** 

#### **SUMMARY**

Cell [%s] cannot be specified as a black box because the design does not have any instance associated with this cell or instance may create nested blackBox. Ensure the design has an instance referenced to this cell or specify correct name of cell and rerun %s again.

#### DESCRIPTION

Specified cell cannot be defined as a black box because the design does not have any instance that is referenced to this cell or instance may create nested blackBox. Ensure there is at least one instance that is associated with this cell and rerun the command again.

## **PTNPIN-1669**

#### NAME

**PTNPIN-1669** 

#### SUMMARY

Ptn %s does not have any reserved slots for assigning ptn pins. Check the allowed layers for the partition and make sure that layers based on preferred routing tracks are reserved.

#### **DESCRIPTION**

This warning message is issued while assigning pins on a partition using the Innovus GUI with Partition => Assign Pin... or when using the assign\_partition\_pins Tcl command.

The create\_floorplan likely contains a problem with routing tracks and/or pin layer definitions. The problem can be debugged graphically using: Partition => Specify Partition

Select the offending partition and review the Partition Pin Layer Used section. Make sure the layers defined for pins are included in the Layers Reserved For Partition. Corrections may be made and applied with this form. Check the min max layer allowed though get\_db another reason could be presence of route blockage or PG on partition edge blocking the routing tracks.

Next, confirm there are preferred routing tracks defined for the pin layers using the Layer Control =>

Error and Warning Messages

Track => Pref Track and the Wire&Via layer defined for the pins. If the tracks are incorrect, they may be regenerated using the "generateTracks" Tcl command.

### Example:

get\_pin\_constraint -cell c -side all -layer

Constraint on partition c:

Allowed layer on side [top]: 246

Allowed layer on side [left]: 35

Allowed layer on side [bottom]: 2 4 6

Allowed layer on side [right]: 35

get db design bottom routing layer design top routing layer

design bottom routing layer 2 # string, default=""

design top routing layer 15 # string, default=""

{design bottom routing layer 2} {design top routing layer 15}

Look for the Tracks in a section with: Track:

While corrections can be made to the tmp.fp file and reloaded with the "read\_floorplan tmp.fp" Tcl command, it is generally easier to do make changes with the Innovus GUI.

## **PTNPIN-1671**

#### NAME

PTNPIN-1671

#### SUMMARY

The option %s cannot be used for updating pin attribute. Correct the command options and run the command again.

#### **DESCRIPTION**

Specified option cannot be used for just updating pin attribute. This option is used with other options for assigning pin location. Check the reference manual for the legal specified options. Then

correct the command options and rerun the editPin command again.

## **PTNPIN-1699**

### **NAME**

**PTNPIN-1699** 

#### SUMMARY

Selective-pin-assignment by specifying just partition name(s) to command assign\_partition\_pins is obsolete and will be removed in future releases. The old usage still works in this release, but to avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with "assign\_partition\_pins -partitions -pins".

#### DESCRIPTION

To avoid this warning and to ensure compatibility with future releases, replace the obsolete usage with 'assign\_partition\_pins -partitions <ptnName> -pins <pinName>'

### Example:

-----

\* The following command assign pins name starting with "in" of partition "A" and pins name starting with "out" of partition "B"

assign\_partition\_pins -partitions {A} -pins {in\*} -partitions {B} -pins {out\*}

\* The following command accept a file pinLst.txt that contains the list of pins to be placed for partition A and partition B.

assign\_partition\_pins -partitions A -partitions B -pin\_file pinLst.txt

## **PTNPIN-1704**

#### NAME

PTNPIN-1704

#### **SUMMARY**

The options [-row] and [-bringBackRow] are obsolete. Rows are brought back automatically, without using any of these options. To avoid this warning and ensure compatibility with future releases, update your script to not use any of these options.

#### **DESCRIPTION**

This messages is issued when obsolete options are used. Using these options will have no impact in this case.

Example:
----eg. use uncommit\_partitions

## **PTNPIN-1717**

#### **NAME**

PTNPIN-1717

### **SUMMARY**

The specifyPartition command will be obsolete in the next release. Use the create\_partition command to define the partitions.

### **DESCRIPTION**

The message occurs because you are using 'specifyPartition' which is obsoletelease use the 'create\_partition' command to define the partitions.

| Example:                                   |
|--------------------------------------------|
|                                            |
| The following example defines a partition: |
| create_partition \                         |
| -hinst ctr_inst \                          |

```
-core_spacing 0.56 0.56 0.0 0.0 \\
-rail_width 0.0 \\
-min_pitch_left 2 \\
-min_pitch_right 2 \\
-min_pitch_top 2 \\
-min_pitch_bottom 2 \\
-reserved_layer {1 2 3 4} \\
-pin_layer_top {2 4} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_left {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
-pin_layer_left {3} \\
-pin_layer_right {3} \\
-pin_layer_left {3} \\
```

### **NAME**

**PTNPIN-1755** 

### **SUMMARY**

Pin [%s] of %s [%s] connected to net [%s] is [%s] at location (%8.3f, %8.3f) on layer %1d %s.

### **DESCRIPTION**

Message reports specific error/violation on a partition pin.

Error and Warning Messages

#### Example of ABUTMENT violation on a pin:

-----

Pin [pin\_1] of partition [ptn\_1] connected to net [net\_1] is [PLACED] at location (210.452, 540.160) on layer 8 has ABUTMENT violation WITH partition chip.

In above example error/violation is being reported for partition "ptn\_1" pin's "pin\_1" which is connected to net "net\_1" and is placed at location "210.452, 540.160" on layer "8" having assignment status as "placed". Pin has abutment (is placed on adjoining boundary of "ptn\_1" and "chip") violation with partition named "chip". Ideally the pin pair of two adjoining (abutting) partitions should be placed on same track on edge of partition boundaries, touching each other (abutting).

Abutment violation could be because of following two reasons:

- 1. Net has multi-partition-pins. Since all other pins of different partitions cannot be placed at same location (no electrical connection through any overlap of physical shape), so it is reported as abutment violation.
- 2. "pin\_1" pin of net "net\_1" is not connected to any pin of adjoining (abutted) partition "chip".

List other violations on pin:

- pin min-width violation
- pin min-depth violation
- pin missing metal shape violation
- pin min-area violation
- pin-color violation
- pin not on routing track (or ndr-rule-routing-track) violation
- pin not on fence violation
- pin spacing (drc and spacing constraints) violation
- pin not on allowed layer violation
- For nested partition it checks for child fence area violation
- pin outside pin-guide or bus-guide violation
- Pin associated pin-group or net-group violation

#### NAME

**PTNPIN-1802** 

#### **SUMMARY**

Route layer setting through routing modes [set\_db %s <value>] or [set\_db %s <value>] setting will not be honored. Set the value using setDesignMode command [set\_db %s <value>] and run the command again.

### **DESCRIPTION**

This message is reported related to IO pin routing if there are any IO pins falls above maxRouteLayer. Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set\_db or set\_db for minLayer but has missed to set setDesignMode for minLayer, and user would like to set min/max layer of pin that is different from route\_early\_global. Innovus checks for this issue and generate the message as user may forget to set min/max layer of pin when it differs from route\_early\_global.



\_\_\_\_\_

Because of the following reason the ENCPTN-1802 is reported.

Message ENCPTN-1802 is generated to correct the user expectation, when user had set either set db or set db for minLayer but has missed to set setDesignMode for minLayer.

Use "set\_db design\_top\_routing\_layer <layer>" to placing IO pins, to avoid this problem.

## **PTNPIN-3207**

### **NAME**

PTNPIN-3207

#### **SUMMARY**

The hierarchical-PG net %s is connected to an instance term %s inside the partition hinst %s. However, it is not connected to any PG port of the partition hinst. This is erroneous data. As a consequence, instance term %s will become unconnected. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside the partition, and run the command again.

#### DESCRIPTION

Reason of such incorrect PG net connection is generally introduced by either incorrect UPF or incorrect GNC rule. To correct this error, ensure that the above net is connected to a partition PG port when connecting to an instance PG term inside partition. Or, if this connection is not needed inside the partition hinst, then ensure that the net does not connect to any of the PG terms inside the partition hinst.

# **SPEF-1123**

### **NAME**

SPEF-1123

#### **SUMMARY**

Invalid capacitor node (%s) does not belong to net found in D NET (%s) that starts on line %u.

#### DESCRIPTION

This message is issued when one of the capacitor nodes defined in D\_NET section does not belong to the same spef file. For Example, Design consisting two spef files i.e. spef1 and spef2 and one of the capacitor nodes specified in D\_NET section in spef1 belongs to D\_NET section of spef2.

#### NAME

SPEF-1124

#### **SUMMARY**

Invalid capacitor node (%s) found in D\_NET (%s) that starts on line %u. %s. Check the SPEF file is valid, correct as needed and read it again.

### **DESCRIPTION**

This message is issued when the capacitor nodes defined in D\_NET section are invalid. This could be due to either the capacitor node doesn't have corresponding pin or port in the netlist or the net in spef doesn't have corresponding net in the netlist or the node name is not present in the netlist.

# **SPEF-1125**

### **NAME**

SPEF-1125

#### SUMMARY

Capacitor nodes (%s) do not belong to net found in D NET (%s) that starts on line %u.

### **DESCRIPTION**

This message is issued when both the capacitor nodes defined in D\_NET section do not belong to the same spef file. For Example, Design consisting two spef files i.e. spef1 and spef2 and both the capacitor nodes specified in D\_NET section of spef1 belong to D\_NET section of spef2.

#### NAME

SPEF-1127

#### **SUMMARY**

Invalid CONN connection found (%s) for D\_NET (%s) that starts on line %u.

### **DESCRIPTION**

This message is issued when the connection defined in "CONN" section for a D\_NET of spef file does not exist in design netlist.

## **SPEF-1132**

#### NAME

SPEF-1132

### **SUMMARY**

An invalid or ignored D\_NET reference (%s) is detected in D\_NET. %s. This D\_NET starts on line %u. Check the SPEF file is valid, correct as needed and read it again.

### DESCRIPTION

This message is issued when the net name specified with D\_NET is invalid. For example spef file consisting D\_NET n1 does not exist in netlist even though it is being referenced in "NAME\_MAP" section of the spef file.

#### NAME

SPEF-1134

#### **SUMMARY**

Invalid resistor node (%s) does not belong to net found in D NET (%s) that starts on line %u.

#### **DESCRIPTION**

This message is issued when both the resistor nodes defined in D\_NET section do not belong to the same spef file. For Example, Design consisting two spef files i.e. spef1 and spef2 and both the resistor nodes specified in D\_NET section in spef1 belong to D\_NET section of spef2.

## **SPEF-1135**

#### NAME

SPEF-1135

#### **SUMMARY**

Invalid resistor node (%s) found in D\_NET (%s) that starts on line %u. %s. Check the SPEF file is valid, correct as needed and read it again.

#### **DESCRIPTION**

This message is issued when the resistor node defined in D\_NET section is invalid. This could be due to either the resistor node doesn't have corresponding pin or port in the netlist or the net in spef doesn't have corresponding net in the netlist or the node name is not present in the netlist.

#### NAME

SPEF-1149

#### **SUMMARY**

Net (%s) referenced in SPEF but has no D NET data.

#### **DESCRIPTION**

This message is issued when the D\_NET section has a net but corresponding connection, capacitance and resistance information is missing.

## **SPEF-1152**

#### NAME

SPEF-1152

### **SUMMARY**

Net '%s' is not fully specified as per its connectivity in design netlist. Missing ports have been added to the net using low RC values. The timing accuracy is not reliable for such nets.

### **DESCRIPTION**

This message is issued when there is mismatch in the connectivity of net specified in the SPEF file and design netlist. Missing ports will be added to the net in SPEF file with low RC values to match the netlist connectivity. The timing accuracy is not reliable for such nets. Refer the file with extension .incomplete\_res.net in working directory for list of such design nets.

# **SPEF-1155**

### NAME

SPEF-1155

### **SUMMARY**

Detected resistor attached on both ends to the same node (%s) in the SPEF file for D\_NET (%s) starting on or around line %u.

### **DESCRIPTION**

This message is issued when resistor is connected to the same nodes (i.e., input and output nodes are same). SPEF parser expects a resistor between two different nodes in \*RES section of a D NET and issues the message (SPEF-1155), whenever this is violated.

### Example:

\*D\_NET \*2468 0.000936122

\*RES

9 \*2468:4 \*2468 2.20892

10 \*2468 \*2468 12.1356 ===== Here, both the nodes of the resistor are the same.

# **TAMODEL-101**

#### NAME

TAMODEL-101

### **SUMMARY**

%d registers and latches have data signals at the control input pins. One example of such a control input pin is '%s'. This arises because clocks are not defined properly or because control input pins are fed by register/latch output pins. To model this data/clock conflict, the model extractor preserves register/latch clock pins and the register/latch output pins along with associated check arcs and delay arcs. Model extraction is terminating because this may lead to a very long runtime, a large memory consumption and a large TLF size. Please use '-force' option to continue.

### **DESCRIPTION**

To remedy this problem, please 1) define clocks, or 2) remove '-keep\_trigger\_arcs' option to ignore the data/clock conflicts or 3) use '-force' option to continue with the preservation of clock trigger arcs

# **TAMODEL-112**

### **NAME**

TAMODEL-112

### **SUMMARY**

Output file '%s' specified with -outFile option of compare\_model\_timing command cannot be created. Please specify a valid file path with write permission.

## **DESCRIPTION**

Output file specified with -outFile option of compare\_model\_timing command cannot be created. Please specify a valid file path with write permission.

## TAMODEL-113

### NAME

TAMODEL-113

### SUMMARY

Input file '%s' specified with %s option of %s command does not exist or cannot be read. Please specify valid file name with read permission.

### **DESCRIPTION**

Input file specified does not exist or cannot be read. Please specify valid file name with read permission.

# **TAMODEL-114**

### **NAME**

TAMODEL-114

### SUMMARY

pg\_pin '%s'is not connected to any power net. Attribute power\_down\_function cannot be written for output pin '%s'.

### DESCRIPTION

This message is issued when rail net is not defined for power pg\_pin or non-zero ground pg\_pins. Attribute 'power down function' cannot be written for such output pins.

# **TAMODEL-115**

### NAME

TAMODEL-115

## **SUMMARY**

Attribute power down function '%s' consists floating ground rail with operator other than + and \*.

Attribute power down function cannot be written for pin '%s'.

### DESCRIPTION

This message is issued when power down function is encountered with complex operators.

# **TAMODEL-116**

### NAME

TAMODEL-116

### **SUMMARY**

The attribute '%s' defined on pin '%s' of cell '%s' and '%s' defined on pin '%s' of cell '%s' have different voltage range. The attribute '%s' cannot be written for pin '%s' in ETM.

### **DESCRIPTION**

This message is issued when non-overlapping voltage range is found for multi driver and multi receiver cases.

# **TAMODEL-117**

### NAME

TAMODEL-117

### **SUMMARY**

The internal\_power could not be calculated for the block as there is no switching activity at any interface pin

## **DESCRIPTION**

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

This message is issues when there's no pin found with non zero switching activity to write internal power on.

# **TAMODEL-301**

### NAME

TAMODEL-301

### **SUMMARY**

This design contains assertions at internal or hierarchical pins that will be ignored in the black box model

### DESCRIPTION

Black box models do not support assertions at internal or hierarchical pins unless they are of the type set\_disable\_timing or set\_case\_analysis. Such assertions are being ignored. The resulting model may not reflect the original timing behavior.

## **TAMODEL-303**

### NAME

TAMODEL-303

### **SUMMARY**

TLF does not recognize a time unit of %f ns, 1 ns assumed

### **DESCRIPTION**

Possible time units in TLF are 1ns, 10ns, 1ps, 10ps and 100ps. Please use set\_time\_unit command to change the time unit to one of the legal values prior to extracting timing models.

# **TAMODEL-307**

### NAME

TAMODEL-307

### **SUMMARY**

Three-dimensional model for delay arc from '%s' to '%s' has been reduced to two-dimensional model. The model will lose accuracy if loading at secondary output '%s' changes from the current value of %.4\n

### **DESCRIPTION**

Three-dimensional models are reduced to two-dimensional model by fixing the secondary loading at the value used in the present context. Avoid using '-blackbox\_2d' option unless the model is to be used within a tool that does not understand three-dimensional models.

## **TAMODEL-308**

## NAME

TAMODEL-308

### **SUMMARY**

The number of slew values (%d) for delay arc from '%s' to '%s' exceeds the maximum permissible value of %d. Only the first %d slew values are considered for delay characterization.

### **DESCRIPTION**

The large number of slew values usually arises from output-to-output paths due to secondary loading effect. To account for the secondary loading, the number of slews is multiplied by the number of primary load values and this product can become very large. To avoid this warning, specify a higher tolerance value using -tolerance option.

# **TAMODEL-309**

### NAME

TAMODEL-309

### SUMMARY

The '%s' to '%s' transition of arc from '%s' to '%s' have early delays greater than the late delays. This may cause issue in timing analysis with the extracted model.

### **DESCRIPTION**

The early delays becomes greater than the late delays in special scenarios like cycle / latency / uncertainty adjustment, or greater early derated, or greater delays in early input libraries. As the extracted model have two parallel arcs; one for early analysis and other for late analysis, In such cases the early arcs being worst delay arc will be used for late analysis and vice-versa.

## **TAMODEL-310**

### **NAME**

TAMODEL-310

## **SUMMARY**

The extracted model will be context dependent on clock frequencies, as multicycle path exception for '%s' arc from '%s' to '%s' can not be pushed out.

## **DESCRIPTION**

When multicycle paths exception on arcs between two pins can not pushed out, the cycle adjustment is adjusted in the arcs delay itself. This cause the extracted model to be context clock frequencies dependent. For such designs the model needs to be re-extracted whenever the clock

frequencies change.

# **TAMODEL-311**

### NAME

TAMODEL-311

### SUMMARY

Found a feedback loop on transparent latch pin %s while traversing path to output port : %s for %s transition.

### DESCRIPTION

If the worst path to an output port is coming from a transparent latch then tools traces backward the latch to find the actual start point of data and stop at non-borrowing latch, flop or input port. In case while tracing backward if there is a feedback loop in the latches, then no actual path is found. Such paths will be skipped.

## TAMODEL-312

### **NAME**

TAMODEL-312

### **SUMMARY**

Pin: %s is duplicated to combinational and sequential part, as both combinational and trigger present on this pin.

### DESCRIPTION

When two pins have both combinational and sequential arc between then, and one arc is valid for setup analysis and other arc is valid for hold analysis only. In such cases pin is duplicated to

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

<pinName>\_COMB\_pin and <pinName>\_SEQ\_pin, and the sequential and combinational arcs are bind to the duplicated pins.

## **TAMODEL-313**

### NAME

TAMODEL-313

### **SUMMARY**

The testcase is running in MMMC configuration. Specify -view option.

### **DESCRIPTION**

In MMMC configuration user need to specify the view for which model need to be extracted. The view specified should be active for both setup and hold analysis. Use -view option to specify the required view.

# TAMODEL-314

## **NAME**

TAMODEL-314

#### SUMMARY

View: %s is not active for %s analysis mode. Use set\_analysis\_view command to make the view active for both setup and hold analysis.

### **DESCRIPTION**

Extracted model contain both setup and hold arc information. So the view, for which you want to extract the model should be active for both setup and hold analysis. You can make view active by using the set analysis view command.

# **TAMODEL-315**

### **NAME**

TAMODEL-315

### **SUMMARY**

Path from '%s' of '%s' and captured by clock '%s' have pin-based clock uncertainties. These constraints will not be a part of the generated ETM model as the global variable 'timing\_extract\_model\_include\_latency\_and\_uncertainty' has been set to false. Ensure that these pin based uncertainty constraints are re-applied after stitching the ETM at the top level.

### DESCRIPTION

Setting the global variable 'timing\_extract\_model\_include\_latency\_and\_uncertainty' to false means that clock latency and uncertainty will not be a part of the generated ETM model. Both of these constraints are expected to come from the clock waveforms of the top level when a design is stitched together for timing analysis. However, the internal pin-based clock latency and certainty will not come from the top level. So, if required, during timing analysis, you will need to reapply these constraints when the design is stitched together using ETM models.

## TAMODEL-316

### NAME

TAMODEL-316

### **SUMMARY**

The software has encountered a problem subdividing the maximum capacitance range for port '%s' into '%d' unique indices due its small value and the current precision setting. The capacitance range for this port will be extended to the default value of %f to allow the calculation of intermediate load points.

### DESCRIPTION

In case the precision of the capacitance range is very low, for instance, in femtofarad and as a result the range is too low to be expressed in the unit specified by the user, for instance, picofarad. In such cases, it is not feasible to divide the already small capacitance interval into unique index points. In such cases, extending the capacitance range to the default value makes sense in order to calculate the index points for the load.

## TAMODEL-317

### NAME

TAMODEL-317

### SUMMARY

The software has encountered a problem subdividing the maximum slew range for port '%s' into '%d' unique indices due its small value and the current precision setting. The slew range for this port will be extended to the default value of %f to allow the calculation of intermediate slew points.

### DESCRIPTION

In case the precision of the slew range is very low, and as a result the range is too low to be expressed in the unit specified by the user. In such cases, it is not feasible to divide the already small slew interval into unique index points. In such cases, extending the slew range to the default value makes sense in order to calculate the index points for the slew.

## TAMODEL-319

### NAME

TAMODEL-319

### **SUMMARY**

CPPR aware model extraction is not supported in BcWc mode. The value of the global

timing extract model enable cppr will be ignored by model extractor.

### DESCRIPTION

The tool does not support generation of ETM that is CPPR aware in the BcWc mode. The current setting of the global timing\_extract\_model\_enable\_cppr is true, which will be ignored by the command model extractor.

# TAMODEL-320

### NAME

TAMODEL-320

### **SUMMARY**

The multicycle path exception for '%s' arc from '%s' to '%s' can not be pushed out. No context-dependent cycle adjustment was made, since the global variable 'timing extract model disable cycle adjustment' has been set to true.

## **DESCRIPTION**

When multicycle paths exception on arcs between two pins can not pushed out, the resulting model may not reflect the original timing behavior. In such cases, when the ETM is instantiated at the top, recoding the multicycle path that is applied at the block will remove the inconsistency.

## **TAMODEL-321**

### NAME

TAMODEL-321

### **SUMMARY**

Waveform Propagation is currently not supported in ETM in worst-case slew propagation mode.

Extracting ETM in path-based slew propagation mode.

### DESCRIPTION

Waveform Propagation is currently not supported in ETM in worst-case slew propagation mode. Extracting ETM in path-based slew propagation mode.

## TAMODEL-322

### NAME

TAMODEL-322

### SUMMARY

Model extractor will characterize all the feed through paths for a default load range, which has 64pf/ff as highest load characterization point. This may lead to interpolation error when timing models are read. For better accuracy user should set the highest load characterization point using global timing\_extract\_model\_max\_feedthrough\_characterization\_load before extracting the timing models.

#### DESCRIPTION

Model extractor will characterize all the feed through paths for a default load range, which has 64pf/ff as highest load characterization point. This may lead to interpolation error when timing models are read. For better accuracy user should set the highest load characterization point using global 'timing\_extract\_model\_max\_feedthrough\_characterization\_load' before extracting the timing models.

## **TAMODEL-323**

#### NAME

TAMODEL-323

### **SUMMARY**

Compare\_model\_timing cannot compare '%s' with '%s' as they have been generated with different 'write\_model\_timing -type' arguments. Please generate both the files with the same argument of 'write\_model\_timing -type' and compare.

### DESCRIPTION

Compare\_model\_timing cannot compare the pre and post write\_model\_timing's reports as they have been generated with different 'write\_model\_timing -type' arguments. Please generate both the files with the same argument of 'write model timing -type' and compare.

## TAMODEL-324

### **NAME**

TAMODEL-324

## **SUMMARY**

do\_extract\_model encountered path delay exception that may prevent a timing arc from being extracted from port '%s'. You may want to remove the path exception before extracting the model.

### **DESCRIPTION**

do\_extract\_model encountered path delay exception that may prevent a timing arc from being extracted from port '%s'. You may want to remove the path exception before extracting the model.

# **TAMODEL-325**

### NAME

TAMODEL-325

### **SUMMARY**

Both analog and digital receivers found for port '%s'. Tool will model this as analog pin and write 'is\_analog : true' on '%s' pin.

### DESCRIPTION

Both analog and digital receivers found for port '%s'. Tool will model this as analog pin and write 'is analog: true' on '%s' pin.

## TAMODEL-326

### NAME

TAMODEL-326

### **SUMMARY**

Both analog and digital drivers found for port '%s'. Tool will model this as analog pin and write 'is\_analog : true' on '%s' pin.

## **DESCRIPTION**

Both analog and digital drivers found for port '%s'. Tool will model this as analog pin and write 'is\_analog : true' on '%s' pin.

# TCLCMD-ERR\_COMCMD86

## **NAME**

TCLCMD-ERR\_COMCMD86

### **SUMMARY**

More than one objects to be renamed are specified

### DESCRIPTION

Only one object to be renamed can be specified at a time

# TCLCMD-ERR\_INVALID\_DATA\_REQUESTED2

### NAME

TCLCMD-ERR\_INVALID\_DATA\_REQUESTED2

### **SUMMARY**

'%s' checks can only be reported in '%s' analysis mode, or simultaneous setup/hold analysis mode. Use either '%s' or simultaneous setup/hold analysis mode, and re-run the command.

## **DESCRIPTION**

The software maintains different analysis modes which at a given time can provide either Setup check related data, Hold check related data, or the combined data for both Setup and Hold style checks. The default and normal operation in Innovus is to have either the Setup or Hold data active at any given time. In Tempus, the normal operation is to have both Setup and Hold active at the same time. The general recommendation is for users to run both of the tools in their respective default modes. As such, users are more likely to see this error message while running Innovus rather than Tempus.\n); detail (\n); detail (The type of analysis being performed by the timer is controlled by:\n); detail (\n); detail (> setAnalysisMode -checkType setup | hold (Innovus Legacy UI)\n); detail (> set analysis mode -checkType setup| hold (Tempus Legacy UI)\n); detail (> set db timing analysis mode setup | hold (Stylus UI)\n); detail (\n); detail (When Setup and Hold analysis data are not simultaneously present in the timer, some types of reporting queries will generate an error - indicating the timer is not in the correct analysis mode to provide the requested data.\n); detail (\n); detail (Example:\n); detail (\n); detail (innovus> setAnalysisMode -checkType hold\n); detail (innovus> report timing -check type setup\n); detail (\n); detail (\*\*ERROR: (TCLCMD-1045): 'setup' checks can only be reported in 'setup' analysis mode, or simultaneous setup/hold analysis mode. Use either 'setup' or simultaneous setup/hold analysis mode, and re-run the command.\n); detail (\n); detail (In Innovus, you could resolve this issue by switching the analysis type back to 'setup'.\n); detail (\n); detail (innovus> setAnalysisMode -checkType setup\n); detail (\n); detail (You should be aware that switching the check type back-and-forth between 'setup' and 'hold' will cause

Error and Warning Messages

timing reset's to occur. You will need to wait for delay calculation and timing analysis to be regenerated.\n); detail (\n); detail (Tempus is almost always run in a mode where both Setup and Hold data are present at the same time - so this type of error condition is rarely encountered.\n

# TCLCMD-ERR MODCMD2

### **NAME**

TCLCMD-ERR\_MODCMD2

### SUMMARY

No module selected

## **DESCRIPTION**

You must set a current module

# TCLCMD-ERR\_TACMD6

### NAME

TCLCMD-ERR\_TACMD6

### **SUMMARY**

The current module is not unique with respect to the top timing module.

### DESCRIPTION

You must set a top timing module and set a unique current module or set a current instance (using set\_current\_instance) before performing any timing commands.

# TCLCMD-ERR\_VIEWCMD1

### NAME

TCLCMD-ERR\_VIEWCMD1

### **SUMMARY**

No view selected

## **DESCRIPTION**

You must set a current view by setting a current module

# TCLCMD-WARN\_COMCMD8

### **NAME**

TCLCMD-WARN COMCMD8

### **SUMMARY**

The software could not find a matching object of the specified type for the pattern '%s'

## **DESCRIPTION**

The get\_\* commands are used for retrieving object and collection references from the timing system. If no objects could be returned that match the specified pattern, possible causes include: \n.P\n - The object truly does not exist in the design.\n.sp .5 \n - You have specified an incorrect wildcard matching pattern - refer to the documentation for more information on proper wildcarding syntax.

# TCLCMD-WARN\_VERBOSE\_PBA\_EXHAUSTIVE\_LIMIT\_1

### **NAME**

TCLCMD-WARN VERBOSE PBA EXHAUSTIVE LIMIT 1

### **SUMMARY**

There are some endpoints which are not able to converge in EPBA Bounded Mode. Refer to verbose log file of current session for more details.

### DESCRIPTION

Exhaustive PBA nworst limit set by timing\_pba\_exhaustive\_path\_nworst\_limit is exhausted for some end-points due to which not all paths terminating to these endpoints are exercised for PBA. To avoid this message, increase the limit by using the global 'set timing\_pba\_exhaustive\_path\_nworst\_limit <value>'.

# TCLCMD-WARN\_WRGCF1

### NAME

TCLCMD-WARN WRGCF1

### **SUMMARY**

Constraint of clock required time on pin '%s' will not be converted in GCF

### DESCRIPTION

The command set\_clock\_required\_time should be replaced by the command set\_external\_delay - ref in order to specify required times for output ports on the clock network. set\_clock\_required\_time should only generated internally by timing analysis during time budgeting and is an obsolete

command.

# TCLCMD-WARN\_WRGCF3

### NAME

TCLCMD-WARN WRGCF3

### **SUMMARY**

Required time on pin '%s' with respect to clock '%s' cannot be converted to GCF

### **DESCRIPTION**

Currently there is no corresponding construct defined in GCF which can represent set required time constraint

# TCLCMD-WARN\_WRGCF4

### NAME

TCLCMD-WARN\_WRGCF4

## **SUMMARY**

Edge identifier and/or timing check type at target pin '%s' doesn't match the type at source pin '%s' in false path assertion

## **DESCRIPTION**

Due to the mismatch, the path may be over-constrained when converted to GCF

# TCLCMD-WARN\_WRGCF5

### NAME

TCLCMD-WARN WRGCF5

### **SUMMARY**

Edge identifier and/or timing check type at target pin '%s' doesn't match the type at source pin '%s' in multi-cycle path assertion

### **DESCRIPTION**

Due to the mismatch, the path may be over-constrained when converted to GCF

# TCLCMD-WARN\_WRGCF12

## **NAME**

TCLCMD-WARN\_WRGCF12

## **SUMMARY**

Path exception with '-through' pin to target pin '%s' is not supported by back-end tool

### DESCRIPTION

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF13

### NAME

TCLCMD-WARN\_WRGCF13

### SUMMARY

Path exception with %s pin asserted on %s port '%s' is not supported by back-end tool

## **DESCRIPTION**

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF14

### **NAME**

TCLCMD-WARN WRGCF14

### **SUMMARY**

Path exception asserted on hierarchical pin '%s' is not supported by back-end tool

## **DESCRIPTION**

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF15

#### NAME

TCLCMD-WARN WRGCF15

### **SUMMARY**

Path exception with TO pin '%s' asserted on instance output is not supported by back-end tool

### **DESCRIPTION**

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF16

### NAME

TCLCMD-WARN WRGCF16

## **SUMMARY**

Path exception with FROM pin '%s' asserted on instance output other than register data output is not supported by back-end tool

## **DESCRIPTION**

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF19

### **NAME**

TCLCMD-WARN WRGCF19

## **SUMMARY**

Path exception asserted on bi-directional pin '%s' is not supported by back-end tool

## **DESCRIPTION**

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF20

### NAME

TCLCMD-WARN WRGCF20

### SUMMARY

Path exception with FROM pin '%s' asserted on instance input other than register clock input is not supported by back-end tool

### **DESCRIPTION**

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF21

### NAME

TCLCMD-WARN WRGCF21

## **SUMMARY**

Path exception with TO pin '%s' asserted on instance input other than register clock or data input is not supported by back-end tool

### **DESCRIPTION**

The generated GCF output may contain unsupported GCF v1.3 construct(s)

# TCLCMD-WARN\_WRGCF30

### NAME

TCLCMD-WARN WRGCF30

### SUMMARY

Default pin based clock uncertainty (without '-to' option) can not be converted to GCF, treating it as a '-to' unceratinty.

### DESCRIPTION

In PKS by default, an uncertainty specification on pin X is honored only at those registers or latches where there is a path from pin X to both the data pin and the clock pin of the register or latch. However, the -to option lifts this restriction and makes it applicable to all registers and latches whose clock pin is in the transitive fanout of pin X. Since the default uncertainty can not be converted to GCF, it treats default uncertainty in the same way as '-to' uncertainty.

## TECHLIB-103

#### NAME

TECHLIB-103

### **SUMMARY**

Unknown timing sense '%s' on pin '%s', cell '%s'

### DESCRIPTION

This message is issued when the invalid timing\_sense is defined on pin of the cell. The valid timing\_sense is negative\_unate, positive\_unate and non\_unate. To fix the issue, re-characterize the library with appropriate settings, such that the valid timing\_sense is defined.

### NAME

TECHLIB-104

### **SUMMARY**

Incorrect latch/ff/bank combination, cell '%s'

## **DESCRIPTION**

This message is issued when the ff/latch bank is specified with negative bit or ff/latch is defined with bit. To fix the issue, re-characterize the library with appropriate settings, such that the correct combination is used.

# **TECHLIB-106**

### NAME

TECHLIB-106

### **SUMMARY**

Could not find any cells in library '%s'

## **DESCRIPTION**

This message is issued when library does not have any cell defined in it.

### NAME

TECHLIB-107

### **SUMMARY**

Could not find pin '%s' on cell '%s'

### **DESCRIPTION**

This message is issued when the undefined related\_pin is used in the power arcs/EM arcs/timing arcs of cell. To fix the issue, re-characterize the library with appropriate settings, such that the related pin specified is defined in cell.

# TECHLIB-122

### NAME

TECHLIB-122

### **SUMMARY**

Wireload model %s in selection table not found

### **DESCRIPTION**

This message is issued when the wire\_load group is not defined in library but referred in wire\_load\_table group. To fix the issue, re-characterize the library with appropriate settings, such that the wire\_load group used in wire\_load\_table group is defined.

### NAME

TECHLIB-123

### **SUMMARY**

Undefined template '%s' referred in cell '%s'

## **DESCRIPTION**

This message is issued when a template is referred in cell but is not defined at library level. To fix the issue, re-characterize the library with appropriate settings, such that the template used is defined in library.

# TECHLIB-152

### NAME

TECHLIB-152

## **SUMMARY**

Linear timing property '%s' found on pin '%s' of cell '%s' in the non-linear library '%s'

## **DESCRIPTION**

This error happens when your non-linear library contains a linear model cell or you update a linear model cell to a non-linear library

### NAME

TECHLIB-169

### **SUMMARY**

Couldn't find pin '%s' specified in the function of cell '%s'

## **DESCRIPTION**

This message is issued when a pin is used in function statement but is not defined in the cell. Function statement will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the undefined pins are not used in function statement.

# **TECHLIB-180**

### NAME

TECHLIB-180

## **SUMMARY**

Unknown model for PVT multiplier '%s'

### DESCRIPTION

Currently only constant and linear models are supported for PVT multiplier

### NAME

TECHLIB-183

### **SUMMARY**

The index '%d' of bus '%s' is out of bus range

### **DESCRIPTION**

This message is issued when the scaler bit is specified which is out of range as per the bus bit definition. To fix the issue, re-characterize the library with appropriate settings, such that the correct range is defined.

# **TECHLIB-184**

### NAME

TECHLIB-184

### SUMMARY

Attempt to create BDD for '%s' string '%s' on timing arc of pin '%s' in cell '%s' failed. This is an internal error.

### **DESCRIPTION**

When the tool is unable to create a BDD against the when/when\_start/when\_end expression it reports an ERROR. The reason can be multiple. One of the reason can be incorrect logic in the expression.

### NAME

TECHLIB-190

### **SUMMARY**

Unrecognized value '%s' of library attribute '%s'

### **DESCRIPTION**

This message is issued when the value of the attributes default operating condition/default wire load selection/default wireload is undefined in library. To fix the issue, re-characterize the library with appropriate settings, such that no undefined value of these attributes are used in the library.

# **TECHLIB-191**

### NAME

TECHLIB-191

## **SUMMARY**

The value '%f' on cell '%s', pin '%s', '%s' should be non-negative

### DESCRIPTION

This message is issued when either the constraint attribute in minimum\_period group or the constraint\_high/constraint\_low attributes in minimum\_pulse\_width group are defined with negative value. Negative values are not allowed in these attributes. To fix the issue, re-characterize the library with appropriate settings, such that constraints are defined with positive value.

### NAME

TECHLIB-246

### SUMMARY

Error encountered while reading cell '%s' in library '%s'

## **DESCRIPTION**

This message is issued when the error is already issued while reading a cell in library. Refer the log file for the failure reason.

# TECHLIB-248

## **NAME**

TECHLIB-248

## **SUMMARY**

Thresholds cannot have negative values

### **DESCRIPTION**

This message is issued when the slew threshold values are specified as negative. Slew thresholds cannot have negative values. To fix the issue, re-characterize the library with appropriate settings, such that positive slew threshold is defined.

### NAME

TECHLIB-249

### SUMMARY

'%s': '%f' should be less than '%s': '%f'

### **DESCRIPTION**

This message is issued when the value of attribute slew\_upper\_threshold/slew\_measured\_upper\_threshold is less than slew\_lower\_threshold/slew\_measured\_lower\_threshold. Value of upper threshold should be greater than the lower threshold value. To fix the issue, re-characterize the library with appropriate settings, such that slew threshold values are defined correctly.

## **TECHLIB-257**

### **NAME**

TECHLIB-257

### **SUMMARY**

%s '%s' has identical lower and upper measured slew thresholds for %s transition

## **DESCRIPTION**

This message is issued when the value of attribute slew\_measured\_lower\_threshold and slew\_measured\_upper\_threshold is defined as same for rise\_transition or fall\_transition in a library. Value of the upper threshold should be greater than the lower threshold value. To fix the issue, recharacterize the library with appropriate settings, such that slew threshold values are defined correctly.

### NAME

TECHLIB-258

### SUMMARY

%s '%s' has identical lower and upper slew thresholds for %s transition

## **DESCRIPTION**

This message is issued when the value of attribute slew\_lower\_threshold and slew\_upper\_threshold is defined as same for rise\_transition or fall\_transition in a library. Value of the upper threshold should be greater than the lower threshold value. To fix the issue, recharacterize the library with appropriate settings, such that slew threshold values are defined correctly.

# **TECHLIB-263**

### NAME

TECHLIB-263

## **SUMMARY**

Pin %s property %s/%s is negative: %f. Check arc is not created

## **DESCRIPTION**

Setup and hold time can be negative. However other check arcs such as: pulse\_width, period, nochange, skew, . These can not be negative values.

### NAME

TECHLIB-264

### SUMMARY

Pin %s property %s/%s -> %s(related\_pin) is negative: %f. Check arc is not created

## **DESCRIPTION**

Setup and hold time can be negative. However other check arcs such as: pulse\_width, period, nochange, skew, . These can not be negative values.

# **TECHLIB-265**

## **NAME**

TECHLIB-265

## **SUMMARY**

Pin %s property (%s %s %s %s) %s/%s is negative: %f. Check arc is not created

#### DESCRIPTION

Setup and hold time can be negative. However other check arcs such as: pulse\_width, period, nochange, skew, . These can not be negative values.

### NAME

TECHLIB-266

### SUMMARY

Attribute '%s' on pin '%s' of cell '%s' is not defined in the library

### **DESCRIPTION**

This message is issued when the attributes

fanout\_load/max\_fanout/min\_fanout/max\_transition/min\_transition/max\_capacitance/min\_capacitance are not defined on pin of cell in the library. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined in the cell pin.

# **TECHLIB-269**

### NAME

TECHLIB-269

### SUMMARY

Wrong usage of template '%s', used in cell '%s' pin '%s'

#### DESCRIPTION

Libcompile will exit when this error occurs. This error happens when a template is wrongly used. For example, in 2-dimensional table lookup, The 'cell\_rise' table expects template that contains The 'input\_net\_transition' and The 'total\_output\_net\_capacitance' indices. If these two template index types can not be found at the compile time of 'cell\_rise' table, BuildGates will flag an error and exit.

### NAME

TECHLIB-270

#### **SUMMARY**

Wrong usage of template '%s', used in cell '%s'

### **DESCRIPTION**

Libcompile will exit when this error occurs. This error happens when a template is wrongly used by non-pin related arcs, such as either in 'rise/fall\_transition\_degradation' or in 'rise/fall\_net\_delay' For an example, in 2-dimensional table lookup, The 'rise\_net\_delay' table expects template that contains The 'output\_pin\_transition' and The 'connect\_delay' indices. If these two template index types can not be found at the compile time of 'rise\_net\_delay' table, BuildGates will flag an error and exit.

# **TECHLIB-271**

#### NAME

TECHLIB-271

#### **SUMMARY**

%s threshold specifications are incomplete

#### DESCRIPTION

This message is to inform users that only partial slew/delay threshold points are specified. For example, only rise threshold points are specified while the fall threshold points are not

#### NAME

TECHLIB-272

#### SUMMARY

Syntax error in '%s' specification. Expecting a '%s'

### **DESCRIPTION**

This message is issued when the attribute input\_threshold\_fall/input\_threshold\_rise is specified with invalid value, for example 'string'. These attributes can accept 'float' values only. To fix the issue, re-characterize the library with appropriate settings, such that valid value is defined for threshold.

## TECHLIB-274

### **NAME**

TECHLIB-274

#### SUMMARY

Can not resolve the when expressions found in the two libraries

### **DESCRIPTION**

There are various possibilities this error may occur as follows: 1. The when condition of pin power construct specified in multiple libraries are overlapping 2. The sum of subsets when-functions is not equal to the superset when-function 3. The when condition of pin power construct specified in from library do not cover all specified in to library, or vice-versa

#### NAME

TECHLIB-275

### **SUMMARY**

Multiple pin power are specified but no when condition specified on each pin power table

### **DESCRIPTION**

BuildGates requires that each pin power table of a specific cell pin to have when condition expression that is mutually exclusive from other when expressions. This message though is limited to detect a case where multiple pin power are specified but do not have when condition expression. When this error message occurs, it means that the library is bad and BuildGates will error out

## **TECHLIB-276**

### **NAME**

TECHLIB-276

#### SUMMARY

Library defines an invalid %s threshold for %s transition of %.0f%%. Use -force option to continue with default values

### **DESCRIPTION**

Delay and slew thresholds of 0 or 100% is physically impossible. Rising exponential waveform will never reach 100%. Falling exponential waveform will never reach 0%

#### NAME

TECHLIB-277

#### SUMMARY

Only one default power table can be specified. BuildGates can not merge libraries.

### **DESCRIPTION**

A default power table is a power table that does not have the WHEN condition specified. Following this message, pin and cell names are displayed, which tell you where the multiple default power tables are found. If you have the min and max library source files, you can compare the power tables to find the source of the error.

# **TECHLIB-278**

### **NAME**

TECHLIB-278

#### SUMMARY

Library '%s' %s does not have correct FE ASIC license

## **DESCRIPTION**

When using FE ASIC license, you should only use the library that is provided by specific ASIC vendor. Contact your ASIC vendor to provide you with the library that contains proper FE ASIC license string

#### NAME

TECHLIB-279

#### SUMMARY

The number of input pins for cell '%s' differ between two libraries. First library has %d input pins, whereas second has %d. Aborting update.

### **DESCRIPTION**

To load the library successfully, make sure the information for the cell in both libraries is consistent.

## TECHLIB-280

### NAME

TECHLIB-280

### **SUMMARY**

Invalid slew threshold range %.2f-%.2f%%. The slew threshold range must be greater than one percent.

## **DESCRIPTION**

This message is issued when the difference between the attributes slew\_lower\_threshold and slew\_upper\_threshold is less than 1%. To fix the issue, re-characterize the library with appropriate settings, such that the slew threshold range greater than 1% is defined.

#### NAME

TECHLIB-281

### SUMMARY

Attempt to read .lib library '%s' failed

### **DESCRIPTION**

This message is issued when the error is already issued while reading a library. Refer the log file for the failure reason.

## **TECHLIB-282**

### **NAME**

TECHLIB-282

### **SUMMARY**

Table values less than expected in user defined group '%s'%s". Table index points being truncated

#### DESCRIPTION

This message is issued when the number of table values specified in user defined group are less than product of dimensions of index values. To fix the issue, re-characterize the library with appropriate settings, such that the table values are specified correctly.

#### NAME

TECHLIB-302

#### **SUMMARY**

No function defined for cell '%s'. The cell will only be used for analysis.

### **DESCRIPTION**

This message is issued when the function of the cell is not defined. This cell will not be used for optimization. To fix the issue, re-characterize the library with appropriate settings, such that the function should be specified.

# **TECHLIB-305**

#### NAME

TECHLIB-305

#### SUMMARY

Library '%s' is already loaded. You need to use read library update command to update a library.

#### DESCRIPTION

You can not use subsequent read\_alf to read in two different libraries with different names. You will have to use read\_library\_update to update the library which share the same name. read\_library\_update only updates cells, operating conditions, and wireload model. It assumes that other properties such as templates and units are already defined in the first library and BG will not update these properties.

#### NAME

TECHLIB-311

#### SUMMARY

Can't derive the asynchronous type of input pin '%s' from the function of output pin '%s' in sequential cell '%s'

### **DESCRIPTION**

The asynchronous timing type (preset or clear) of an input-to-output timing arc in a sequential cell is derived by checking if the input is in the support set of the corresponding asynchronous function of that output. If the asynchronous function of the output is not specified, the asynchronous type cannot be determined and therefore the timing type of that timing arc will be set to combinational by default

## TECHLIB-313

#### NAME

TECHLIB-313

### **SUMMARY**

Property '%s' can not be set on pin '%s' of cell '%s'

### **DESCRIPTION**

Some attributes are specific to certain pin types (input/output/inout). The reported property may not be applicable to the given pin based on its pin type.

#### NAME

TECHLIB-318

### **SUMMARY**

Derating table '%s' already defined, ignored

### **DESCRIPTION**

Currently the old derating table is not overridden by the new one

# **TECHLIB-319**

## **NAME**

TECHLIB-319

### **SUMMARY**

Template '%s' already defined, ignored

## **DESCRIPTION**

Currently the old template is not overridden by the new one

# **TECHLIB-324**

#### NAME

TECHLIB-324

### SUMMARY

Scaling\_factors table '%s' was referenced at cell level but not defined in the library. The scaling factors table will be ignored.

#### DESCRIPTION

All cell scaling\_factors references must have the scaling\_factor defined in the library level in the same file. read\_library\_update may not be used to merge scaling\_factors defined in one file with scaling\_factors references defined in another file

## **TECHLIB-327**

#### NAME

TECHLIB-327

### SUMMARY

Cell '%s' has more than %d input pins. The cell will only be used for analysis.

#### DESCRIPTION

This message is issued when a cell has more than 24 input pins. Such cells are not used during optimization and are used only for analysis.

# **TECHLIB-336**

### **NAME**

TECHLIB-336

#### **SUMMARY**

The minimum clock %s constraint in cell '%s' is not a constant, ignored

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

## **DESCRIPTION**

Only constant TLF model is supported now

# **TECHLIB-338**

## **NAME**

TECHLIB-338

#### **SUMMARY**

Linear timing property '%s' found on pin '%s' of cell '%s' in the non-linear library '%s'

### **DESCRIPTION**

This message is issued when the non-linear library contains a linear model cell or update a linear model cell to a non-linear library.

# TECHLIB-342

#### NAME

TECHLIB-342

### **SUMMARY**

Attempt to create mode '%s' belonging to mode group '%s' failed

### **DESCRIPTION**

The BDD for the conditional expression associated with this mode could not be built

#### NAME

TECHLIB-357

#### **SUMMARY**

Test cell '%s' uses '%s' as state variable whereas scan cell uses '%s' in library '%s'; '%s' is used as state variable in test cell

#### **DESCRIPTION**

This message is issued when the state variables defined in the library are not same in the test cell and scan cell. To fix the issue, re-characterize the library with appropriate settings, such that the state variables are defined correctly.

# **TECHLIB-368**

### NAME

TECHLIB-368

#### SUMMARY

Unable to find the ff/latch '%s' functionality pin for cell '%s'

#### **DESCRIPTION**

This message is issued when the ff/latch functionality pin (IQ/IQn) for cell is undefined. To fix the issue, re-characterize the library with appropriate settings, such that the function of a cell is defined.

#### NAME

TECHLIB-369

#### SUMMARY

Unable to extract the '%s' function for sequential cell '%s'

### **DESCRIPTION**

This message is issued when the values defined for statetable for the attributes next\_state/clocked\_on/preset/clear/clear\_preset\_var1/clear\_preset\_var2 cannot be converted into ff/latch.

# **TECHLIB-377**

#### NAME

TECHLIB-377

#### **SUMMARY**

%s '%s' not equivalent to %s '%s'.

### **DESCRIPTION**

This message is issued when there is discrepancy between the scaled cell and regular cell. Cells are not equivalent. To fix the issue, re-characterize the library with appropriate settings, such that the cells are matched.

#### NAME

TECHLIB-381

### **SUMMARY**

Values for '%s' different between the scaled and regular %s '%s'.

### **DESCRIPTION**

This message is issued when there is discrepancy between the scaled cell and regular cell in values for direction/number of timing arc/number of related pins for power arc/number of equal or opposite pins for power arc/when string for power arc/period/pulse\_width/fanout\_load/output\_function/three\_state\_function for I/O pins. To fix the issue, re-characterize the library with appropriate settings, such that the values for these attributes between cells are matched.

## **TECHLIB-382**

#### NAME

TECHLIB-382

### **SUMMARY**

No pin '%s' found in scaled cell but present in regular cell.

#### DESCRIPTION

This message is issued when there is discrepancy in pins between the scaled cell and regular cell. To fix the issue, re-characterize the library with appropriate settings, such that the pins are consistent between the cells

#### NAME

TECHLIB-383

#### **SUMMARY**

Attempt to create three-state function for %s pin '%s' in cell '%s' failed

### **DESCRIPTION**

Check if three-state function is incorrectly defined in terms of output pin itself. Check if the pins defined in the three-state function are defined for the cell. Cell will not be mapped to but if instantiated manually, will be correctly timed.

# **TECHLIB-385**

#### NAME

TECHLIB-385

### **SUMMARY**

Pin %s property %s/%s is zero or negligible: %f. BG will still create the check arc

## **DESCRIPTION**

BuildGates will still create any check arcs that are zero.

### NAME

TECHLIB-386

#### **SUMMARY**

Pin %s property %s/%s -> %s(related\_pin) is zero or negligible: %f. BG will still create the check arc

### **DESCRIPTION**

BuildGates will still create any check arcs that are zero.

# **TECHLIB-387**

### **NAME**

TECHLIB-387

### **SUMMARY**

Pin %s property (%s %s %s %s) %s/%s is zero or negligible: %f. BG will still create the check arc

## **DESCRIPTION**

BuildGates will still create any check arcs that are zero.

# **TECHLIB-389**

### **NAME**

TECHLIB-389

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

#### SUMMARY

Unable to find cell '%s' in library to update spice pin order

#### **DESCRIPTION**

'read\_library\_update -spice' is to update spice pin order This warning message occurs if the spice subckt file contains cells that can not be found in the timing library In which case, BuildGates will ignore such subckt

## TECHLIB-390

#### **NAME**

TECHLIB-390

#### SUMMARY

No delay threshold points for %s transition specified in library '%s', assuming delay thresholds %.0f%%-%.0f%%

#### DESCRIPTION

This warning is encountered if the following constructs are missing from the library. input\_threshold\_pct\_fall input\_threshold\_pct\_rise output\_threshold\_pct\_fall output\_threshold\_pct\_rise These constructs in the timing library define how the delay of the characterized cells has been deduced. For example a input\_threshold\_pct\_rise of 30 and output\_threshold\_pct\_rise of 60 means theat the delay value in the tables are the time difference between the input rising to 30% of its values and output rising to 70% of its value. If these are missing, then they are assumed to be 50% for both input and output and rise and fall. To avoid this warning make sure that the timing labraries have the correct values of input and output rise/fall thresholds specified.

#### NAME

TECHLIB-391

### **SUMMARY**

No slew threshold points for %s transition specified in library '%s', assuming slew thresholds %.0f%%-%.0f%% (measured) %.0f%%-%.0f%% (reported).

### **DESCRIPTION**

This warning is encountered if the following constructs are missing from the library. slew\_lower\_threshold\_pct\_fall slew\_upper\_threshold\_pct\_fall slew\_lower\_threshold\_pct\_rise slew\_upper\_threshold\_pct\_rise These constructs in the timing libraries are the slew thresholds which define how slew values are calculated. For example a slew\_lower\_threshold\_pct\_rise of 20 and slew\_upper\_threshold\_pct\_rise of 80 means that the time values present in the library were written as if 'measured' at 20% of the signal and 80% of the signal, and the slew is represented as their difference. If these are missing, they are assumed to be 40% -60% (measured) 10%-90% (reported). The measured thresholds are the ones at which timing is actually measured from spice. These can be then stretched to reported thresholds linearly, to generate the data in the timing library. To avoid this warning make sure that the timing libraries have the correct slew threshold values specified.

# TECHLIB-392

#### **NAME**

TECHLIB-392

### SUMMARY

Ignoring pin power table on pin '%s' of cell '%s' because of bad type: %d

#### DESCRIPTION

This message tells the user that specific INTERNAL\_ENERGY statement is ignored because of invalid TLF data type. BuildGates only accepts the following data types for internal energy: - INTERNAL\_ENERGY( model [COND( cond)]) - INTERNAL\_ENERGY(RISE( model) FALL( model) [COND( cond)])

# TECHLIB-393

#### NAME

TECHLIB-393

#### SUMMARY

Pin '%s' of cell '%s' has power arcs with incomplete when conditions

## **DESCRIPTION**

This message occurs if pin power arcs has incomplete when conditions Incomplete means that the when conditions for a specific power arcs do not add to 1.

# **TECHLIB-395**

#### NAME

TECHLIB-395

#### SUMMARY

Library defines an invalid %s threshold for %s transition of %.0f%%. Default value of %.0f%% is used instead.

### **DESCRIPTION**

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

Delay and slew thresholds of 0 or 100% is physically impossible. Rising exponential waveform will never reach 100%. Falling exponential waveform will never reach 0%

## TECHLIB-397

#### NAME

TECHLIB-397

### SUMMARY

BG computes reported slew threshold that is beyond the 0%%-100%% range. For rising transition: %.0f%%-%.0f%% For falling transition: %.0f%%-%.0f%%

### **DESCRIPTION**

The reported slew threshold is computed using the library defined slew threshold and the library defined slew\_derate value Such case may happen for example if the library defines a slew threshold of 20-80 and a slew\_derate value of 0.5

## TECHLIB-398

#### NAME

TECHLIB-398

#### **SUMMARY**

%s threshold specifications are incomplete. You can override the threshold specifications using set\_tech\_info command

### **DESCRIPTION**

Only partial slew/delay threshold points are specified. For example, delay threshold for rising transition is specified while delay threshold for falling transition is not.

#### NAME

TECHLIB-399

#### SUMMARY

No %s threshold for %s transition specified, assuming default value of %.0f%%

## **DESCRIPTION**

The mentioned threshold value is missing from the library and the default value is used to compensate for the missing information. This message occurs only if partial threshold information is specified. For example, delay threshold for rising transition is specified while delay threshold for falling transition is not.

# **TECHLIB-400**

### **NAME**

TECHLIB-400

#### SUMMARY

State table for cell '%s' is ignored because it contains multiple references to input map. The input\_map attribute can be defined more than once for multi-bit sequential cells only.

#### DESCRIPTION

Examples of multiple instances of a sequential device in a single cell include master-slave devices, shift registers or counters. Only simple register/latch banks with explicit bundle specification are supported

#### NAME

TECHLIB-401

#### **SUMMARY**

There are multiple power pin defined with the same related\_pin and the same when condition on pin %s of cell %s. Only the last data is used.

### **DESCRIPTION**

Multiple power pin with the same related\_pin, same equal\_or\_opposite\_pins, same when conditions, and same transition edges will be merged. i.e. the last data will override the earlier one.

## **TECHLIB-402**

#### NAME

TECHLIB-402

#### SUMMARY

Support for libcompile is being phased out. Use read\_dotlib to read in .lib natively or syn2tlf and read\_tlf to compile into TLF. Some constructs such as generated clocks and interface\_timing are supported only in read\_dotlib and syn2tlf/read\_tlf

### **DESCRIPTION**

Refer to the Timing Analysis Using BuildGates Synthesis and Cadence PKS for more details on constructs that are not supported by libcompile

#### NAME

TECHLIB-403

#### SUMMARY

Invalid specification of %s in the output/internal pin %s of cell %s. These specifications are only allowed in input/bidir pins; therefor, these specifications will be ignored when library loading.

### **DESCRIPTION**

According to the Liberty format, hyperbolic noise can only be specified on input pins of a cell. All hyperbolic noise specifications on internal and output pins will be ignored.

# **TECHLIB-404**

#### NAME

TECHLIB-404

#### **SUMMARY**

The coefficient value is less than 0 for the hyperbolic %s coefficient for %s in pin %s of Cell %s. Therefore the entire group will be ignored.

### DESCRIPTION

Hyperbolic coefficients for area, width and height can not be negative. Even if one of them is specified as negative, the entire hyperbolic noise group is ignored.

#### NAME

TECHLIB-405

#### **SUMMARY**

Template %s should be of size 2D, specified as a function of noise width (input\_noise\_width) and output load (total output net capacitance). Ignoring this template.

### **DESCRIPTION**

The Noise Immunity templates must have exactly two axies. The input\_noise\_width axis specifies the noise width and the output load is specified by the total output net capacitance axis

## **TECHLIB-406**

#### NAME

TECHLIB-406

#### SUMMARY

Ignoring the specified 'steady\_state\_current\_tristate' table in the non three\_state pin/bus/bundle %s of cell %s. The above specification applies only to three state pins.

#### **DESCRIPTION**

The steady\_state\_current\_tristate can only be specified for three state pins, buses or bundles. If it is specified for a non three-state pin, its value is ignored.

#### NAME

TECHLIB-407

#### SUMMARY

The specified value is less than 0 for %s steady\_state\_resistance in pin %s of cell %s. Values must be positive float numbers.

### **DESCRIPTION**

The steady\_state\_resistance can not take negative values. All such negative values are neglected.

# **TECHLIB-408**

### **NAME**

TECHLIB-408

## **SUMMARY**

The template definition for %s, referenced in pin %s of cell %s is missing in the library. Therefore, the table would be ignored while loading the library.

## **DESCRIPTION**

Specify the missing template at the library level.

#### NAME

TECHLIB-409

#### SUMMARY

Invalid axis specified for 'iv\_lut\_template' %s. It must be function of output voltage (iv\_output\_voltage). Ignoring this template.

### **DESCRIPTION**

The iv\_lut\_template must be a single dimensional table. The only axis is the output voltage axis, specified by iv\_output\_voltage

# **TECHLIB-410**

#### NAME

TECHLIB-410

#### SUMMARY

Invalid combination of axis specified for 'propagation\_lut\_template' %s. It must be a function of noise width (input\_noise\_width), noise height (input\_noise\_height) and output load (total\_output\_net\_capacitance). Ignoring this template.

#### DESCRIPTION

The propagation\_lut\_template must be a 3D table. The axes which need to specified are - noise width (input\_noise\_width), noise height (input\_noise\_height) and output load (total\_output\_net\_capacitance)

#### NAME

TECHLIB-411

#### **SUMMARY**

The lookup table template %s specified in the library is a Scalar lookup template. All of the axis in the template contain only single co-ordinate points, which would not be useful during table lookup.

#### DESCRIPTION

A scalar lookup template is one which has only one axis point in each of its axis. Such a lookup template is useless for table lookup.

# **TECHLIB-412**

#### NAME

TECHLIB-412

#### **SUMMARY**

A single data point found in the axis point redefinition of template %s in pin %s of cell %s. This axis point will not be useful during table lookup.

### **DESCRIPTION**

Single point axis is not useful for lookups. Any redefinition of such single points will not effect the lookup in any way

#### NAME

TECHLIB-413

#### SUMMARY

Negative data found in table for %s noise immunity in pin %s of cell %s. The data values must be positive.

### **DESCRIPTION**

Noise immunity data can not specified as negative.

## **TECHLIB-414**

### NAME

TECHLIB-414

### **SUMMARY**

Missing %s %s noise propagation specification in pin %s of cell %s in the library. Height and width tables for a particular region (low, high, below\_low, above\_high) must be specified in pairs.

### **DESCRIPTION**

Height and Width specifications for a particular noise region should always come in a pair. Need to specify both the parameters for propagation.

#### NAME

TECHLIB-415

#### **SUMMARY**

Template definition for %s, referenced in pin %s of cell %s missing in the library. Table would be ignored while library loading.

### **DESCRIPTION**

The template used must be defined at the library level.

# **TECHLIB-416**

### **NAME**

TECHLIB-416

### **SUMMARY**

Single Data point found in the axis point redefinition of template %s in pin %s of cell %s. Axis point would not be useful during lookup.

### **DESCRIPTION**

Single point axis are not useful for lookups. Any redefinition of such single points will not effect the lookup in any way

#### NAME

TECHLIB-417

### **SUMMARY**

Multiple definitions of template %s found in the library. Preserving the latest definition.

### **DESCRIPTION**

If a template is defined multiple number of times at the library level, only the latest definition is preserved.

## **TECHLIB-418**

### NAME

TECHLIB-418

### **SUMMARY**

Number of data points in the table %s in pin %s in cell %s does not match the number of axis points specified in the template.

### **DESCRIPTION**

The number of data points should preferably match the number of axis points in a template. If this is not the case, table lookups might not be accurate.

#### NAME

TECHLIB-419

#### **SUMMARY**

Number of index point in axis redefinition of template %s in pin %s in cell %s is not equal to that in the original template.

### **DESCRIPTION**

The number of points in axis redefinition should be exactly equal to the number of axis points in the template.

# **TECHLIB-420**

#### NAME

TECHLIB-420

#### **SUMMARY**

Number of ecsm\_waveforms in the '%s' table on pin %s of cell %s does not match the number of transition table axis points specified in the template '%s'. Ignoring waveform data.

#### **DESCRIPTION**

The number of ecsm\_waveforms must match the number of data points in the transition table for correct waveform lookup. If this is not the case, waveform data for the transition group is ignored.

#### NAME

TECHLIB-421

#### **SUMMARY**

Invalid ecsm waveform group name %s specified in pin %s of cell %s. Ignoring waveform data.

### **DESCRIPTION**

Waveform group name must be a digit and the value of the digit must not be greater than or equal to the total number of entries in the output transition table. All the waveforms must start from 0.

## **TECHLIB-422**

#### NAME

TECHLIB-422

### **SUMMARY**

The output transition table '%s' for pin '%s' of cell '%s' is not a function of capacitive load. No ECSM data is available for this transition group. Capacitive load indices are required for generating the ECSM data.

#### **DESCRIPTION**

This message is issued when the output transition table is not a function of capacitive load. Such ECSM data will not be available. To fix the issue, re-characterize the library with appropriate settings, such that the capacitive load indices are defined.

#### NAME

TECHLIB-423

#### SUMMARY

Unable to infer polarity for pin %s of cell %s. Positive polarity assumed.

### **DESCRIPTION**

Couldn't find two different delay values in the table for pair of input slew and output load.

# **TECHLIB-424**

### NAME

TECHLIB-424

#### SUMMARY

Invalid ECSM\_Current/PGDC waveform group name %s specified in pin %s of cell %s. Ignoring waveform data.

### **DESCRIPTION**

Waveform group name must be a digit and the value of the digit must not be greater than or equal to the total number of entries in the output transition table. All the waveforms must start from 0.

#### NAME

TECHLIB-425

#### **SUMMARY**

Invalid rail connection name %s specified in ECSM\_Power/PGDC group for pin %s of cell %s. Ignoring waveform data.

### **DESCRIPTION**

Waveform rail connection name is optional. If provided it must be valid one

# **TECHLIB-426**

### **NAME**

TECHLIB-426

## **SUMMARY**

Incompatible ecsm\_power\_version/pgdc\_version %f in library %s

## **DESCRIPTION**

The ecsm\_power\_version/pgdc\_version defined in a library must be equal to 1.0

#### NAME

TECHLIB-427

### **SUMMARY**

Empty ECSM\_Current/PGDC waveform group found in cell %s, of library %s

### **DESCRIPTION**

If ECSM\_Current/PGDC groups are defined, they must contain waveform groups also. They can not be empty

## **TECHLIB-428**

### NAME

TECHLIB-428

## **SUMMARY**

Number of index\_1 points does not match with the number of values points for the %s waveform group %s specified in pin %s of cell %s Ignoring waveform data.

## **DESCRIPTION**

This message is issued when the total number of index\_1 points are not equal to the total number of values specified in pin of cell for ECSM power/PGDC group. To fix the issue, re-characterize the library with appropriate settings, such that the index\_1 is correctly defined.

#### NAME

TECHLIB-429

#### SUMMARY

Waveform group count does not match with the template %s in pin %s of cell %s

### **DESCRIPTION**

The total number of waveform groups must be equal to the total number of values described by the corresponding template

## **TECHLIB-430**

### **NAME**

TECHLIB-430

## **SUMMARY**

Values of the %s waveform group %s should monotonically increase in pin %s of cell %s

### **DESCRIPTION**

This warning is encountered if the ECSM waveform in the timing library is not monotonically increasing or monotonically decreasing. ECSM waveform models the v-t relationship for a signal. The voltage should monotonically increase (for rise waveforms) and monotonically fall (for fall waveforms). If there is glitch in the waveform the above message is issued. To avoid this warning, fix the ECSM waveform data in the library so that there are no glitches in the waveform.

#### NAME

TECHLIB-431

#### SUMMARY

Mismatch in the number values redefined for Index\_%d of template %s in pin %s of cell %s

### **DESCRIPTION**

Index redefinitions should contain exactly the same number of values as defined in the original template

# **TECHLIB-432**

### **NAME**

TECHLIB-432

### **SUMMARY**

Unknown ecsm\_capacitance type defined in pin %s of cell %s. Ignoring ecsm\_capacitance defined in the pin.

### **DESCRIPTION**

The ecsm\_capacitance type should be either rise or fall. If a value other than rise or fall is encountered, the ecsm\_capacitance information will be ignored

#### NAME

TECHLIB-433

#### SUMMARY

Cell %s is not an isolation cell, pin %s on line %d is specified isolation %s pin. Ignoring 'isolation\_cell\_%s\_pin' attribute of this pin.

### **DESCRIPTION**

'isolation\_cell\_enable\_pin' attribute specifies the enable pin of an isolation cell and 'isolation\_cell\_data\_pin' attribute specifies the data pin of an isolation cell. The parent cell of this pin is not an isolation cell. To mark the cell as an isolation cell, mention 'is\_isolation\_cell: true' at the cell level.

## **TECHLIB-434**

### **NAME**

TECHLIB-434

#### SUMMARY

Cell %s is not a level shifter cell, pin %s is specified level shifter %s pin. No data is ignored.

#### DESCRIPTION

'level\_shifter\_enable\_pin' and 'level\_shifter\_data\_pin' attribute specifies the enable pin and data pin of a level shifter cell respectively. The parent cell of this pin is not a level shifter cell. To mark the cell as a level shifter cell mention 'is\_level\_shifter: true' at the cell level.

#### NAME

TECHLIB-435

#### **SUMMARY**

Nominal Voltage for library %s is specified to be 0. This may cause problems with delay calculation

### **DESCRIPTION**

Nominal voltage of a library defines the voltage at which the library was characterized. A zero value is unrealistic for this attribute.

# **TECHLIB-436**

### **NAME**

TECHLIB-436

### **SUMMARY**

Attribute 'fanout load' on '%s' %s of cell '%s' is not defined in the library.

#### DESCRIPTION

When a library is loaded, software checks for the presence of fanout\_load attribute on input pins of all cells in library automatically. This message is issued when any of the mentioned attribute is missing.

#### NAME

TECHLIB-437

#### **SUMMARY**

The ecsm\_waveform\_set group in pin '%s' cell '%s' is redefined with different axis points

### **DESCRIPTION**

Number of index and value points defined in the ecsm\_waveform\_set group should be same. If the index points are redefined, the number of redefined index points should be same as the number of index points defined in the original template

# **TECHLIB-452**

#### NAME

TECHLIB-452

#### SUMMARY

The %s capacitances %s table group %s%s%s for %s transition in pin '%s' of cell '%s' are not in the range of min cap value

#### **DESCRIPTION**

For correct calculation of delay value the capacitances value should be more than or equal to min cap value.

#### NAME

TECHLIB-453

#### SUMMARY

The %s capacitances %s table value %s%s%s for %s transition in pin '%s' of cell '%s' are not in the range of pin's capacitances value

#### **DESCRIPTION**

For correct calculation of delay value the capacitances value should be less than or equal to pin's capacitances value.

# **TECHLIB-458**

#### NAME

TECHLIB-458

#### **SUMMARY**

The %s index of ECSM capacitances table %s %s in pin '%s' of cell '%s' is greater than pin's capacitances value

### **DESCRIPTION**

For correct calculation of delay value the capacitances value should be less than or equal to pin's cap value.

#### NAME

TECHLIB-459

#### **SUMMARY**

Appending library '%s' to the previously read library of the same name and nominal PVT. Cell definitions from the previously read library will not be overridden.

### **DESCRIPTION**

This warning is encountered if two library files with the same library name and nominal pvts are specified in the same group (conf file ui\_timelib\* variables) or in the same libset. Two library files with same name and nominal pvts when specified in the same group or in the same libset are considered as two parts of the same library. Any new cells in the subsequent libraries are append to the library already present in the memory. Any cells in the second library file, which are already present in the first library are ignored. To avoid this warning, unify the cells in both the libraries into a single library file.

# **TECHLIB-460**

### NAME

TECHLIB-460

#### SUMMARY

The internal power arcs on the output/inout pin '%s' of cell '%s' does not have the related pin construct. This can cause problem for some application to generate the ecsm power tables.

#### DESCRIPTION

For correct calculation of ecsm power tables related pin information should be provided in the

internal power tables.

# **TECHLIB-461**

### **NAME**

TECHLIB-461

#### SUMMARY

The %s %s on output/inout pin '%s' of cell '%s' is single dimensional. The power arc should be atleast two dimensional for correct generation of ecsm power tables i.e load and slew index point should be defined.

#### DESCRIPTION

For correct calculation of ecsm power the power arc should have atleast two dimensional template defined.

# **TECHLIB-604**

### **NAME**

TECHLIB-604

#### SUMMARY

Operating condition library '%s' not found in library set '%s'. Operating condition library must be part of library set. Check the library provided is internal library name and not the file name. Ignoring operating condition '%s'.

### **DESCRIPTION**

This warning is encountered if the operating condition specified for a delay corner is not present in the timing library set specified for that delay corner. The user can specify the operating condition

Error and Warning Messages

with delay corner information like this - create\_delay\_corner -name xxxx -opcond OpCondName - opcond\_library <OPCONDLIB>. This means that the operating condition for the delay corner needs to be picked up from the specified library. This library needs to be specified in the library set for the delay corner. To avoid this warning make sure to include the library containing the operating condition defined for a delay corner in the library set for that delay corner.

## **TECHLIB-606**

#### NAME

TECHLIB-606

### **SUMMARY**

An inconsistency was found during interpolated library checking of library set '%s'. Cell '%s' found in library '%s', but missing in library '%s'. This can potentially cause issues during delay calculation.

#### DESCRIPTION

This message is issued when inconsistency found due to the cell mismatch between the libraries during interpolation of library set. For example interpolated library set has two libraries and cell\_1 is present in library\_1 but missing in library\_2. To fix the issue, re-characterize the library with appropriate settings, such that cell is present in library.

# **TECHLIB-608**

#### NAME

TECHLIB-608

#### SUMMARY

An inconsistency was found during interpolated library checking of library set '%s'. The timing arc with related pin '%s', timing\_type '%s', timing\_sense '%s' %s of pin '%s' of cell '%s' is present in library '%s' but missing in library '%s'. This can potentially cause issues during delay calculation.

#### DESCRIPTION

This message is issued when inconsistency found due to the timing arc mismatch between the libraries during interpolation of library set. For example interpolated library set has two libararies and timing arc\_1 defined for cell\_1 is present in library\_1 but missing for cell\_1 in library\_2. To fix the issue, re-characterize the library with appropriate settings, such that timing arc is present in library.

# **TECHLIB-609**

#### NAME

TECHLIB-609

#### SUMMARY

Operating condition '%s' not found in library set '%s'. Ignoring operating condition '%s'.

### **DESCRIPTION**

This message is issued when the operating condition name specified with commands 'update\_delay\_corner -opcond' and/or 'create\_delay\_corner -opcond' is not present in library set. To fix the issue, specify valid opcond name.

# **TECHLIB-620**

#### NAME

TECHLIB-620

#### **SUMMARY**

Can not open %s for writing. Check the write permissions and path.

### **DESCRIPTION**

Error and Warning Messages

This message is issued when software cannot open a file for writing. It could be the unix write permission issue.

# **TECHLIB-622**

#### NAME

TECHLIB-622

### **SUMMARY**

Could not read %s. Check the file path and read permissions.

### **DESCRIPTION**

This message is issued when software cannot open a file to read. It could be the unix read permission issue.

# **TECHLIB-700**

#### NAME

TECHLIB-700

#### SUMMARY

Cell %s is not a power switch cell, pin %s is specified switch pin. Ignoring 'switch\_pin' attribute of this pin.

### **DESCRIPTION**

'switch\_pin' attribute specifies the enable pin of a power switch cell. The parent cell of this pin is not a power switch cell. To mark the cell as a power switch define 'switch\_cell\_type:' at the cell level.

#### NAME

TECHLIB-701

#### **SUMMARY**

Invalid axis specified for 'lut\_template' %s. This axis type should be input\_voltage/output\_voltage. Ignoring this template.

### **DESCRIPTION**

This message is issued when the axis type specified for the lut\_template for dc\_current group is invalid. The valid axes are input\_voltage/output\_voltage. Such template will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the valid axis type is defined.

# TECHLIB-702

### NAME

TECHLIB-702

#### SUMMARY

No pg\_pin with name '%s' has been read in the cell '%s'. The attribute '%s' specified for the %s '%s' is being ignored.

#### DESCRIPTION

This message is issued when the pg\_pin specified with related\_power\_pin/related\_ground\_pin/related\_bias\_pin does not exist at cell level. These attributes will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the undefined pg\_pin is not used.

#### NAME

TECHLIB-703

#### **SUMMARY**

Setting '%s' as the default value for the attribute '%s' for the pin '%s' for cell '%s'

#### **DESCRIPTION**

This message is issued when the pg\_pin is not defined for the attributes related\_power\_pin or related\_ground\_pin of cell. In such cases the first pg\_pin group having pg\_type primary\_power/primary\_ground will be considered. To fix the issue, re-characterize the library with appropriate settings, such that the pg\_pin is defined.

# **TECHLIB-704**

### NAME

TECHLIB-704

#### SUMMARY

The voltage\_map attribute with name '%s' referenced by the pg\_pin '%s' in the cell '%s', is absent in the library. The required voltage\_map group needs to be added. This pg\_pin is ignored. Related low power constructs referencing this pg\_pin may not be read correctly.

#### DESCRIPTION

This message is issued when the attribute voltage\_map with voltage\_name referenced by pg\_pin in the cell is not defined in the library. Such pg\_pin will be ignored and any low power constructs referencing this pg\_pin may not work as expected. To fix the issue, re-characterize the library with appropriate settings, such that the attribute volatge\_map referenced by pg\_pin is defined at library

level.

# **TECHLIB-705**

#### NAME

TECHLIB-705

#### SUMMARY

The voltage\_name attribute is missing in the pg\_pin '%s' in the cell '%s'. This is a mandatory attribute for the pg\_pin group. This pg\_pin is ignored. Related low power constructs referencing this pg\_pin may not be read correctly.

#### DESCRIPTION

This message is issued when the attribute voltage\_name is not defined in the pg\_pin group in the cell. The attribute voltage\_name is mandatory attribute. Such pg\_pin will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the volatge\_map in pg\_pin is specified.

## **TECHLIB-707**

#### NAME

TECHLIB-707

### **SUMMARY**

The attribute '%s' is missing in the dc\_current group '%s' in cell '%s'. This may result in incorrect behavior later.

### **DESCRIPTION**

This message is issued when the attributes related switch pin, related pg pin and

Error and Warning Messages

related\_internal\_pg\_pin are not defined for dc\_current group. To fix the issue, re-characterize the library with appropriate settings, such that the attributes should be specified for dc\_current group.

# TECHLIB-708

#### NAME

TECHLIB-708

### **SUMMARY**

No pg\_pin with name '%s' has been read in the cell '%s'. The attribute '%s' for the dc\_current group '%s' is referencing this pg\_pin. Ignoring this attribute value.

#### **DESCRIPTION**

This message is issued when the pg\_pin specified with related\_pg\_pin/related\_internal\_pg\_pin does not exist at cell level for dc\_current group. Such attribute will be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the pg\_pin is defined.

# TECHLIB-709

#### NAME

TECHLIB-709

### **SUMMARY**

No lu\_table\_template with name '%s' has been read in the library '%s'. The dc\_current group is ignored for cell '%s'.

#### DESCRIPTION

This message is issued when lu\_table\_template is specified in cell but not defined at library level. Such dc\_current group will be ignored. To fix the issue, re-characterize the library with appropriate

settings, such that the lu\_table\_template is defined.

# TECHLIB-710

#### NAME

TECHLIB-710

#### SUMMARY

EM group for cell: '%s' and pin: '%s' has negative values in the EM toggle rate group. This group will be ignored.

#### DESCRIPTION

This message is issued when the attribute values specified in the em\_max\_toggle\_rate group is defined with negative value. Such EM group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the defined value is positive.

# TECHLIB-711

### **NAME**

TECHLIB-711

#### SUMMARY

EM group for cell: '%s' and pin: '%s' should have related\_pin/related\_bus\_pin attribute defined for a two dimension EM toggle rate table. This group will be ignored.

#### **DESCRIPTION**

This message is issued when the attributes related\_pin and related\_bus\_pin are not defined for an electromigration group specified with two-dimensional tables. For two-dimensional tables, related\_pin and related\_bus\_pin are mandatory attributes in electromigration group. To fix the

issue, re-characterize the library with appropriate settings, such that the related\_pin and related\_bus\_pin are defined.

### TECHLIB-712

#### NAME

TECHLIB-712

### **SUMMARY**

For the cell '%s', the lowerbound value '%f' is greater than upperbound value '%f' for the attribute '%s'. This is not permitted. The attribute is being ignored.

### **DESCRIPTION**

This message is issued when the lowerbound value of attributes input\_voltage\_range/output\_voltage\_range is greater than the upperbound value of these attributes at cell level. To fix the issue, re-characterize the library with appropriate settings, such that the lowerbound/upperbound values are specified correctly.

### TECHLIB-713

### NAME

TECHLIB-713

### **SUMMARY**

For the pin '%s' of cell '%s', the lowerbound value '%f' is greater than upperbound value '%f' for the attribute '%s'. The attribute is being ignored

### **DESCRIPTION**

This message is issued when the lowerbound value of input\_voltage\_range and

Error and Warning Messages

output\_voltage\_range is greater than upperbound value for the pin of cell. To fix the issue, recharacterize the library with appropriate settings, such that the lowerbound value should be specified lower than the upperbound value.

# TECHLIB-715

#### NAME

TECHLIB-715

#### SUMMARY

Power\_rail '%s' specified in rail\_connection '%s' of cell '%s' is not present in power\_supply group. This rail connection will be ignored.

#### **DESCRIPTION**

This message is issued when the attribute power\_rail is specified in rail\_connection of the cell but not specified in the power\_supply group. For example, Power\_rail 'VDD3' is specified in rail\_connection 'PV3' of cell but is not present in power\_supply group. Such rail\_connection will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the power\_rail should be specified in both i.e. rail\_connection as well as power\_supply\_group.

# TECHLIB-716

### **NAME**

TECHLIB-716

### **SUMMARY**

Number of primary outputs specified as the bundle members do not match with the number of bits in the sequential bank for cell '%s'. The bundle definition needs to be checked.

### **DESCRIPTION**

Error and Warning Messages

This message is issued when there is a mismatch in bundle width and number of bits in the sequential bank. To fix the issue, re-characterize the library with appropriate settings, such that the number of bits should match with bundle width.

# TECHLIB-800

#### NAME

TECHLIB-800

#### SUMMARY

For the timing arc of pin '%s' of cell '%s', the value '%s' specified for the user defined attribute domino\_arc\_typeis invalid. This attribute is being ignored.

#### **DESCRIPTION**

This message is issued when the value defined for domino\_arc\_type for the timing arc of pin of cell for user defined group is invalid. The valid values of domino\_arc\_type are clock\_precharge, clock\_eval and data\_eval. The attribute will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the valid value is defined.

# TECHLIB-802

### **NAME**

TECHLIB-802

#### SUMMARY

The vector template '%s' for the vector group number '%d' specified in '%s' group of the timing arc in pin '%s' of cell '%s' is not defined. The CCS data for this current\_rise/fall group is ignored

### **DESCRIPTION**

Error and Warning Messages

This message is issued when an undefined template is used in vector groups output\_current\_fall and output\_current\_rise. Such output\_current group would be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the template used is defined in output current group.

# TECHLIB-804

#### NAME

TECHLIB-804

#### **SUMMARY**

Invalid specification for input\_net\_transition axis for the vector group number '%d' specified in '%s' group of the timing arc in pin '%s' of cell '%s'. Only a single slew value is expected. The CCS data for this output current rise/fall group is ignored.

#### **DESCRIPTION**

This message is issued when the input\_net\_transition axis for the vector group specified in output\_current\_fall and output\_current\_rise has more than one value. The axis can have only single value. The CCS data for output\_current\_fall and output\_current\_rise group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that input\_net\_transition for output\_current group should have only single value.

# **TECHLIB-805**

### **NAME**

TECHLIB-805

### **SUMMARY**

Invalid specification for total\_output\_net\_capacitance axis for the vector group number '%d' specified in '%s' group of the timing arc in pin '%s' of cell '%s'. Only a single cap value is expected. The CCS data for this output current rise/fall group is ignored

#### DESCRIPTION

This message is issued when the total\_output\_net\_capacitance axis for the vector group specified in output\_current\_fall and output\_current\_rise has more than one value. The axis can have only single value. The CCS data for output\_current\_fall and output\_current\_rise group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that total\_output\_net\_capacitance for output\_current group should have only single value.

# **TECHLIB-806**

#### NAME

TECHLIB-806

#### SUMMARY

Invalid axis specified for the vector group number '%d' specified in '%s' group of the timing arc in pin '%s' of cell '%s'. The CCS data for this output current rise/fall group is ignored

#### **DESCRIPTION**

This message is issued when the axes specified for the vector group output\_current\_fall and output\_current\_rise are invalid. The valid axes are input\_net\_transition and total\_output\_net\_capacitance. Therefore CCS data will be ignored for this group. To fix the issue, re-characterize the library with appropriate settings, such that the defined axes should be valid.

# **TECHLIB-807**

### **NAME**

TECHLIB-807

#### SUMMARY

The axis '%s' is missing for the vector group number '%d' specified in '%s' group of the timing arc in pin '%s' of cell '%s'. The CCS data for this output current rise/fall group is ignored

#### DESCRIPTION

This message is issued when the axis input\_net\_transition or total\_output\_net\_capacitance is missing for the vector group output\_current\_fall and output\_current\_rise of the timing arc in pin of the cell. The CCS data for this group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the axes should be specified for output\_current\_fall and output\_current\_rise.

# **TECHLIB-808**

### NAME

TECHLIB-808

#### SUMMARY

The number of current values is not equal to the number of time index points for the vector group number '%d' specified in '%s' group of the timing arc in pin '%s' of cell '%s'. The CCS data for this output current rise/fall group is ignored

#### DESCRIPTION

This message is issued when the number of current values is not equal to the time index points specified in the output\_current\_fall and output\_current\_rise of the timing arc in pin of cell. The CCS data for this group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the number of time index points should match with the current values for output current fall and output current rise.

# TECHLIB-809

### **NAME**

TECHLIB-809

Error and Warning Messages

#### **SUMMARY**

Time values of the vector group number '%d' specified in '%s' group of the timing arc in pin '%s' of cell '%s', should monotonically increase.

#### **DESCRIPTION**

This message is issued when the time values specified in the vector groups output\_current\_fall and output\_current\_rise of the timing arc in pin of cell do not monotonically increase. To fix the issue, recharacterize the library with appropriate settings, such that the time values for output\_current\_fall and output\_current\_rise groups vector are monotonic.

### TECHLIB-810

#### **NAME**

TECHLIB-810

#### SUMMARY

Both the '%s' groups must be specified for the timing arc in pin '%s' of cell '%s'. The receiver capacitance data for this timing arc is ignored

#### **DESCRIPTION**

This message is issued when any of the receiver\_capacitance1\_rise, receiver\_capacitance1\_fall, receiver\_capacitance2\_rise, receiver\_capacitance2\_fall is missing for the timing arc in pin of the cell of receiver\_capacitance group. All of them must be defined if any one of them is defined. Such receiver\_capacitance data for this timing arc will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the receiver\_capacitance group is defined correctly.

#### NAME

TECHLIB-811

#### **SUMMARY**

Undefined template '%s' for the '%s' group specified for the timing arc in pin '%s' of cell '%s'. The receiver capacitance data for this timing arc is ignored.

### **DESCRIPTION**

This message is issued when an undefined template is used in receiver\_capacitance\_rise and receiver\_capacitance\_fall groups. Such receiver\_capacitance data for this timing arc would be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the template used is defined in library.

### TECHLIB-812

#### NAME

TECHLIB-812

#### SUMMARY

The number of cap values in the '%s' group specified in the timing arc in pin '%s' of cell '%s' is not equal to the number of index points specified. The receiver capacitance data for this timing arc is ignored.

### **DESCRIPTION**

This message is issued when the number of cap values in the receiver\_capacitance\_rise1/receiver\_capacitance\_rise2/receiver\_capacitance\_fall1/receiver\_capacitance fall2 specified in the timing arc in pin of cell is not equal to the number of index points. Such

Error and Warning Messages

receiver\_capacitance data for this timing arc will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the number of cap values and index points match.

## TECHLIB-814

#### NAME

TECHLIB-814

### **SUMMARY**

Number of vector groups(%d) specified in '%s' group of timing arc in pin '%s' of cell '%s' do not match unique slew/load(%dx%d) pair value. This output current group will be ignored.

#### **DESCRIPTION**

This message is issued when there is mismatch in the number of vector groups and unique slew/load pair. For this output current group, conversion of the CCS vector groups to ECSM waveform groups is ignored for timing analysis. This may impact delay calculation accuracy. Recharacterize the library such that output current group is specified correctly.

## **TECHLIB-816**

#### NAME

TECHLIB-816

### **SUMMARY**

The receiver\_capacitance group specified over the output pin '%s' of cell '%s' is ignored.

### **DESCRIPTION**

This message is issued when the receiver\_capacitance group is specified on the output pin of cell. The receiver\_capacitance group can be defined on input pin or inout pin at pin level. The

Error and Warning Messages

receiver\_capacitance group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the receiver\_capacitance group is not specified on output pin of the cell.

# TECHLIB-817

#### NAME

TECHLIB-817

#### SUMMARY

The receiver capacitance %s groups are missing in the receiver capacitance group %s specified for %s of cell '%s'.

#### **DESCRIPTION**

This message is issued when either of the rise group (receiver\_capacitance1\_rise/receiver\_capacitance2\_rise) or fall group (receiver\_capacitance1\_fall/receiver\_capacitance2\_fall) is missing for pin in the receiver\_capacitance group for a 'when' condition. If there are duplicate 'when' conditions, this data must be present for at least one of the 'when' condition. In such case, other receiver\_capacitance group with same 'when' condition need not have all 4 groups. They can just have either rise or fall groups. To fix the issue, re-characterize the library with appropriate settings, such that the receiver\_capacitance group is defined correctly.

### TECHLIB-818

### **NAME**

TECHLIB-818

### **SUMMARY**

Only input\_net\_transition axis is expected for '%s' group defined within receiver\_capacitance group specified on the pin '%s' of cell '%s'. This receiver capacitance group is ignored.

#### DESCRIPTION

This message is issued when the invalid axis is defined for receiver\_capacitance1\_rise/receiver\_capacitance2\_rise/receiver\_capacitance1\_fall/receiver\_capacitance2\_fall on the pin of the cell for receiver\_capacitance group. The valid axis is only input\_net\_transition. Such receiver\_capacitance group will be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the input\_net\_transition axis should be specified for receiver\_capacitance group.

# TECHLIB-819

#### NAME

TECHLIB-819

#### **SUMMARY**

The number of cap values is not equal to the number of time index points for the '%s' group specified in pin '%s' of cell '%s'. This receiver\_capacitance group is ignored.

#### DESCRIPTION

This message is issued when the number of capacitance value is specified for receiver\_capacitance\_rise1/receiver\_capacitance\_rise2/receiver\_capacitance\_fall1/receiver\_capacitance\_fall2 are not equal to the number of time index points. Such receiver\_capacitance group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the number of cap value should be equal to the number of time index points.

## TECHLIB-820

### **NAME**

TECHLIB-820

Error and Warning Messages

#### **SUMMARY**

Undefined template '%s' for the '%s' group specified for the pin '%s' of cell '%s'. The receiver capacitance data for this pin is ignored.

#### **DESCRIPTION**

This message is issued when an undefined template is used in receiver\_capacitance1\_rise/receiver\_capacitance2\_rise/ receiver\_capacitance1\_fall/receiver\_capacitance2\_fall groups. Such receiver\_capacitance data for this pin would be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the template used is defined in library.

# **TECHLIB-827**

#### NAME

TECHLIB-827

#### SUMMARY

The support to threshold construct in ecsm capacitance group has be provided post ECSM VERSION 1.2. The library ECSM VERSION is %s, therefore the threshold construct will be ignored for the ecsm capacitance group in pin '%s' and cell '%s'.

#### DESCRIPTION

This message is issued when threshold\_pct construct in ecsm\_capacitance group is specified in library but the ECSM VERSION<1.2. Threshold construct will be ignored for the ecsm capacitance group.

#### NAME

TECHLIB-828

#### **SUMMARY**

The 'pulse\_generator' and 'pulse\_generator\_polarity' attributes are obsolete, as specified over the pin '%s' of the cell '%s'. The 'pulse\_clock' attribute should be used instead.

#### **DESCRIPTION**

This message is issued when the attributes pulse\_generator and pulse\_generator\_polarity are specified on the pins of the cell. The pulse\_clock attribute should be defined instead of pulse\_generator and pulse\_generator\_polarity, as they are discontinued now. To fix the issue, recharacterize the library with appropriate settings, such that the pulse\_clock should be defined.

### TECHLIB-904

#### NAME

TECHLIB-904

#### SUMMARY

Cell '%s' has both edge and combinational arcs between pins '%s' and '%s'. Such arcs can cause problems in the timing analysis flow.

#### DESCRIPTION

For correct timing analysis both combinational and edge arcs should not be present between two pins.

#### NAME

TECHLIB-905

#### **SUMMARY**

Found a function attribute specified on pin '%s' with 'interface\_timing' attribute set to true on cell '%s'. As per the liberty standard, a function attribute should not be specified for a cell which has interface timing attribute set to true. This function attribute will be ignored.

### **DESCRIPTION**

When 'interface\_timing: true', the cell is regarded as a complex black box cell instead of a regular standard cell and 'function' attribute should not be specified for a black box cell. Re-characterize the library such that the correct attribute is set on the cell.

# TECHLIB-906

### **NAME**

TECHLIB-906

### **SUMMARY**

Input Timing Library '%s' already loaded in the session. write\_ldb command will not work for this library.

### **DESCRIPTION**

For correct ldb generation write\_ldb command should be invoked in a separate session.

#### NAME

TECHLIB-908

#### **SUMMARY**

The ccsn\_last\_stage group is present on the timing arc, but the ccsn\_first\_stage is not present on %s and cell '%s'. The ccsn\_last\_stage group can be present on a timing arc only when cssn first stage group is present. The ccsn\_last\_stage group will be ignored.

### **DESCRIPTION**

The timing group can contain a ccsn\_last\_group only when ccsn\_first\_stage group is present. Otherwise it can cause problems during noise analysis.

# TECHLIB-914

### **NAME**

TECHLIB-914

#### SUMMARY

The vector template '%s' for the vector group number '%d' specified in '%s' group on pin '%s' of cell '%s' is not defined. The CCS Noise data for this %s group is ignored

#### DESCRIPTION

This message is issued when the vector template of vector group output\_voltage\_fall and output\_voltage\_rise is not defined. Therefore CCS noise data for this group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the vector template used for output voltage fall and output voltage rise groups is defined in library.

#### NAME

TECHLIB-915

#### **SUMMARY**

Invalid axis '%s' specified for the vector group number '%d' specified in '%s' group on pin '%s' of cell '%s'. The CCS Noise data for this %s group is ignored

### **DESCRIPTION**

This message is issued when the axis type specified for the vector group output\_voltage\_rise/output\_voltage\_fall is invalid. The valid axes are input\_net\_transition and total\_output\_net\_capacitance. Such ccs noise data will be ignored for this group. To fix the issue, re-characterize the library with appropriate settings, such that the valid axis type is defined.

### TECHLIB-916

#### **NAME**

TECHLIB-916

#### **SUMMARY**

The number of time index points does not match with the voltage values of vector group number '%d' specified in '%s' group on pin '%s' of cell '%s'. The CCS Noise data for this %s group is ignored

### DESCRIPTION

This message is issued when the voltage value of vector groups propagated\_noise\_high and propagated\_noise\_low of a cell do not match with the number of time index points. Therefore CCS noise data for this group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the number of time index points should match with the voltage values of vector

group propagated\_noise\_high and propagated\_noise\_low.

# **TECHLIB-919**

### **NAME**

TECHLIB-919

#### SUMMARY

The pin level %s group(s) found on %s %s of cell '%s'. The pin level %s group(s) are expected only on %s or inout pins, therefore the %s group(s) will be ignored.

#### DESCRIPTION

This message is issued when the ccsn\_first\_stage group is defined at pin level on output pin or the ccsn\_last\_stage is defined on input pin of a cell. The ccsn\_first\_stage group can be defined only on an input pin or inout pin and the ccsn\_last\_stage can be defined only on an output pin or inout pin. If ccsn group is not defined at proper pin then they will be ignored. To fix the issue, re-characterize the library with appropriate settings.

### TECHLIB-921

#### NAME

TECHLIB-921

### **SUMMARY**

Invalid number of index\_%d points specified for the vector group number '%d', in '%s' group on pin '%s' of cell '%s'. Only single value is expected for this index. The CCS Noise data for this %s group is ignored.

### **DESCRIPTION**

Error and Warning Messages

This message is issued when the vector group output\_voltage\_fall and output\_voltage\_rise of a cell are not specified with correct number of index points. The axes input\_net\_transition/total\_output\_net\_capacitance i.e. index\_1 and index\_2 can have only single value for the vector group output\_voltage\_fall and output\_voltage\_rise. To fix the issue, recharacterize the library with appropriate settings, such that the number of index points should be specified correctly for output\_voltage\_fall and output\_voltage\_rise groups.

## TECHLIB-922

#### NAME

TECHLIB-922

#### SUMMARY

The stage\_type of ccsn\_\*\_stage group does not match with the pin's driver type '%s' of cell '%s'. The stage\_type of CCSN group must match with the pin's driver type. This ccsn\_\*\_stage group will therefore be ignored.

### **DESCRIPTION**

This message is issued when the ccsn\_first\_stage and ccsn\_last\_stage groups are not defined with correct driver type. The valid values are pull\_up and pull\_down. Therefore ccsn\_stage group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the correct driver type should be defined.

## TECHLIB-924

### **NAME**

TECHLIB-924

#### SUMMARY

Unable to read the LDB file because it has been compiled with a newer version '%s' of the software than you are currently using. Either recompile it with a compatible version '%s' of the software, or

use the equivalent Liberty (.lib) format.

#### DESCRIPTION

Cadence supports backward compatibility between newer versions of the software and LDB timing libraries compiled using older releases, but the reverse is not possible. The reason is that whenever a new syntax is added or adopted from the Liberty library specification, the binary representation of that data in the form of the LDB file will change, and older versions of the software will not be able to interpret the new library syntax properly. To use this library data, you must either recompile the library with a compatible version of the software, or use the uncompiled (.lib) version of the Liberty library.

## TECHLIB-925

#### **NAME**

TECHLIB-925

### **SUMMARY**

Input library file '%s' contains more than one library definition. This is not supported for LDB conversion. Separate the library definitions to individual files for converting to individual LDBs. Output LDB '%s' not written.

### **DESCRIPTION**

This message is issued when a single file contains more than one library definition. LDB conversion is not possible for such libraries because tool will read only first library and rest will be ignored.

# **TECHLIB-935**

### NAME

TECHLIB-935

Error and Warning Messages

#### SUMMARY

No indices specified for the ecsm capacitance in pin %s of cell %s. Ignoring ecsm\_capacitance defined in the pin.

#### **DESCRIPTION**

The index\_1 attribute needs to be defined for ecsm\_capacitance. If it is not defined, the ecsm\_capacitance information will be ignored

# TECHLIB-1001

### NAME

TECHLIB-1001

#### **SUMMARY**

Multiple normalized driver waveform groups without a driver\_waveform\_name were found. The latest definition would overwrite the earlier ones.

### **DESCRIPTION**

This message is issued when the normalized driver waveform group is defined multiple times but driver waveform name is absent. The latest definition will be retained and rest will be ignored.

# TECHLIB-1002

#### NAME

TECHLIB-1002

### **SUMMARY**

Error and Warning Messages

Mismatch found in the number of index points for '%s' in the normalized\_driver\_waveform and its template. The normalized\_driver\_waveform data at the group level will be used.

#### DESCRIPTION

This message is issued when the number of index points are different in the normalized\_driver\_waveform group and its template at the library level. Data specified in the template will be ignored and data specified in the normalized driver waveform group will be used.

## TECHLIB-1003

#### **NAME**

TECHLIB-1003

#### SUMMARY

The number of values in the normalized\_driver\_waveform group does not match the number of index points. This could cause delay calculation issues and should be corrected

### **DESCRIPTION**

This message is issued when there is discrepancy between the number of values (M x N) in the normalized\_driver\_waveform group and number of index points M and N. This may result in a loss of accuracy during analysis.

### TECHLIB-1004

#### NAME

TECHLIB-1004

#### **SUMMARY**

The normalized driver waveform group is specified with only one axis. This may result in accuracy

loss during analysis.

## DESCRIPTION

This message is issued when the normalized\_driver\_waveform is specified with only one axis i.e. either input\_net\_transition or normalized\_voltage only is specified as axis. This may cause inaccuracy in timing analysis. To fix the issue, re-characterize the library with appropriate settings, such that the normalized\_driver\_waveform should be specified with both axes.

# TECHLIB-1005

# **NAME**

TECHLIB-1005

# **SUMMARY**

The normalized\_driver\_waveform '%s' specified as '%s' for cell '%s' was not found in the library

# **DESCRIPTION**

This message is issued when the normalized\_driver\_waveform is specified as driver\_waveform/driver\_waveform\_rise/driver\_waveform\_fall for a cell but is not defined in library. To fix the issue, re-characterize the library with appropriate settings, such that the library does not use undefined normalized\_driver\_waveform.

# TECHLIB-1006

# NAME

TECHLIB-1006

# **SUMMARY**

The normalized driver waveform '%s' specified as '%s' for pin '%s' in cell '%s' was not found in the

library

## DESCRIPTION

This message is issued when the normalized\_driver\_waveform is specified as driver\_waveform/driver\_waveform\_rise/driver\_waveform\_fall for a pin in a cell but is not found in library. To fix the issue, re-characterize the library with appropriate settings, such that the library does not use undefined normalized driver waveform.

# **TECHLIB-1007**

# **NAME**

TECHLIB-1007

### SUMMARY

Incorrect axis type specified in the template '%s' for driver waveform. The template and all normalized\_driver\_waveform groups using this template would be ignored.

# **DESCRIPTION**

This message is issued when the axis type is specified in the normalized\_driver\_waveform group template is not correct. The valid axes are input\_net\_transition and normalized\_voltage. The template and all normalized\_driver\_waveform groups using this template would be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the template should be specified with correct axis type.

# TECHLIB-1010

# **NAME**

TECHLIB-1010

Error and Warning Messages

## SUMMARY

Template of the name '%s' was not found in the library. The driver waveform group at (line no: %d) would be ignored.

### **DESCRIPTION**

This message is issued when an undefined template is used in driver waveform group. Such driver waveform group would be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the template used is defined in library.

# TECHLIB-1051

### NAME

TECHLIB-1051

# **SUMMARY**

Library reading has failed due to an error that occurred in one of the libraries to be merged. Refer to the previous messages issued to find the details of the issue in the library.

# **DESCRIPTION**

This message is issued when library reading is failed due to some error in library. Refer to the previous messages issued to find the details of the issue. For example: if there is some syntax error then library reading will be failed.

# TECHLIB-1056

### NAME

TECHLIB-1056

## SUMMARY

Missing cell:%s in 'library:%s' but present in 'library:%s'. The libraries cannot be used for merging.

# **DESCRIPTION**

This message is issued when there is discrepancy between the nominal PVT of two timing libraries having same library name in library header. To fix the issue, re-characterize the library with appropriate settings, such that the library should be specified with different name.

# TECHLIB-1064

# NAME

TECHLIB-1064

# **SUMMARY**

Missing internal pin '%s' in cell '%s' of library '%s' but present in library '%s'.

## **DESCRIPTION**

This message is issued when the internal pin is missing in a cell of one library but specified in other library.

# TECHLIB-1068

# NAME

TECHLIB-1068

# **SUMMARY**

Identified number of pins mismatch for cell '%s' between library '%s' and '%s'

## DESCRIPTION

This message is issued when there is mismatch in number of pins for cell between the libraries. To fix the issue, re-characterize the library with appropriate settings, such that the number of pins should match for cell between libraries.

# TECHLIB-1069

# NAME

TECHLIB-1069

# **SUMMARY**

The number of cells are more than one in library '%s'. The ETM libraries should have only one cell. The libraries cannot be used for merging.

# **DESCRIPTION**

This message is issued when the ETM libraries is having more than one cell. Multiple cells are not allowed in ETM libraries. Such libraries cannot be merged.

# TECHLIB-1070

### **NAME**

TECHLIB-1070

### SUMMARY

No AOCV libraries have been read.

# **DESCRIPTION**

This message is issued when AOCV libraries have not been loaded in the session. Use

create\_library\_set -aocv command to load AOCV libraries.

# TECHLIB-1071

### NAME

TECHLIB-1071

### SUMMARY

Identified pin capacitance mismatch '%f' and '%f' in pin '%s', for cell '%s', between libraries '%s' and '%s'. The libraries cannot be used for merging.

## DESCRIPTION

This message is issued when there is discrepancy between the pin capacitance of a cell pin in two libraries. This may not permit the merging of these two libraries. To fix the issue, re-characterize the library with appropriate settings, such that there is no discrepency in pin capacitance across two libraries.

# TECHLIB-1073

## NAME

TECHLIB-1073

# **SUMMARY**

Identified mismatch in %s definition in pin '%s', for cell '%s', between libraries '%s and '%s'. The %s definition will be ignored in merged library.

### DESCRIPTION

This message is issued when there is discrepancy between the definition of function and three\_state function in a pin of a cell of two libraries. To fix the issue, re-characterize the library with

appropriate settings, such that the library should be specified with different name.

# TECHLIB-1076

### NAME

TECHLIB-1076

### SUMMARY

The vector template '%s' for the vector group number '%d' of cell '%s' is not defined in pg\_current group. The CCS power data in this group is ignored

## DESCRIPTION

This message is issued when the vector template for the vector group of cell is not defined in pg\_current group. The CCS power data in this group will be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the template name should be defined for pg\_current group.

# TECHLIB-1077

## **NAME**

TECHLIB-1077

# SUMMARY

Invalid specification for input\_net\_transition/total\_output\_net\_capacitance axis for the vector group '%s' specified in pg\_current group. Only a single slew/cap value is expected. The CCS Power data for this pg\_current group is ignored.

# **DESCRIPTION**

This message is issued when the input\_net\_transition/total\_output\_net\_capacitance indices for the

Error and Warning Messages

vector group specified in pg\_current group have more than one value. These attributes can have only single value. The CCS Power data for such pg\_current group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that input net transition/total output net capacitance in pg\_current group have only single value.

# TECHLIB-1078

### NAME

TECHLIB-1078

# **SUMMARY**

The number of current values is not equal to the number of time index points for the vector group number '%d' specified in pg\_current. The CCS Power data for this pg\_current group is ignored

## **DESCRIPTION**

This message is issued when the number of current values in CCS power data for pg\_current group is not matched with the number of time index points. CCS power data for such pg\_current group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the number of current values is equal to the number of time index points.

# TECHLIB-1103

# **NAME**

TECHLIB-1103

# **SUMMARY**

The number of pins in input\_map for the pin '%s' of cell '%s' doesn't match the number of inputs given in the state table. This may cause issues in function inference from state table.

# DESCRIPTION

Error and Warning Messages

This message is issued when there is a discrepancy between the number of inputs given in the state table and number of pins in input\_map for the pin of the cell. This may cause issues in function inference from state table. To fix the issue, re-characterize the library with appropriate settings, such that the number of inputs in the state table is equal to the number of pins in input\_map.

# TECHLIB-1104

### NAME

TECHLIB-1104

### SUMMARY

Time values of the %s specified in '%s' group of cell '%s', should monotonically increase.

## DESCRIPTION

This message is issued when the time values specified in the ccs\_power vector group of a cell do not monotonically increase. To fix the issue, re-characterize the library with appropriate settings, such that the time value for the ccs\_power vector group are monotonic.

# TECHLIB-1105

# NAME

TECHLIB-1105

# **SUMMARY**

Vector groups specified in '%s' group of cell '%s' are not defined for every slew and load pair value. This may lead to undesirable analysis results.

# **DESCRIPTION**

This message is issued when vector group is not defined for each load and slew pair. The vector

Error and Warning Messages

group should be defined for each slew and load pair and number of vector group should match with slew \* cap value pair. To fix the issue, re-characterize the library with appropriate settings such that corresponding vector groups are defined for each slew and load pair.

# TECHLIB-1106

### NAME

TECHLIB-1106

### SUMMARY

The operating condition '%s' with PVT ('%.4f', '%.4f', '%.4f') already exists in the library '%s'. The new operating condition PVT ('%.4f', '%.4f', '%.4f') will be ignored.

## DESCRIPTION

This message is issued when an operating conditions with pvt values is specified but a previous operating condition with same PVT definition already exists in the library. The new operating conditions with PVT values will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that same PVT conditions are not specified in two different operating conditions.

# TECHLIB-1107

# **NAME**

TECHLIB-1107

## SUMMARY

The phase %d is not supported for retention pin for cell %s, pin %s. The retention pin would be ignored.

# **DESCRIPTION**

Error and Warning Messages

Unrecognized phase/retention\_disable\_value for state retention power gating pin/retention pin. The cell cannot be used for SRPG synthesis

# TECHLIB-1108

## NAME

TECHLIB-1108

# SUMMARY

No normalized driver waveform found in this library. This can cause accuracy issues during delay calculation.

# **DESCRIPTION**

The normalized driver waveform is required for higher precision during delay calculation.

# TECHLIB-1109

### NAME

TECHLIB-1109

### SUMMARY

Nominal Condition '%s' is not defined in timing library. Assuming default value %.3f. Setting this attribute is recommended as it can impact timing and SI results.

## **DESCRIPTION**

This message is issued when the nominal condition PVT is not defined in the timing library and thus it assumes the default values. The default value of Process is 1, default value of voltage is 5 and default value of temperature is 25. The nominal condition attributes should be set appropriately.

## NAME

TECHLIB-1114

### **SUMMARY**

There is mismatch between '%s' tables for '%s' arc defined on pin '%s' of cell '%s' for mode '%s' specified with command merge model timing.

## **DESCRIPTION**

This message is issued when there is mismatch in rise\_constarint/fall\_constraint tables defined for minimum\_pulse\_width/minimum\_period arc while merging the libraries using command 'merge\_model\_timing' for a specified mode. To fix the issue, specified the libraries with consistent tables.

# TECHLIB-1115

### **NAME**

TECHLIB-1115

### SUMMARY

Multiple definitions of the power\_rail '%s' for the power\_supply group at line %d. The last definition would be retained

## DESCRIPTION

This message is issued when power\_rail for power\_supply group is defined more than once. The same attribute cannot have multiple definition. Last definition will be retained and rest will be ignored.

## NAME

TECHLIB-1116

### SUMMARY

Multiple definitions of the voltage '%s' for the voltage\_map at line %d. The first definition would be retained

## **DESCRIPTION**

This message is issued when a supply voltage is defined more than once with different values in voltage\_map. The same voltage cannot have multiple definition. First definition will be retained and rest will be ignored.

# TECHLIB-1117

# **NAME**

TECHLIB-1117

## SUMMARY

Power supply group at line %d has no default\_power\_rail attribute defined.

## **DESCRIPTION**

This message is issued when the attribute default\_power\_rail is not present for power supply group. To fix the issue, re-characterize the library with appropriate settings, such that this attribute is specified for power supply group.

## NAME

TECHLIB-1118

# **SUMMARY**

Cell %s is an Isolation cell, pin %s is specified level shifter %s pin. Ignoring '%s' attribute of this pin.

# **DESCRIPTION**

'level\_shifter\_enable\_pin' and level\_shifter\_data\_pin attribute specifies the enable pin and data pin of a level shifter cell respectively. The parent cell of this pin is not a level shifter cell. To mark the cell as a level shifter cell mention 'is level shifter: true' at the cell level.

# TECHLIB-1119

### NAME

TECHLIB-1119

## **SUMMARY**

Conflicting definition of user defined %s attribute %s. It is defined as %s in present library and as %s in previous library '%s'.

## **DESCRIPTION**

This message is issued when there is conflict between the attributes defined by the user in the present library and defined in the previous library. To fix the issue, re-characterize the library with appropriate settings, such that there should not be mismatch between the attributes across libraries.

## NAME

TECHLIB-1120

### SUMMARY

Input map for bus/bundle %s for cell %s is not defined on all pins.

# **DESCRIPTION**

This message is issued when the input map for bus/bundle is not defined on all pins of a bus/bundle. To fix the issue, re-characterize the library with appropriate settings, such that the input map for bus/bundle should be defined on all pins at cell level.

# TECHLIB-1123

#### NAME

TECHLIB-1123

## SUMMARY

Identified multiple definitions of the related\_pin for the '%s' group defined on pin '%s' of cell '%s'. The first definition would be retained and rest will be ignored.

## **DESCRIPTION**

This message is issued when related\_pin is specified more than once for max\_trans and max\_cap groups defined at pin level. The first definition would be retained and rest will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the related\_pin is defined correctly.

# NAME

TECHLIB-1131

## SUMMARY

The normalized driver waveform '%s' will be extrapolated to span the voltage range 0 to 1.

# **DESCRIPTION**

This message is issued when the voltage range of normalized\_driver\_waveform is specified within the range of 0 to 1 but does not span fully from 0 to 1. In such cases, tool will extrapolate to span the voltage from 0 to 1. To fix the issue, re-characterize the library with appropriate settings, such that the normalized driver waveform should be defined with appropriate voltage range.

# TECHLIB-1135

# NAME

TECHLIB-1135

## SUMMARY

Identified multiple spatial table for %s '%s'. The first table would be retained.

## **DESCRIPTION**

This message is issued when the multiple spatial tables are defined at cell level. The first definition will be considered and rest will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the spatial tables are defined correctly.

## NAME

TECHLIB-1141

### SUMMARY

Cell '%s' redefined in library. The first cell definition will be retained, rest will be ignored.

# **DESCRIPTION**

Cell re-definitions in a library is not allowed. In case of multiple definitions for the same cell name, only the first definition is retained and rest are ignored. In order to retain all cell definitions, the cell names must be unique. Modify the cell definition in library by changing name of cells such that all the cells are distinct

# TECHLIB-1142

# NAME

TECHLIB-1142

## SUMMARY

No 'values' attribute found for normalized driver waveform group at line number %d. This is a mandatory attribute for normalized waveform group. This group will be ignored.

## DESCRIPTION

The normalized driver waveform group should have mandatory attribute 'values'. If this attribute is not present the characterized library is incorrect and the library should be re-characterized.

## NAME

TECHLIB-1143

### **SUMMARY**

The pin '%s' in the statetable/input\_map is not defined in the cell '%s'. The statetable will be ignored. Fix incorrect pin names or any special characters in the statetable to rectify the error.

# **DESCRIPTION**

The pin names defined in the input\_map or statetable should be the same as defined in the library cell definition. Also, per liberty statetable syntax, pin names are identified based on white space delimiter. Any special characters, if any in the statetable, separated by white spaces could be also be identified as pins. To rectify the Error, correct the incorrect pin names or remove special characters from the statetable, if any.

# TECHLIB-1144

#### NAME

TECHLIB-1144

# **SUMMARY**

The pg pin '%s' has also been defined as pin in cell '%s'. The pin will be retained, but the pg\_pin will be ignored. Correct the pin names in library cell definition to fix the error.

# **DESCRIPTION**

This error is displayed when both pg\_pin and pin of a cell defined in the library, have the same name. The cell definition in the library must have unique pin names for pin and pg\_pin for a cell. Due to this error, the software will retain the pin and ignore the pg\_pin in the cell definition. The pin

Error and Warning Messages

name with pg\_pin attribute will be ignored. This may lead to issues during design load and analysis, especially if the design includes pg information.

# TECHLIB-1145

## NAME

TECHLIB-1145

# SUMMARY

Message with id '%d' not found.

## DESCRIPTION

This message is issued when valid message id is not specified.

# TECHLIB-1146

## NAME

TECHLIB-1146

## **SUMMARY**

Mismatch between values of library global(s) set during LDB reading versus those set during LDB compilation. For a detailed list of library global settings, you can use the 'check\_ldb\_version' command. To avoid this warning, recompile LDBs with the same library global values

## **DESCRIPTION**

This warning is issued when the library global settings, set during LDB compilation, do not have the same values as those set while reading LDBs. To rectify this issue, you need to recompile the LDBs with the same library global setting(s). The recommended settings for LDB compilation are the software default settings.

### NAME

TECHLIB-1147

## SUMMARY

Equivalent waveform model and/or waveform propagation mode is enabled for delay calculation during analysis. This requires normalized driver waveform (NDW) information in timing libraries. The timing libraries used in the design are missing NDW information. The software will autogenerate the NDW information to be used for analysis.

### DESCRIPTION

The software auto-generates the NDW waveform by weighted mean of linear and exponential waveform. The default value of weighted mean is 0.5 and it can be controlled using the 'timing normalized driver waveform weight factor' global variable.

# TECHLIB-1148

### NAME

TECHLIB-1148

## **SUMMARY**

Found redefined indices in the ecsm\_capacitance group of timing arc section of cell '%s'. Indices cannot be redefined in the ecsm\_capacitance group of timing arc section as this group would use the indices of transition table. This can cause issues during delay calculation.

# **DESCRIPTION**

In timing arc section, the ECSM Capacitance group defined is 2 dimensional and would use the

Error and Warning Messages

indices of transition table. The ECSM capacitance are not expected to have index\_1 or index\_2 defined in this group of timing arc section.

# TECHLIB-1150

## NAME

TECHLIB-1150

# SUMMARY

The template '%s' for dc\_current group on pin '%s' of cell '%s' is not defined. The 'dc\_current' group will be ignored.

# **DESCRIPTION**

The dc\_current group should have a template defined at library level otherwise group will be ignored. To rectify the problem define the template at library level.

# TECHLIB-1151

# **NAME**

TECHLIB-1151

### SUMMARY

Invalid axis '%s' specified for '%s' group referred by template name '%s' on pin '%s' of cell '%s'. This group is ignored.

# DESCRIPTION

The valid index name needs to be specified for group template. To rectify the problem change the variable\_1 or variable\_2 or variable\_3 to these valid values in the template group.

## NAME

TECHLIB-1152

### SUMMARY

Identified path\_depth axis for the ocv derate group '%s' referred by '%s' attribute. This path\_depth axis is not allowed for ocv derate distance group. This attribute will be ignored.

## DESCRIPTION

When the ocv derate group is referred by ocv\_derate\_distance\_group or default\_ocv\_derate\_distance\_group should have template with distance as axis name. If any template has path\_depth as axis then this ocv group will not be applied for specified cell or library level group.

# TECHLIB-1153

### NAME

TECHLIB-1153

### SUMMARY

The ocv derate group name '%s' referred by '%s' attribute is not defined at %s level. This attribute is ignored.

# DESCRIPTION

The

default\_ocv\_derate\_group/default\_ocv\_derate\_distance\_group/ocv\_derate\_group/ocv\_derate\_dist ance\_group name referred should be defined at library level otherwise it will be ignored. The cell specific ocv derate group can be defined at cell level as well. The issue can be rectified by

Error and Warning Messages

specifying the ocv derate group at library level or cell specific derate at cell level.

# TECHLIB-1154

# **NAME**

TECHLIB-1154

### SUMMARY

Identified more than one leakage\_power groups with same condition in cell '%s', Last definition will be retained.

# **DESCRIPTION**

Identified more than one leakage\_power groups with same condition in cell <cellName>. The last definition will be retained.

# TECHLIB-1156

### NAME

TECHLIB-1156

## **SUMMARY**

The nominal PVT (%.2f, %.2f, %.2f) of timing library '%s' does not match with previously read timing library of the same name with nominal PVT (%.2f, %.2f, %.2f). To read this library you must change the library name.

### DESCRIPTION

This message is issued when there is discrepancy between the nominal PVT of two timing libraries having same library name in library header. To fix the issue, re-characterize the library with appropriate settings, such that the library should be specified with different name.

# NAME

TECHLIB-1157

## SUMMARY

Identified non monotonic time value during CCS to ECSM conversion.

# **DESCRIPTION**

This is a debug message which would be flagged only when the global timing\_library\_debug\_mode\_on is set.

# TECHLIB-1161

## NAME

TECHLIB-1161

## SUMMARY

The library level attribute %s on line %d is defined after at least one cell definition. The attribute will be ignored.

# **DESCRIPTION**

This message is issued when any library level simple or complex attribute is defined after the cell definition in library file. Since such attributes are applicable for all cells in design, they must be specified before the cell definition.

## NAME

TECHLIB-1170

### SUMMARY

Name of '%s' group is missing on line %d. To fix this issue, define the missing group name in the library.

## **DESCRIPTION**

The message is issued when a group such as cell, pin etc., is defined in the library without any name. For example, the group pin is defined as: pin. To rectify the issue, correct the library to define the missing name of the group in the library.

# TECHLIB-1171

# **NAME**

TECHLIB-1171

## SUMMARY

The attribute '%s' of group '%s' has one or more values which are %s. This may lead to unexpected analysis results.

## DESCRIPTION

The message is issued when attribute values defined are beyond the value/range. Beyond the range could include, less than, less than equal to, greater than or greater than equal to. Valid values could be integers, 0,1 or n and float values. This may lead to unexpected results in analysis. To fix the issue, re-characterize the library with appropriate settings to have requisite values per the standard for the attributes for which this message is issued.

### NAME

TECHLIB-1172

## SUMMARY

The '%s' attribute has been defined more than once for group '%s' on line %d. The attribute should be defined only once.

### **DESCRIPTION**

The message is issued when multiple values has been defined within a group. For example, index\_1 in lu\_table\_template group is defined more than once. Each attribute should be defined only once per group. To fix the issue, re-characterize the library with appropriate settings.

# TECHLIB-1173

# NAME

TECHLIB-1173

### SUMMARY

The '%s' attribute has not been defined for %s '%s' on line %d. This may lead to undesirable analysis results. To fix this issue, define the missing attribute in library.

## DESCRIPTION

The message is issued when an expected attribute is not defined for a group. For example, directionattribute expected for the pingroup is not defined in the library. To fix the issue, define the missing attribute in the library or re-characterize the library with appropriate settings.

### **NAME**

TECHLIB-1174

### SUMMARY

The attribute '%s' defined in group '%s' on line %d is not monotonically %s for values '%f' to '%f'. This may lead to undesirable analysis results.

## **DESCRIPTION**

The message is issued when an attribute range does not increase or decrease monotonically as per the Liberty standard or convention. For example, instead of the expected range of monotonically increasing index\_1: (1, 2, 3, 4, 5), the range defined in library is index\_1: (1, 2, 3, 2, 3). To fix the issue, re-characterize the library with appropriate settings.

# TECHLIB-1175

### NAME

TECHLIB-1175

### SUMMARY

Template name '%s' used in group '%s' on line %d is not defined in the library. To fix this issue, define the missing template in the library.

# DESCRIPTION

The message is issued when a template name which has not been defined in the library, has been specified in a table group. For example, the group 'cell\_rise(abc)' given, but the template name 'abc' has not been defined in the library. To rectify the issue, correct the library to define the missing template definition.

### NAME

TECHLIB-1176

## SUMMARY

The table size (%d) of the lookup table group '%s' on line %d is not as per the indices definition '%s'. This may lead to unexpected analysis results.

# DESCRIPTION

The message is issued when the table size of the lookup table in the library is different from the expected size. The expected size is (size of index\_1) x (size of index\_2). For example, index\_1: (1, 2); index\_2: (3, 4); values (1, 2, 3, 4, 5, 6, 7). The size of look up table here is 7, whereas the expected size of table in this case is (2x2). To fix the issue, re-characterize the library with appropriate settings.

# TECHLIB-1177

### NAME

TECHLIB-1177

## **SUMMARY**

'index\_%d' defined in '%s' group should have at least '%d' float values. This may lead to undesirable analysis results.

# **DESCRIPTION**

The message is issued when any index specified in the library has less than the minimum number of float values expected To fix this issue, re-characterize the library such that all indices match the

expected number of float values.

# TECHLIB-1179

# **NAME**

TECHLIB-1179

### SUMMARY

The 'index\_%d' is defined for '%s' group on line %d but its corresponding 'variable\_%d' is not defined for template '%s' '%s' on line %d. This may lead to undesirable analysis results.

## DESCRIPTION

This message is issued when an index is defined in the group but its corresponding variable name is not defined in the template. For index definition to be complete, its variable must be defined in the template. To fix the issue, re-characterize the library with appropriate settings such that all indices have defined variables in the template.

# TECHLIB-1180

## NAME

TECHLIB-1180

# **SUMMARY**

The 'index\_%d' is not defined for '%s' group on line %d, but is required as per definition of template '%s' %s on line %d. This may lead to undesirable analysis results.

# **DESCRIPTION**

This message is issued when an index is not defined for a group but is required as per the template definition. To fix the issue, re-characterize the library with appropriate settings such that all indices

are defined in the group as per the template definition.

# TECHLIB-1181

# **NAME**

TECHLIB-1181

### SUMMARY

The 'variable\_%d' is defined but 'index\_%d' is not defined for %s '%s' on line %d.

# **DESCRIPTION**

This message is issued when a variable is defined in the template but its corresponding index is not defined. All variables should have defined indices in the template. To fix the issue, re-characterize the library with appropriate settings such that all indices exist corresponding to the variables in the template definition.

# TECHLIB-1182

# NAME

TECHLIB-1182

### SUMMARY

The higher level variable\_%d is defined but variable\_%d is not defined for template group '%s' '%s'. This template group will be ignored.

# **DESCRIPTION**

This message is issued when a higher level variable is defined without the lower level variable definition. For example, variable\_2 is defined but variable\_1 definition is missing. To fix the issue, re-characterize the library with appropriate settings such that higher level variables are not defined

without the lower level variable definitions.

# TECHLIB-1183

### NAME

TECHLIB-1183

### SUMMARY

The variable\_%d and variable\_%d have the same value %s for template group '%s' '%s' on line %d.

# DESCRIPTION

This message is issued when two variables in a template have same value. Each variable should have unique value in the template. To fix the issue, re-characterize the library with appropriate settings such that all variables in a template have unique values.

# TECHLIB-1184

### NAME

TECHLIB-1184

### SUMMARY

The attribute '%s' is defined but the attribute '%s' is not defined in '%s' group on line %d.

## **DESCRIPTION**

This message is issued when defining one attribute alone is not sufficient, but another attribute which is also mandatorily needed to be defined with that attribute, is missing. Not only either one but both attributes are necessary for analysis. For example, in one case where attribute 'sdf\_cond' is defined, but 'when' attribute is missing from library or vice-versa. Another case, where the library does not specify the 'default\_wire\_load\_selection' when wire load models are present. In both the

Error and Warning Messages

cases, both attributes are required to be defined in the library. To fix the issue, re-characterize the library with appropriate settings, such that all mandatory dependent attributes are defined in the library.

# TECHLIB-1185

### NAME

TECHLIB-1185

### SUMMARY

The '%s' '%s' is defined in '%s' cell group but not defined in '%s' group.

# **DESCRIPTION**

This message is issued when a cell object such as bus, bundle, pin etc., is inconsistent between the main and test cell defined in the library. To fix the issue, re-characterize the library with appropriate settings, such that cell objects are consistent between main cell and test cell definition

# TECHLIB-1186

### NAME

TECHLIB-1186

## **SUMMARY**

The '%s' table found for timing group with timing\_type %s.

## **DESCRIPTION**

This message is issued when attributes cell\_rise/cell\_fall/rise\_transition/fall\_transition are found for timing group with sequential timing arcs. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are specified for sequential timing arcs.

### NAME

TECHLIB-1187

## SUMMARY

The cell '%s' on line %d has both pad cell and auxiliary pad cell attributes defined.

# **DESCRIPTION**

This message is issued when both pad\_cell and auxiliary\_pad\_cell attributes are defined for a cell. The cell can be classified either as a pad cell or an auxiliary pad cell, but not both. To fix the issue, re-characterize the library with appropriate settings, such that the cell is defined with the correct attribute.

# TECHLIB-1188

# NAME

TECHLIB-1188

### SUMMARY

The cell '%s' on line %d has attribute pad type defined, but it is not a pad cell.

## DESCRIPTION

This message is issued when the attribute pad\_type has been defined for a cell which is not a pad cell. Only pad cells are expected to have the attribute pad\_type defined on them. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined on the cell.

## NAME

TECHLIB-1189

## SUMMARY

The cell '%s' on line %d has pad\_cell attribute but has no 'is\_pad' attribute set to true on any pin/pg\_pin.

# **DESCRIPTION**

This message is issued when the attribute is\_pad is missing for all the pins or pg\_pins of the cell which is defined as a pad cell. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined on the pin and cell.

# TECHLIB-1190

# NAME

TECHLIB-1190

## SUMMARY

The cell '%s' is not a pad cell but has '%s' attribute specified for %s '%s'.

## **DESCRIPTION**

This message is issued when pad attributes such as hysteresis, drive\_current etc., have been defined for a pin of cell which is not a pad cell. Only pad pins are expected to have pad attributes defined on them. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined on the pin/cell.

# NAME

TECHLIB-1191

### SUMMARY

The attribute 'power down function' has been defined for %s '%s' of test cell on line %d.

# **DESCRIPTION**

This message is issued when attribute power\_down\_function is defined on any pin of test\_cell. The test\_cell pins cannot have power\_down\_function attribute. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined on test\_cell pins.

# TECHLIB-1192

### NAME

TECHLIB-1192

## SUMMARY

The attribute '%s' has been defined for %s %s '%s' on line %d.

## DESCRIPTION

This message is issued when the attributes function/state\_function/Clock\_gate\_out\_pin are defined incorrectly on pins with certain direction i.e. function attribute cannot be defined for input pins, state\_function cannot be defined for input and internal pins and clock\_gate\_out\_pin cannot be set true for input and internal pins. To fix the issue, re-characterize the library with appropriate settings, such that the attributes function/state\_function/Clock\_gate\_out\_pin should be defined on correct pins.

## NAME

TECHLIB-1193

## SUMMARY

The %s '%s' on line %d is undefined in the library.

# **DESCRIPTION**

This message is issued when any attribute is used but it is not defined in the library. To fix the issue, re-characterize the library with appropriate settings, such that there is no undefined attribute getting used in library.

# TECHLIB-1194

### NAME

TECHLIB-1194

## SUMMARY

The attribute 'bit\_width' %d on line %d does not match with the bit range specified using attributes 'bit from' %d and 'bit to' %d.

# **DESCRIPTION**

This message is issued when specified bit\_width attribute does not match with the bus\_width calculated from bit\_from and bit\_to attributes. To fix the issue, re-characterize the library with appropriate settings, such that there is no such conflict.

### NAME

TECHLIB-1195

#### **SUMMARY**

The bus pin '%s' on line %d, is out of range as per bus bit definition %d to %d.

## **DESCRIPTION**

This message is issued when a bus pin is specified with width which is out of range as per the bus bit definition. For example, the pin X is specified with bus bit range 2 i.e. (0 to 1) but the bus pin is specified like X[3]. To fix the issue, re-characterize the library with appropriate settings, such that the correct range is defined.

# TECHLIB-1196

## NAME

TECHLIB-1196

### SUMMARY

The group '%s' with name '%s' on line %d is already defined on line %d. The first definition will be retained, rest will be ignored.

## DESCRIPTION

This message is issued when an attribute is defined more than once. The same attribute cannot have multiple definition. First definition will be retained and rest will be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the attributes are defined correctly.

### NAME

TECHLIB-1197

#### **SUMMARY**

The cell '%s' on line %d is neither a pad cell nor an auxiliary pad cell but has 'is\_pad' attribute set to true on %s at line %d.

## **DESCRIPTION**

This message is issued when the attribute pad\_cell/auxiliary\_pad\_cell is missing at cell level but has pin(s)/pg\_pin(s) with is\_pad attribute. Pins should have is\_pad attribute only if cell is a pad cell. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined on pin/cell.

## TECHLIB-1198

#### NAME

TECHLIB-1198

#### SUMMARY

The 'index\_%d' is defined but its corresponding 'variable\_%d' is not defined for template '%s' '%s'. This may lead to undesirable analysis results.

## DESCRIPTION

This message is issued when an index is defined but its corresponding variable name is not defined in the template. For index definition to be complete, its variable must be defined in the template. To fix the issue, re-characterize the library with appropriate settings such that all indices have defined variables in the template.

#### NAME

TECHLIB-1199

### SUMMARY

The delay\_model attribute specified on line %d should be the first attribute in the library.

## **DESCRIPTION**

This message is issued when delay\_model attribute is specified in library but it is not the first attribute in library. As per Liberty standards, delay\_model attribute must be first attribute if technology attribute is not specified in library.

## TECHLIB-1200

## NAME

TECHLIB-1200

#### SUMMARY

The attribute '%s' defined on line %d is not supported for '%s' group. It should be defined at '%s' level.

### DESCRIPTION

The message is issued when an attribute defined for a group is not supported by that group and needs to be defined at a different parent level in the library. For example, if a library level attribute (such as time\_unit) is defined at the cell or pin level definition. To fix the issue, re-characterize the library with appropriate settings, such that only attributes supported by a group definition are specified in that group.

#### NAME

TECHLIB-1201

### SUMMARY

The attribute '%s' defined on line %d is not supported for the '%s' group.

## **DESCRIPTION**

The message is issued when an attribute defined for a group is not supported by that group and needs to be defined at a different parent level in the library. For example, if a library level attribute (such as time\_unit) is defined at the cell or pin level definition. To fix the issue, re-characterize the library with appropriate settings, such that only attributes supported by a group definition are specified in that group.

## TECHLIB-1202

### **NAME**

TECHLIB-1202

## SUMMARY

The %s statement for '%s' on line %d is first defined on line %d. The first definition will be retained.

## **DESCRIPTION**

The message is issued when more than one definitions of the define\_group attribute are defined in the library. To fix the issue, re-characterize the library with appropriate settings, such that only one definition per define\_group is present in the library.

### NAME

TECHLIB-1203

#### SUMMARY

The name of cell defined on line %d is missing. The definition will be ignored.

## **DESCRIPTION**

The message is issued when the cell definition is missing the name string. In such cases, the cell definition will be completely ignored. To fix the issue, re-characterize the library with appropriate settings, such that the name of the cell definition is defined such that it can be referenced correctly.

# TECHLIB-1204

#### NAME

TECHLIB-1204

## **SUMMARY**

Illegal value '%s' defined for attribute '%s'. The attribute will be ignored.

## DESCRIPTION

The message is issued when non-legal and unacceptable values are specified for attributes. For example, per liberty guidelines, the acceptable values for attributes such as dont\_touch and dont\_use are only true/false. If the library has other values such as enum or integers specified, the attribute will not be honored. To fix the issue, re-characterize the library with appropriate settings, such that the attribute has legal value specified and can be honored.

### NAME

TECHLIB-1205

#### **SUMMARY**

Boolean value '%s' defined for attribute %s on line %d. The acceptable value is true/false. However, the value and the attribute will be honored.

## **DESCRIPTION**

The message is issued when boolean values are specified for attributes. For example, per liberty guidelines the acceptable values for attributes such as dont\_touch and dont\_use are only true/false. However, if the library has boolean values specified, the tool honors the valu and the attribute, along with this message. To fix the issue, re-characterize the library with appropriate settings, such that the attribute has values specified per the required syntax.

## TECHLIB-1206

#### NAME

TECHLIB-1206

## **SUMMARY**

The attribute '%s' defined on line %d has invalid syntax for floating number. It will be ignored.

### DESCRIPTION

The message is issued when a library attribute having inconvertible floating point numbers such as single float is expected but multiple values are provided or unusable values are provided like nan/inf in float value or float array. For example, the attributes rise\_capacitance and fall\_capacitance are expected to have a single float value defined. To fix the issue, re-characterize

Error and Warning Messages

the library with appropriate settings, such that the attribute takes a scalar float value.

## TECHLIB-1207

## **NAME**

TECHLIB-1207

#### SUMMARY

The attribute wire\_load\_from\_area defined on line %d of wire\_load\_selection group has max area value %f specified less than min area value %f.

### DESCRIPTION

The message is issued when the min area value defined in the wire\_load\_from\_area attribute of the wire\_load\_selection group, is less than that defined as the max area value. Min area should be lesser than the max area value. To fix the issue, re-characterize the library with appropriate settings, such that the area range is defined correctly.

## TECHLIB-1208

### NAME

TECHLIB-1208

## **SUMMARY**

The attribute '%s' of '%s' group '%s' has value '%f' which is '%s'.

### **DESCRIPTION**

The message is issued when the attribute in a group has a value which is different (less than, less than equal to, greater than, greater than equal to defined values which could be integers or float values) than the expected value/range per the Liberty standard. For example, if max\_area value

Error and Warning Messages

defined in the wire\_load\_from\_area attribute of the wire\_load\_selection group, is less than or equal to 0. Or min\_area value is less than 0. To fix the issue, re-characterize the library with appropriate settings, such that the attribute values are defined per Liberty standard.

## TECHLIB-1209

#### NAME

TECHLIB-1209

#### SUMMARY

The area range %f-%f specified for wire\_load\_from\_area attribute defined on line %d of wire\_load\_selection group '%s' overlaps with the range %f-%f of the wire\_load\_from\_area attribute defined on line %d.

## DESCRIPTION

The message is issued when area range defined in one wire\_load\_from\_area attribute of the wire\_load\_selection group, overlaps the area range defined in the another wire\_load\_from\_area attribute. The range of area defined should be mutually exclusive. To fix the issue, re-characterize the library with appropriate settings, such that the area range is defined correctly.

# TECHLIB-1210

### NAME

TECHLIB-1210

## SUMMARY

The %s attribute(s) is not defined for %s group on line %d, even though %s attributes(s) are defined.

Error and Warning Messages

The message is issued when the ff/ff\_bank attributes such as preset, clear, clear\_preset\_var1 and clear\_preset\_var2 are not all defined in the library when either of the attributes are defined. For example, in case one, if preset and clear are not defined when clear\_preset\_var1 or clear\_preset\_var2 are defined or in case two, if when both clear and preset are defined, but clear\_preset\_var1 and/or clear\_preset\_var2 are not defined. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined per the requirement.

## TECHLIB-1211

## NAME

TECHLIB-1211

#### SUMMARY

The %s '%s' is not a pad pin but has '%s' attribute specified on line %d.

## **DESCRIPTION**

The message is issued when pad attributes such as hysteresis, drive\_current etc., have been defined for a pin which is not a pad pin. Only pad pins are expected to have pad attributes defined on them. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined on the pad pin

## TECHLIB-1212

#### NAME

TECHLIB-1212

#### SUMMARY

The pad attribute '%s' is defined on %s '%s' on line %d. It should be defined on '%s'.

Error and Warning Messages

The message is issued when pad attributes such as hysteresis, drive\_current are defined on incorrect pin based on direction. Per Liberty standard, the hysteresis attribute is valid only for input pad pins, whereas drive\_current can only be defined for output pad pins. In cases where the library specifies it the differently, the message is issued. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined with respect to the pad pin directions.

## TECHLIB-1213

## NAME

TECHLIB-1213

#### SUMMARY

For '%s' timing group defined on line %d, related pin %s is not same as the pin %s.

## **DESCRIPTION**

This message is issued when the attribute related\_pin name is not same as the parent pin name for 'min\_pulse\_width' and 'minimum\_period' timing groups. To fix the issue, re-characterize the library with appropriate settings, such that the correct related pin value is set.

## TECHLIB-1214

## NAME

TECHLIB-1214

### **SUMMARY**

For '%s' timing group defined on line %d, related pin is same as the parent pin '%s'.

Error and Warning Messages

This message is issued when the attribute related\_pin name is defined same as parent pin for timing arcs other than min\_pulse\_width and minimum\_period. To fix the issue, re-characterize the library with appropriate settings, such that the correct related pin value is set.

## TECHLIB-1215

#### NAME

TECHLIB-1215

#### SUMMARY

For cell '%s', pin name %s defined on line %d conflicts with sequential variable for '%s' group defined on line %d

### DESCRIPTION

This message is issued when the pin name is defined same as the variable(s) specified for 'ff' and 'latch' group. To fix the issue, re-characterize the library with appropriate settings, such that the correct pin name is specified.

## TECHLIB-1216

#### NAME

TECHLIB-1216

## **SUMMARY**

The reference time values '%f' and '%f' defined for vector groups on line '%d' and '%d' respectively are different, even though their input\_transition\_time index is same.

## **DESCRIPTION**

This message is issued when values of the reference\_time and input\_net\_transition attributes are

Error and Warning Messages

inconsistent inside the output\_current\_rise or output\_current\_fall group. To fix the issue, recharacterize the library with appropriate settings, such that there is no such inconsistency.

## TECHLIB-1217

### NAME

TECHLIB-1217

## **SUMMARY**

For the cell '%s', the always-on %s has related\_power\_pin '%s' which is not of pg\_type 'backup power'.

## **DESCRIPTION**

This message is issued for an always-on cell, when the cell pin has related\_power\_pin which is not the pg\_type 'backup\_power'. To fix the issue, re-characterize the library with appropriate settings, such that the correct pg\_type pin is specified.

## TECHLIB-1218

### NAME

TECHLIB-1218

## **SUMMARY**

For the cell '%s', the always-on %s has related\_ground\_pin '%s' which is not of pg\_type 'backup ground'.

#### DESCRIPTION

This message is issued for an always-on cell, when the cell pin has related\_ground\_pin which is not the 'backup ground' pg type. To fix the issue, re-characterize the library with appropriate

settings, such that the correct pg\_type pin is specified.

## TECHLIB-1220

#### NAME

TECHLIB-1220

#### SUMMARY

The '%s' attribute is not defined for the cell %s. This may lead to undesirable analysis results. To fix this issue, define the missing attribute in library.

### DESCRIPTION

This message is issued when the attributes such as ecsm\_vtp and ecsm\_vtn are not defined for the cell in library with ecsm version >= 1.2. To fix the issue, re-characterize the library with appropriate settings, such that these attributes are defined on the cell.

# TECHLIB-1221

## **NAME**

TECHLIB-1221

#### SUMMARY

The attribute pg\_type of the pg\_pin '%s' on line %d is not defined as 'primary\_power' even though the attribute 'std\_cell\_main\_rail' is true

## **DESCRIPTION**

The message is issued when even though the attribute 'std\_cell\_main\_rail' is defined as true on a pg\_pin, but the attribute 'pg\_type' is not defined as 'primary\_power'. When 'std\_cell\_main\_rail' is set as true, it is mandated to have the 'pg\_type' defined as 'primary\_power'. To fix the issue, re-

Error and Warning Messages

characterize the library with appropriate settings, such that attributes are correctly defined.

# TECHLIB-1222

#### NAME

TECHLIB-1222

#### SUMMARY

The 'index\_%d' of type '%s' defined in '%s' group on line %d should have single float value. The group will be ignored.

## **DESCRIPTION**

The message is issued when any index specified in the library is expected to have single float value but has more than one float value. To fix this issue, re-characterize the library such that all indices match the expected number of float values.

# TECHLIB-1223

## **NAME**

TECHLIB-1223

### SUMMARY

The attribute '%s' has value '%g' which is not '%s'.

### **DESCRIPTION**

This message is issued when the attribute has float values beyond the defined range as per the Liberty standard.

### NAME

TECHLIB-1224

### SUMMARY

The internal\_power group is defined multiple times for cell '%s', %s '%s' on lines %d and %d. First definition will be used for analysis

## **DESCRIPTION**

This message is issued for multiple definitions of internal\_power groups for a pin with the same related\_pg\_pin and same 'when' condition attributes. First definition is used for analysis.

# TECHLIB-1225

#### NAME

TECHLIB-1225

### SUMMARY

For clock gating integrated cell '%s', output %s '%s', the function attribute has both '%s' and '%s' at line %d. This may lead to unexpected analysis results.

## **DESCRIPTION**

This message is issued when pin function attribute is defined with both IQ and IQN pins for clock gating integrated cells. To fix the issue, re-characterize the library with appropriate settings.

### NAME

TECHLIB-1226

### SUMMARY

For the cell '%s', inout %s '%s' on line %d has missing three state function.

## **DESCRIPTION**

This message is issued when the three\_state function is not specified for the inout pin of the cell. To fix the issue, re-characterize the library with appropriate settings, such that the three\_state function should be specified.

# TECHLIB-1227

## NAME

TECHLIB-1227

### SUMMARY

For cell %s, %s pg pin %s on line %d has related bias pin %s which is not of type %s.

## **DESCRIPTION**

This message is issued when the attribute related\_bias\_pin has invalid value. For power pins, it can only be nwell/deepnwell and for ground pins, it can only be pwell/deeppwell. To fix the issue, re-characterize the library with appropriate settings, such that the correct related\_bias\_pin values are set.

#### **NAME**

TECHLIB-1228

#### SUMMARY

The pin name '%s' defined on line %d is part of the list of reserved words for sequential cells. However, the pin name is honored.

## **DESCRIPTION**

This message is issued when a sequential cell has pin names that are part of the reserved words for sequential cells. List of the reserved words is following: clocked\_on\_also, data\_in, enable, enable\_also, preset, clear, force\_00, force\_01, force\_10, force\_11. To fix the issue, re-characterize the library with appropriate settings, such that the correct pin name is specified.

## TECHLIB-1229

## **NAME**

TECHLIB-1229

## **SUMMARY**

The first value %f for '%s' group defined on line %d is the '%s' value.

## DESCRIPTION

This message is issued when the first value of the current waveform in CCS library is not correctly specified. The first value in the 'values' attribute of the group 'output\_current\_rise' cannot be the maximum value and the first value in the 'values' attribute of the group 'output\_current\_fall' cannot be the minimum value. To fix the issue, re-characterize the library with appropriate settings, such that the correct values are specified.

## NAME

TECHLIB-1230

### SUMMARY

Failed to parse '%s' expression for %s group on line number %d. %s

## **DESCRIPTION**

This message is issued when software encounters an error in parsing the boolean expressions like next\_state/function/when/when\_start/when\_end/sdf\_cond etc.. To rectify the issue, fix the error issued by correcting the Boolean expression definition.

## TECHLIB-1231

## NAME

TECHLIB-1231

## **SUMMARY**

The attribute fanout\_length for wire\_load group '%s' defined on line %d has %d arguments. It must have 2 or 5 arguments.

## DESCRIPTION

This message is issued when the attribute fanout\_length for wire\_load group has incorrect number of arguments. It must have either 2 or 5 arguments. To fix the issue, re-characterize the library with appropriate settings, such that the correct value is set for the attribute.

#### **NAME**

TECHLIB-1232

#### **SUMMARY**

The input\_transition\_time index values '%f' and '%f' defined for vector groups on line '%d' and '%d' respectively are different, even though their respective reference time is same.

## **DESCRIPTION**

This message is issued when values of the reference\_time and input\_net\_transition attributes are inconsistent inside the output\_current\_rise or output\_current\_fall group. To fix the issue, recharacterize the library with appropriate settings, such that there is no such inconsistency.

# TECHLIB-1233

## **NAME**

TECHLIB-1233

### SUMMARY

Number of values in ecsm\_waveform\_set in the transition table %s on line %d in pin %s of cell %s does not match the number of transition table axis points specified in the template. Ignoring waveform data.

## DESCRIPTION

The number of values in ecsm\_waveform\_set must match the number of data points in the transition table for correct waveform lookup. If this is not the case, waveform data for the transition group is ignored.

### NAME

TECHLIB-1234

#### SUMMARY

The %s is not present for the %s '%s' on line '%d' for cell '%s'. This may cause incorrect voltage to be used during timing analysis

## **DESCRIPTION**

This message is issued when the attribute related\_power\_pin or related\_ground\_pin is absent. For special cells (macro/level shifter/always on/retention/isolation/pad etc.), it is mandatory to specify the related\_power\_pin/related\_ground\_pin attribute for every pin definition. Absence of this attribute may cause incorrect voltage to be used during timing analysis. To fix the issue, re-characterize the library with appropriate settings, such that this information is correctly specified for every pin.

## TECHLIB-1235

#### NAME

TECHLIB-1235

## **SUMMARY**

The pg\_pin with the name %s specified for %s attribute for %s on line '%d' is not defined for cell '%s'.

## **DESCRIPTION**

This message is issued when the pin name specified for related\_pg\_pin attribute is not defined at the cell level. To fix the issue, re-characterize the library with appropriate settings, such that the correct pins are specified.

#### NAME

TECHLIB-1236

### SUMMARY

The ecsm\_waveform\_set group on line %d in the transition table %s in pin %s of cell %s does not have valid index\_1 attribute specified. Ignoring waveform data.

### **DESCRIPTION**

Attribute index\_1 is mandatory attribute in ecsm\_waveform\_set group which represents the normalized output voltage sample points which are shared by all voltage waveforms represented by the ecsm\_waveform\_set group. It can be specified at the group level or at the template level. If it is not specified, waveform data for the transition group is ignored.

# TECHLIB-1237

### NAME

TECHLIB-1237

## **SUMMARY**

The related\_pin '%s' specified for %s group on line '%d' is not defined for cell '%s'.

## **DESCRIPTION**

This message is issued when an undefined pin is specified as related\_pin. To fix the issue, recharacterize the library such that valid pin is used for related\_pin.

### NAME

TECHLIB-1238

#### SUMMARY

The %s group on line %d can have only %d parameters. The extra parameters will be ignored.

## **DESCRIPTION**

This message is issued when the extra parameters are defined for the ff/latch and ff\_bank/latch\_bank. For ff/latch parameter limit is 2 and ff\_bank/latch\_bank parameter limit is 3, rest will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the parameter should be defined within the limit.

# TECHLIB-1239

## NAME

TECHLIB-1239

### SUMMARY

The software could not locate the master timing library specified in the side-file library '%s'. You are required to have timing libraries that match your side-file libraries. The variation data will not be loaded.

## DESCRIPTION

The software could not locate the master timing library specified in the side-file library. You are required to have timing libraries that match your side-file libraries. The variation data will not be loaded.

### NAME

TECHLIB-1240

#### **SUMMARY**

The software could not locate the timing library cell '%s' specified in the side-file library '%s'. You are required to have timing library cells to match the cells in your side-file libraries. The variation data will not be loaded.

## **DESCRIPTION**

The software could not locate the timing library cell specified in the side-file library. You are required to have timing library cells to match the cells in your side-file libraries. The variation data will not be loaded.

## TECHLIB-1241

#### **NAME**

TECHLIB-1241

#### SUMMARY

The software could not locate the timing library arc in library '%s' for cell '%s' between pin '%s' and pin '%s' for condition '%s'. You are required to have timing library cells that the match arc topology of the cells in your side-file libraries. The variation data will not be loaded.

## **DESCRIPTION**

The software could not locate the timing library arc in library. You are required to have timing library cells that the match arc topology of the cells in your side-file libraries. The variation data will not be loaded.

#### NAME

TECHLIB-1242

## **SUMMARY**

The library format in the file '%s' is not supported by software. Check the format.

## DESCRIPTION

The software is not able to recognize the library format of file. Liberty timing libraries or side-file files must be in either text-readable format or Cadence compiled .ldb format.

# TECHLIB-1244

#### NAME

TECHLIB-1244

## **SUMMARY**

The LDB file cannot be read because it has been compiled with a newer software version '%s' than the currently used software version. Recompile the LDB file with a compatible software version '%s' or use the equivalent non-compiled library.

## **DESCRIPTION**

This message is issued when the LDB file is compiled with a later software version than the version being used to read the LDB file. This is not allowed because the LDB file may have some data which is not supported in the backward software version you are using to read the LDB file. To fix this issue, re-compile the LDB file with a compatible software version.

#### **NAME**

TECHLIB-1245

### SUMMARY

The LDB file cannot be read because LDB file size is not as per expected file size. LDB file may be corrupted. Recompile the LDB file.

## **DESCRIPTION**

This message is issued when the on-disk file size of the LDB file does not match the file size stored in the header of LDB file. This indicates some data corruption issues. To fix this issue, re-compile the LDB file.

## TECHLIB-1246

## NAME

TECHLIB-1246

### SUMMARY

The LDB file cannot be read because the LDB is compiled on a CPU whose endianness is different from the endianness of the current machine CPU architecture. Re-compile the LDB file on the same CPU architecture that you are using to read the LDB file.

## DESCRIPTION

This message is issued when the CPU architecture reading the LDB file and CPU architecture which was used to generate the LDB file are not compatible in terms of endianness. Use machines with same endianness to fix this issue.

### NAME

TECHLIB-1247

### **SUMMARY**

The report\_aocv\_derate command is disabled because encrypted AOCV libraries have been loaded in the session.

## **DESCRIPTION**

Since this command reports the AOCV derating tables from AOCV libraries in AOCV library format, it is disabled when any of the AOCV library is loaded in encrypted format

# TECHLIB-1248

## NAME

TECHLIB-1248

## **SUMMARY**

Generated LDB '%s' can be read only within %s flows.

## **DESCRIPTION**

LDB files generated by Innovus is not interoperable across Cadence tools and can be used only in Innovus and Conformal.

### NAME

TECHLIB-1249

#### SUMMARY

The LDB is generated by %s tool and is not interoperable with current tool.

## **DESCRIPTION**

LDB files generated by Innovus is not interoperable across Cadence tools and can be used only in Innovus and conformal. LDB files generated from Tempus can be used as input by all tools (Innovus, Tempus, Genus and Voltus). To fix this issue, recompile the LDB file with Tempus.

# TECHLIB-1250

#### NAME

TECHLIB-1250

### SUMMARY

The input library file can not be in LDB format. Specify the text library file.

## **DESCRIPTION**

This message is issued when LDB file is specified as input library file to -library option. Input library file must be in text format. To fix this issue, specify text library file.

### NAME

TECHLIB-1251

#### **SUMMARY**

For cell '%s', arc '%s', 'CCS '%s' waveform has more than one peak '%s' at line %d. Review the multiple peaks and ensure that these are as per the expectations.

## **DESCRIPTION**

This message is issued when CCS output current waveform (rise/fall) has distortions and has more than one peak. Review the multiple peaks and ensure that these are as per the expectations. The default threshold value for maximum peak violation is 0.95. To change the default value in value, use the command line option 'set value mode -ccs current peak tolerance'

## TECHLIB-1252

#### NAME

TECHLIB-1252

## SUMMARY

The '%s' attribute is defined for '%s %s %s' of cell '%s'. This attribute will be ignored.

## DESCRIPTION

The input\_voltage attribute can be defined only for input or inout pins, bus or bundle and output\_voltage attribute can be defined only for output or inout pins, bus or bundle. Incorrectly applied attributes will be ignored during timing analysis. To fix this issue, re-characterize the library with appropriate settings.

### NAME

TECHLIB-1253

#### SUMMARY

'%s' group '%s' is undefined in library. This attribute will be ignored.

## **DESCRIPTION**

This message is issued when input\_voltage and/or output\_voltage group(s) referred by these attributes at the pin level are not defined in the library. Attribute referring to undefined group will be ignored. To fix this issue, re-characterize the library with appropriate settings.

## TECHLIB-1254

#### NAME

TECHLIB-1254

### **SUMMARY**

The '%s - %s' table of the '%s' group on the '%s' %s '%s' does not have a template that uses '%s' as a variable. Ensure that the templates used are in accordance with the direction of the pin.

### **DESCRIPTION**

This message is issued when the input\_net\_transition and total\_output\_net\_capacitance tables defined with incorrect direction of the pin for the power/rise\_power/fall\_power groups. For 1-d tables input pin should have input\_net\_transition. For 2-d tables input and output pins should be defined with both input\_net\_transition and total\_output\_net\_capacitance tables and inout pins can be defined with any of the attribute. To fix the issue, re-characterize the library with appropriate settings, such that the templates used are defined in accordance with the direction of pin.

#### NAME

TECHLIB-1255

### SUMMARY

The '%s' table on the timing arc has %s as '%s' on pin '%s' for cell '%s' but it has no 'ecsm\_capacitance %s' tables. Ensure that the corresponding ecsm\_capacitance/ecsm\_capacitance\_set tables are present.

## DESCRIPTION

This message is issued when complete ECSM data is not present for a timing arc. For example, in timing arc, if ecsm waveform data is present but corresponding ecsm capacitance data is missing then software issues this message. This incomplete data can lead to inaccuracy in timing analysis. To fix this issue, re-characterize the library such that ECSM data is complete for the mentioned timing arc.

## TECHLIB-1256

## NAME

TECHLIB-1256

### SUMMARY

The %s is being ignored due to errors in this group. This group will be excluded for any further library checks. Refer to the previous messages issued for %s to find the details of the issues in this group.

Error and Warning Messages

This message is issued in scenarios when any liberty group has problem. For example, if the template at library level and cell level do not match for number of indices or number of values in indices. It can also occur if indices are expected to have single value for some attributes per Liberty format but library has more than one value for that index. Another case can be when timing type is not specified/invalid and timing arc has sequential timing arcs. In such scenarios, the corresponding table data is ignored.

## TECHLIB-1257

## NAME

TECHLIB-1257

#### SUMMARY

Found %s '%s' in the library. This is not a mandatory %s for merged library and may result in increased library size.

## **DESCRIPTION**

For a merged library only the following constructs are mandatory:\n ecsm\_version and 4 ECSM-Timing Constructs - ecsm\_waveform\_set, ecsm\_capacitance\_set, ecsm\_vtp, ecsm\_vtn and 2 CCS-Noise Constructs - ccsn\_first\_stage, ccsn\_last\_stage \n If any other construct is present, it may cause an increase in size, beyond the expected value for a merge library.

## TECHLIB-1258

## **NAME**

TECHLIB-1258

## **SUMMARY**

Necessary %s '%s' is missing from the '%s' table on the timing arc of pin '%s' for cell '%s' of the merged library. This is a mandatory %s for merged library and may lead to inaccuracy in timing analysis.

### DESCRIPTION

For a merged library only the following constructs are mandatory:\n ecsm\_version and 4 ECSM-Timing Constructs - ecsm\_waveform\_set, ecsm\_capacitance\_set, ecsm\_vtp, ecsm\_vtn and 2 CCS-Noise Constructs - ccsn\_first\_stage, ccsn\_last\_stage\n If these constructs are not present, it may cause inaccuracy in timing analysis.

## TECHLIB-1259

## NAME

TECHLIB-1259

## **SUMMARY**

Necessary %s '%s' is %s for the merged library. This is a mandatory %s for merged library and may lead to inaccuracy in timing analysis.

## **DESCRIPTION**

For a merged libray only the following constructs are mandatory:\n ecsm\_version and 4 ECSM-Timing Constructs - ecsm\_waveform\_set, ecsm\_capacitance\_set, ecsm\_vtp, ecsm\_vtn and 2 CCS-Noise Constructs - ccsn\_first\_stage, ccsn\_last\_stage\n If these constructs are not present, it may casue inaccuracy in timing analysis. Furthermore ecsm\_vtp and ecsm\_vtn are checked only if the ecsm\_version is greater than 1.2/2.1 as the support for these attributes was added in the aforementioned version.

## **TECHLIB-1260**

## NAME

TECHLIB-1260

## **SUMMARY**

Cell '%s' does not have electromigration/max\_cap group on any pin

Error and Warning Messages

## DESCRIPTION

This message is issued when the cell is not specified with any electromigration/max\_cap table on any pin. To fix the issue, re-characterize the library with appropriate settings, such that the electromigration/max cap table is defined on pin at cell level.

## TECHLIB-1261

## NAME

TECHLIB-1261

### **SUMMARY**

Found invalid/missing attribute value. The attribute will be ignored.

## **DESCRIPTION**

This message is issued in scenarios when attribute value is invalid/missing. For example related\_pin attribute is specified but its value is empty string or integer value is specified where string value is expected, the attribute will not be honored. To fix the issue, re-characterize the library with appropriate settings, such that the attribute has legal value specified and can be honored.

## TECHLIB-1262

#### NAME

TECHLIB-1262

## **SUMMARY**

%s

Error and Warning Messages

This message is issued in scenarios when there is error in command line arguments.

## TECHLIB-1263

## **NAME**

TECHLIB-1263

## **SUMMARY**

Unknown capacitance type '%s' defined for %s in cell %s.

## **DESCRIPTION**

The ecsm\_capacitance/ecsm\_capacitance\_set type should be either rise or fall. If a value other than rise or fall is encountered, the ecsm\_capacitance information will be ignored

## TECHLIB-1264

## NAME

TECHLIB-1264

## **SUMMARY**

Pin index range [%d:%d] is out of range of bus %s in cell '%s'

### DESCRIPTION

This message is issued when the specified pin index range is out of range as per the bus definition in cell. To fix the issue, re-characterize the library with appropriate settings, such that the correct range is defined.

### NAME

TECHLIB-1265

#### SUMMARY

scalar pin %s specified as bus with index range [%d:%d] in boolean expression in cell %s. The boolean expression is ignored.

## **DESCRIPTION**

This message is issued when the scalar pin is defined as bus bit in boolean expressions like function, when expression etc. To fix the issue, re-characterize the library with appropriate settings, such that the index range is specified for scaler pin.

# TECHLIB-1266

## **NAME**

TECHLIB-1266

### SUMMARY

Error while translating binary string '%s'

## **DESCRIPTION**

This message is issued when binary string cannot be translated into required format.

### NAME

TECHLIB-1267

### SUMMARY

Pin '%s' does not exist in cell '%s' or it is the part of the function string mapped to a latch/ff element, which has been ignored due to the cell having 'interface timing' set to true.

## **DESCRIPTION**

The message is issued when the cell is a black box cell but it contains function attribute or ff group.

## TECHLIB-1269

## NAME

TECHLIB-1269

## **SUMMARY**

Pin '%s' does not exist in cell '%s'. The functions expression will be ignored.

## **DESCRIPTION**

This message is issued when the pin is not defined in the cell and referred in the function. Function statement will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the pin is defined in the cell.

## NAME

TECHLIB-1270

### SUMMARY

The '%s' attribute/group has been defined more than once. Only the %s occurrence of the attribute will be retained.

## **DESCRIPTION**

The message is issued when there are multiple definitions for an attribute/group. Each attribute/group should be defined only once. To fix this issue, re-characterize the library with the appropriate settings.

# TECHLIB-1271

## **NAME**

TECHLIB-1271

## **SUMMARY**

No ocv\_derate\_factors group specified for ocv\_derate group %s of cell %s.

## **DESCRIPTION**

At least one ocv\_derate\_factors group must be specified within an ocv\_derate group.

## NAME

TECHLIB-1272

## SUMMARY

The '%s' %s has been defined more than once on %s. Only the %s occurrence of the %s will be retained.

## **DESCRIPTION**

The message is issued when there are multiple definitions for an attribute/group. Each attribute/group should be defined only once. To fix this issue, re-characterize the library with the appropriate settings.

# **TECHLIB-1273**

## **NAME**

TECHLIB-1273

## SUMMARY

'%s' should not be defined in lu\_table\_template '%s' used in group %s on line %d, in pin '%s' of cell '%s'.)

## **DESCRIPTION**

The ocv\_sigma\_cell\_rise, ocv\_sigma\_cell\_fall, ocv\_sigma\_rise\_transition, ocv\_sigma\_fall\_transition, ocv\_sigma\_rise\_constraint and ocv\_sigma\_fall\_constraint groups can be 1D, 2D, 3D or scalar only.

## NAME

TECHLIB-1274

### SUMMARY

The valid value of %s is %s in the lu\_table\_template '%s' used in group '%s' on line %d, in pin %s of cell %s.

## **DESCRIPTION**

For the ocv\_sigma\_cell\_rise, ocv\_sigma\_cell\_fall, ocv\_sigma\_rise\_transition, and ocv\_sigma\_fall\_transition groups, the valid values of variable\_1, variable\_2, and variable\_3 are input\_net\_transition, total\_output\_net\_capacitance, and related\_out\_total\_output\_net\_capacitance. For the ocv\_sigma\_rise\_constraint and ocv\_sigma\_fall\_constraint groups, the values of variable\_1 and variable\_2 are related\_pin\_transition and constrained\_pin\_transition respectively. The values of variable\_3 can be related\_out\_total\_output\_net\_capacitance, related\_out\_output\_net\_length, related\_out\_net\_wire\_cap, or related\_out\_output\_net\_pin\_cap.

# TECHLIB-1276

## **NAME**

TECHLIB-1276

## SUMMARY

Cannot find timing library file '%s' specified with '%s'. Check unix permissions.

## DESCRIPTION

This message is issued when the specified library is not found

## NAME

TECHLIB-1277

### SUMMARY

The %s '%s' has been defined for %s %s '%s'. '%s' cannot be defined at this level and is being ignored.

## **DESCRIPTION**

This message is issued when any attribute/group is specified at incorrect level/context. Such attributes/groups are ignored. To fix the issue, recharacterize the library such that attributes/groups are specified correctly.

# TECHLIB-1278

## NAME

TECHLIB-1278

## **SUMMARY**

The mandatory %s '%s' is missing for %s %s '%s'.

## **DESCRIPTION**

This message is issued when any mandatory attribute/groups is missing in library. This can cause issues later in tool applications.

## NAME

TECHLIB-1279

### SUMMARY

For cell '%s', in group '%s', voltage swing on pin/bus/bundle '%s' with load '%f' and slew '%f' is '%.1f%', should be within five percent of '%s'.

## **DESCRIPTION**

Using current waveform for the cell pin in the library, tool converts it to calculate the charging voltage. If the calculated voltage does not reach a particular threshold (within 5% of VDD voltage) then this message is issued. To fix the issue, re-characterize the library with appropriate settings, such that the full voltage swing is reached.

## TECHLIB-1280

### **NAME**

TECHLIB-1280

### SUMMARY

The group '%s' has not been specified corresponding to the group '%s', but '%s' data has been specified corresponding to other groups on the same arc, on %s for cell '%s'.

## DESCRIPTION

This message is issued when the CCS timing/ECSM/LVF/FIT data is defined for one or more slew tables but missing on other slew tables within the same arc. The valid slew groups are rise\_transition, fall\_transition, retain\_rise\_slew, retain\_fall\_slew, ocv\_sigma\_rise\_transition, ocv\_sigma\_fall\_transition, ocv\_sigma\_cell\_rise, ocv\_sigma\_cell\_fall, ocv\_sigma\_rise\_constraint

Error and Warning Messages

and ocv\_sigma\_fall\_constraint. To fix the issue, re-characterize the library with appropriate settings, such that the CCS timing/ECSM waveform/LVF/FIT data is defined corresponding to all group within the same arc.

# TECHLIB-1281

#### NAME

TECHLIB-1281

#### SUMMARY

The timing arc on %s for %s '%s' has CCS timing driver information, but CCS timing receiver information is missing.

## **DESCRIPTION**

This message is issued when the CCS timing driver information is specified but CCS timing receiver information is missing for the timing arc on pin of the cell. The CCS receiver data on arc is a mandatory if CCS driver model information is present. The valid CCS receiver model pairs are receiver\_capacitance1\_rise, receiver\_capacitance2\_rise and receiver\_capacitance1\_fall, receiver\_capacitance2\_fall. To fix the issue, re-characterize the library with appropriate settings, such that timing arc should be specified with both driver and receiver information.

# TECHLIB-1282

#### NAME

TECHLIB-1282

## **SUMMARY**

%s data has been defined on one or more %s for %s '%s' but is missing for the %s on %s of the cell.

## **DESCRIPTION**

Error and Warning Messages

This message is issued when the CCS timing/ECSM waveform/LVF/FIT data is specified on one or more timing arc on pin of the cell and missing for another timing arc on pin of the cell. Only those timing arcs will be considered which have slew tables present on them. The valid slew groups are rise\_transition, fall\_transition, retain\_rise\_slew, retain\_fall\_slew, ocv\_sigma\_rise\_transition, ocv\_sigma\_fall\_transition, ocv\_sigma\_cell\_rise, ocv\_sigma\_cell\_fall, ocv\_sigma\_rise\_constraint and ocv\_sigma\_fall\_constraint. To fix the issue, re-characterize the library with appropriate settings, such that CCS timing/ECSM waveform/LVF/FIT data is defined for all timing arcs of all pins of the cell.

# TECHLIB-1283

## **NAME**

TECHLIB-1283

## **SUMMARY**

The '%s' timing group is defined, but its corresponding '%s' timing group is missing for %s in cell '%s'.

## **DESCRIPTION**

The message is issued when the setup\_rising/setup\_falling timing\_type is defined but its corresponding timing\_type hold\_rising/hold\_falling is not defined in the timing group. To fix the issue, re-characterize the library with appropriate settings, such that setup and hold timing arcs are present in pair for fall/rise transitions.

## TECHLIB-1284

## **NAME**

TECHLIB-1284

## SUMMARY

The '%s' table indices do not match in %s timing group on line %d and %s timing group for %s in

cell '%s'

## DESCRIPTION

This message is issued when there is discrepancy in number of indices of rise\_constraint/fall\_constraint table for setup\_rising and hold\_rising timing group. To fix the issue, re-characterize the library with appropriate settings, such that the indices match in constraint tables.

# TECHLIB-1285

#### NAME

TECHLIB-1285

## **SUMMARY**

The sum of values in '%s' table of %s timing group on line %d and corresponding %s timing group, is below %fps for %s in cell '%s'

## DESCRIPTION

This message is issued when the sum of values of rise\_constraint/fall\_constraint table for setup\_rising/setup\_falling and corresponding hold\_rising/hold\_falling timing group is less than the minimum value. This sum can only be zero or any positive value specified using min\_value. To fix the issue, re-characterize the library with appropriate settings, such that the sum of values matches the specified value. Default value of min\_value is zero.

# TECHLIB-1286

## NAME

TECHLIB-1286

#### SUMMARY

Error and Warning Messages

%s data has been defined on one or more cells in the library, but is missing for cell '%s'.

## DESCRIPTION

This message is issued when the data for CCS timing/ECSM/LVF/FIT data is defined for one or more cell but missing on other cell in the same library. The valid slew groups are rise\_transition, fall\_transition, retain\_rise\_slew, retain\_fall\_slew, ocv\_sigma\_rise\_transition, ocv\_sigma\_fall\_transition, ocv\_sigma\_cell\_rise, ocv\_sigma\_cell\_fall, ocv\_sigma\_rise\_constraint and ocv\_sigma\_fall\_constraint. To fix the issue, re-characterize the library with appropriate settings, such that the CCS timing/ECSM waveform/LVF/FIT data is defined corresponding to all cell within the same library.

## TECHLIB-1287

## **NAME**

TECHLIB-1287

## SUMMARY

For point '%d' in index\_%d (%s) in '%s' table on %s of cell '%s', values %f to %f are not monotonically %s across the index\_%d (%s)

## DESCRIPTION

This message is issued when em\_max\_toggle\_rate table values (M x N), for a fixed point of index\_1/index\_2 of table indices do not monotonically increase/decrease across the index\_2/index\_1 axis. For example, in the em\_max\_toggle\_rate table, for a fixed value of slew index, the table values are not monotonically decreasing across the load axis or for fixed value of load index, the table values are not monotonically increasing across the slew axis. To fix the issue, re-characterize the library with appropriate settings, such that table values are monotonic as per liberty standard.

## NAME

TECHLIB-1288

### **SUMMARY**

Incorrect value '%s' specified for variable\_1 in 1-D %s '%s' in electomigration group defined on line %d defined in %s and direction '%s'.

## **DESCRIPTION**

For one dimensional template, variable\_1 can have only a specific value. For example, in 1-D electromigration template (em\_lut\_template) variable\_1 can only be 'input\_transition\_time'.

# TECHLIB-1290

#### NAME

TECHLIB-1290

## SUMMARY

The cell '%s' is a phase-locked loop cell but '%s' attribute is not defined on any pin of this cell.

## DESCRIPTION

This message is issued when attributes

is\_pll\_reference\_pin/is\_pll\_feedback\_pin/is\_pll\_output\_pin, are not defined for a pin of cell which is a phase-locked loop cell. These attributes are mandatory for phase-locked loop cell. To fix the issue, re-characterize the library with appropriate settings, such that the correct attributes are defined on the pin/cell.

## NAME

TECHLIB-1291

### SUMMARY

The '%s' attribute has been defined on more than one pin for cell '%s'. First definition at line %d would be retained and rest will be ignored.

## **DESCRIPTION**

This message is issued when the attributes is\_pll\_reference\_pin/is\_pll\_feedback\_pin are defined on more than one pin for a phase-locked loop cell. The same attribute cannot have multiple definition. First definition will be retained and rest will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined correctly.

## TECHLIB-1292

### NAME

TECHLIB-1292

## SUMMARY

The cell '%s' is not a phase-locked loop cell but has '%s' attribute specified for %s.

## DESCRIPTION

This message is issued when attributes is\_pll\_reference\_pin/is\_pll\_feedback\_pin/is\_pll\_output\_pin , have been defined for a pin of cell which is not a phase-locked loop (PLL) cell. Only phase-locked loop pins are expected to have phase-locked loop attributes defined on them. To fix the issue, recharacterize the library with appropriate settings, such that the correct attributes are defined on the pin/cell.

## NAME

TECHLIB-1293

## **SUMMARY**

For group '%s', number of vector groups defined is less than four.

## **DESCRIPTION**

There should be a minimum of four vector groups defined within an output\_current\_rise or output\_current\_fall group.

# TECHLIB-1294

#### NAME

TECHLIB-1294

## **SUMMARY**

For group '%s', less than two vector groups are defined having unique values of '%s'.

## **DESCRIPTION**

There should be a minimum of four vector groups defined within an output\_current\_rise or output\_current\_fall group. Current information should be specified for at least two different values of input slew and two different values of output load.

## NAME

TECHLIB-1295

## SUMMARY

Voltage (%0.3f) specified in nom\_voltage attribute does not match the voltage (%0.3f) specified in default\_operating\_conditions (%s) group.

## DESCRIPTION

The nominal voltage and the voltage specified in the default operating condition of the library must be identical.

# TECHLIB-1296

## NAME

TECHLIB-1296

## **SUMMARY**

CCS checks will not be thorough as library contains both CCS and ECSM data.

## **DESCRIPTION**

In case both CCS and ECSM data is present, ECSM data is given priority for timing and power.

## NAME

TECHLIB-1297

### SUMMARY

LDB generation could not complete. Refer to previously issued error messages in the session.

## **DESCRIPTION**

This message is issued when library has some serious errors which prevent LDB file generation. To fix the issue, re-characterize the library to fix the error messages issued in the session.

# TECHLIB-1298

## NAME

TECHLIB-1298

## **SUMMARY**

Number of '%s' specified is %d in generated\_clock group in cell '%s'. It must be odd number.

### DESCRIPTION

This message is issued when the number of edges/shifts are specified as even number in generated\_clock group. Number of edges/shifts must be an odd number. To fix the issue, recharacterize the library with appropriate settings, such that the generated clock is correctly defined.

## NAME

TECHLIB-1299

### SUMMARY

Number of specified 'edges' (%d) is not equal to number of specified 'shifts' (%d) in generated\_clock group in cell '%s'.

## **DESCRIPTION**

This message is issued when there is a mismatch in the number of edges and shifts in generated\_clock group. Number of edges must be equal to the number of shifts. To fix the issue, recharacterize the library with appropriate settings, such that the generated clock is correctly defined.

# TECHLIB-1300

## **NAME**

TECHLIB-1300

## SUMMARY

Invalid frequency %s factor '%d' specified in '%s' attribute in generated\_clock group in cell '%s'. It must be a power of 2.

## **DESCRIPTION**

This message is issued when the invalid frequency multiplication factor or division factor is specified for the attribute multiplied\_by/divided\_by in generated\_clock group. The factor must be a power of two. To fix the issue, re-characterize the library with appropriate settings, such that the generated clock is correctly defined.

## NAME

TECHLIB-1301

### SUMMARY

Invalid generated clock definition in cell '%s'. Attribute(s) '%s' are not allowed together.

## **DESCRIPTION**

This message is issued when the generated\_clock group is defined incorrectly. The attribute divide\_by can not be combined with any of these 'multiply\_by', 'edges', 'shift' and the attribute 'multiply\_by' can not be combined with any of these 'divide\_by', 'edges', 'shift'. To fix the issue, recharacterize the library with appropriate settings, such that the generated clock is correctly defined.

# TECHLIB-1302

## NAME

TECHLIB-1302

## SUMMARY

First edge specified in '%s' is %d in generated\_clock group in cell '%s'. It must be greater than equal to 1.

## DESCRIPTION

This message is issued when the first edge is specified as less than 1 in generated\_clock group. The first edge must be greater than or equal to 1. To fix the issue, re-characterize the library with appropriate settings, such that the correct value of first edge is specified.

#### **NAME**

TECHLIB-1303

### SUMMARY

Number of '%s' specified is %d in generated\_clock group in cell '%s'. It must be greater than or equal to 3

## **DESCRIPTION**

This message is issued when the number of edges specified is less than three in generated\_clock group. The number of edges must be greater than or equal to 3. To fix the issue, re-characterize the library with appropriate settings, such that the correct value of number of edges is defined.

# TECHLIB-1304

## **NAME**

TECHLIB-1304

## SUMMARY

Invalid generated\_clock definition in cell '%s'. Attribute 'shifts' is specified without attribute 'edges'.

## **DESCRIPTION**

This message is issued when the shifts are specified but edges are not specified in generated\_clock group. Both are required as the shifts are added to the edges specified in the edge list to generate the clock. To fix the issue, re-characterize the library with appropriate settings, such that the edges should be defined if shifts are specified.

## NAME

TECHLIB-1305

## SUMMARY

The edges specified must be monotonically increasing in generated\_clock group in cell '%s'.

## **DESCRIPTION**

This message is issued when the edges specified in generated\_clock group of cell do not monotonically increase. To fix the issue, re-characterize the library with appropriate settings, such that the edges defined are monotonic.

# TECHLIB-1306

## NAME

TECHLIB-1306

## SUMMARY

The group %s with name '%s' already defined for %s of cell %s. This will be ignored

## **DESCRIPTION**

The ecsm\_waveform group with same name already exists. First will be retained and rest will be ignored

## NAME

TECHLIB-1307

### **SUMMARY**

The %s group contains values which are not monotonically %s from %f to %f for %s %f and %s %f in group %s.

## **DESCRIPTION**

This message is issued when ecsm\_waveform\_set table values (PxQxR), for a fixed point of two of table indices do not monotonically increase/decrease across the third axis. For example, in the ecsm\_waveform\_set table, for a fixed value of slew index and load index, the table values are not monotonically increasing across the values axis. To fix the issue, re-characterize the library with appropriate settings, such that table values are monotonic as per Liberty standard.

## TECHLIB-1308

#### NAME

TECHLIB-1308

## **SUMMARY**

The user defined group '%s' defined on parent group '%s' has missing 'define\_group' statement at library level. However, group data will be honored.

## **DESCRIPTION**

This message is issued when certain user defined groups are used but not defined at library level using define\_group statements. In such cases, Cadence tools will accept the data but other tools may not do so. It is recommended that library is re-characterized such that undefined user-defined

groups are not used.

# TECHLIB-1309

## **NAME**

TECHLIB-1309

#### SUMMARY

For point '%d' in index\_%d (%s) in '%s' table on %s of cell '%s', values %f to %f are not monotonically %s across the index\_%d (%s)

## DESCRIPTION

This message is issued when delay table values (M x N), for a fixed point of index\_1/index\_2 of table indices do not monotonically increase/decrease across the index\_2/index\_1 axis. For example, in the cell\_rise table, for a fixed value of slew index, the table values are not monotonically decreasing across the load axis or for fixed value of load index, the table values are not monotonically increasing across the slew axis. To fix the issue, re-characterize the library with appropriate settings, such that table values are monotonic as per Liberty standard.

# TECHLIB-1310

## NAME

TECHLIB-1310

#### SUMMARY

The %s group contains values which are not monotonically %s from %f to %f for %s %f and %s %f in group %s.

## **DESCRIPTION**

Error and Warning Messages

This message is issued when delay table values (PxQxR), for fixed point of two of table indices do not monotonically increase/decrease across the third axis. For example, in the cell\_rise table, for a fixed value of load index and load index1, the table values are not monotonically increasing across the slew axis. To fix the issue, re-characterize the library with appropriate settings, such that table values are monotonic as per Liberty standard.

# TECHLIB-1311

#### NAME

TECHLIB-1311

## SUMMARY

For point '%d' in index\_%d (%s) in '%s' table on %s of cell '%s', values %f to %f are not monotonically %s across the index %d (%s)

## DESCRIPTION

This message is issued when transition table values (M x N), for a fixed point of index\_1/index\_2 of table indices do not monotonically increase/decrease across the index\_2/index\_1 axis. For example, in the rise\_transition table, for a fixed value of slew index, the table values are not monotonically decreasing across the load axis or for fixed value of load index, the table values are not monotonically increasing across the slew axis. To fix the issue, re-characterize the library with appropriate settings, such that table values are monotonic as per Liberty standard.

## TECHLIB-1312

## **NAME**

TECHLIB-1312

## SUMMARY

The %s group contains values which are not monotonically %s from %f to %f for %s %f and %s %f in group %s.

This message is issued when transition table values (PxQxR), for fixed point of two of table indices do not monotonically increase/decrease across the third axis. For example, in the rise\_transition table, for a fixed value of load index and load index1, the table values are not monotonically increasing across the slew axis. To fix the issue, re-characterize the library with appropriate settings, such that table values are monotonic as per Liberty standard.

## TECHLIB-1313

## NAME

TECHLIB-1313

### SUMMARY

For cell '%s', in group '%s', voltage swing on pin/bus/bundle '%s' with load '%f' and slew '%f' is '%.1f%', should at least reach second slew threshold.

## DESCRIPTION

This message is issued when the voltage swing defined for cell on pin/bus/bundle in output\_current\_rise /output\_current\_fall vector group with specified load and slew is not reaching the second slew threshold. To fix the issue, re-characterize the library with appropriate settings, such that the full voltage swing is reached.

# TECHLIB-1314

#### NAME

TECHLIB-1314

## **SUMMARY**

For cell '%s', in group '%s', voltage swing on pin/bus/bundle '%s' with load '%f' and slew '%f' is '%.1f%', should at least reach second slew threshold.

This message is issued when the voltage swing defined for cell on pin/bus/bundle in output\_current\_rise /output\_current\_fall vector group with specified load and slew is not reaching the second slew threshold.

## TECHLIB-1315

## **NAME**

TECHLIB-1315

## **SUMMARY**

For cell '%s', pg\_pin groups %s share the same voltage\_name '%s'. These PG pins cannot have same voltage\_name. These PG pins definitions will be ignored.

## **DESCRIPTION**

This message is issued when the same voltage\_name is specified on the pins among opposite(power/ground) category of pg\_type. The power category includes pins with pg\_type as primary\_power/backup\_power/internal\_power/nwell/deepnwell and ground category includes pins with pg\_type as primary\_ground/backup\_ground/internal\_ground/pwell/deeppwell for the cell for pg\_pin group. Such pins will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the pg\_pin(s) of opposite type are not defined with same voltage.

## TECHLIB-1316

#### NAME

TECHLIB-1316

## **SUMMARY**

For MSV cell '%s', pg\_pin groups %s share the same voltage\_name '%s'. These PG pins cannot have same voltage name. This library will be ignored.

This message is issued when the same voltage\_name is specified on the pins among opposite(power/ground) category of pg\_type. The power category includes pins with pg\_type as primary\_power/backup\_power/internal\_power/nwell/deepnwell and ground category includes pins with pg\_type as primary\_ground/backup\_ground/internal\_ground/pwell/deeppwell for MSV cell for pg\_pin group. Such library will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the pg\_pin(s) are not defined with same voltage.

## TECHLIB-1317

#### NAME

TECHLIB-1317

## SUMMARY

Timing library contains '%s' attribute/group, these will be ignored. To enable loading these data, specify 'set timing\_library\_enable\_advanced\_capacitance\_support 1' before loading the libraries in flow

## DESCRIPTION

Support for advanced capacitance data in libraries is enabled under global variable timing\_library\_enable\_advanced\_capacitance\_support. This global variable must be set before read lib or read view definition command in the flow.

## TECHLIB-1318

#### NAME

TECHLIB-1318

## **SUMMARY**

All the table values in the '%s' group on %s of cell '%s' are within '%f' of each other.

This message is issued when all the values defined in any of the cell\_rise/cell\_fall/ rise\_transition/fall\_transition table are within default threshold (0.00001). To fix the issue, recharacterize the library with appropriate settings, such that the table values defined are reasonable.

## TECHLIB-1319

## **NAME**

TECHLIB-1319

## **SUMMARY**

The user-defined attribute '%s' is defined for group '%s' with type '%s'. This is an invalid definition.

## DESCRIPTION

This message is issued when the define statement for user-defined attributes (related\_spice\_node/load\_cap\_rise/load\_cap\_fall) is not specified with appropriate group or type. The related\_spice\_node should be specified for ccsn\_first\_stage/ccsn\_last\_stage groups with type string and load\_cap\_rise/load\_cap\_fall should be specified for ccsn\_first\_stage group with type float. To fix the issue, re-characterize the library with appropriate settings, such that the required user-defined attributes are defined properly.

# TECHLIB-1320

## **NAME**

TECHLIB-1320

## SUMMARY

The user-defined attribute '%s' is not present in any of the '%s' group. This attribute is required for Tempus if SPICE correlation of ROP glitch needs to be performed. The missing attribute does not affect SI delay or glitch analysis.

Error and Warning Messages

## DESCRIPTION

This message is issued when the user-defined attribute related\_spice\_node attribute is not present in library. To fix the issue, re-characterize the library with appropriate settings, such that the required user-defined attributes are defined and used properly.

## TECHLIB-1321

### NAME

TECHLIB-1321

## **SUMMARY**

The %sattribute '%s' is not specified in the group '%s' on %s of cell '%s'.

## DESCRIPTION

This message is issued when the related\_spice\_node/load\_cap\_rise/load\_cap\_fall attribute is defined in library but is not specified on corresponding group ccsn\_first\_stage/ccsn\_last\_stage, or, in cases where related\_ccb\_node is missing on an input\_ccb group. To fix the issue, recharacterize the library with appropriate settings, such that the required user-defined attributes are specified properly.

## TECHLIB-1322

#### NAME

TECHLIB-1322

#### SUMMARY

In cell '%s', on %s, the user-defined attribute '%s' with value '%f' is not in the reasonable range of [%f, %f].

Error and Warning Messages

## DESCRIPTION

The attribute load\_cap\_rise/load\_cap\_fall doesn't have proper load\_cap\_rise/fall value. It should be within range(min, max) value of rise/fall pin capacitance. Attributes capacitance/rise\_capacitance/fall\_capacitance/rise\_capacitance\_range/fall\_capacitance\_range are considered for calculating min/max value to find reasonable range. Min value is defined as 0.001 times of lowest NLDM Pin cap value and max value is defined as 5 times of highest NLDM Pin cap value defined on the cell.

# TECHLIB-1323

#### NAME

TECHLIB-1323

## **SUMMARY**

The define statement of user-defined %s is not valid. The definition contains %d parameters instead of %d parameters.

## DESCRIPTION

The define statement should follow the syntax as: 'define(attr\_name, group\_name, attr\_value\_type);'. To fix the issue, re-characterize the library with appropriate settings, such that the required user-defined attributes are defined properly.

# TECHLIB-1324

## NAME

TECHLIB-1324

#### SUMMARY

The specified type '%s' of user-defined attribute '%s' is invalid. It will be taken as string as default.

The type of user-defined attribute should one of these: integer, boolean, string and float. To fix the issue, re-characterize the library with appropriate settings, such that the required user-defined attributes are defined properly.

# TECHLIB-1325

## **NAME**

TECHLIB-1325

## **SUMMARY**

The specified parent group '%s' of user-defined %s '%s' is invalid. This definition will be ignored.

#### DESCRIPTION

The parent group of user-defined attribute or group should be either a standard group as per liberty or it should be a user-defined group which is defined using define\_group statement. To fix the issue, re-characterize the library with appropriate settings, such that the required user-defined attributes are defined properly.

# TECHLIB-1327

#### NAME

TECHLIB-1327

## **SUMMARY**

The 'retention\_pin' attribute on the pin '%s' in cell '%s' is honored, even though the 'retention\_cell' attribute is missing at cell level.

## **DESCRIPTION**

Error and Warning Messages

It is advisable to have the retention\_cell attribute set on a cell having a retention pin. The retention cell simple attribute identifies a retention cell.

## TECHLIB-1329

## NAME

TECHLIB-1329

## **SUMMARY**

The attribute '%s' on the %s in cell '%s' is missing, even though the cell has multiple supply voltages.

## **DESCRIPTION**

This message is issued when the attributes related\_power\_pin or related\_ground\_pin is not specified on the pin in cell and cell is marked as MSV cell. These are mandatory attributes for MSV cell. To fix the issue, re-characterize the library with appropriate settings, such that the related\_power\_pin or related\_ground\_pin is specified on the pin in cell.

# TECHLIB-1330

#### NAME

TECHLIB-1330

## **SUMMARY**

The attribute '%s' on the %s in cell '%s' is missing, it will be considered as standard cell.

#### DESCRIPTION

This message is issued when the attributes related\_power\_pin or related\_ground\_pin is not specified on the pin in cell and cell has multiple pg pins but only one pg pin is used as

Error and Warning Messages

related\_power\_pin. Such cell will be considered as standard cell. To fix the issue, re-characterize the library with appropriate settings, such that the related\_power\_pin or related\_ground\_pin is specified on the pin in cell

# TECHLIB-1331

#### NAME

TECHLIB-1331

#### SUMMARY

The pg\_pin '%s' with pg\_type '%s' cannot be used in '%s' attribute for pin '%s' of the cell '%s'. This attribute is being ignored which may impact analysis accuracy.

## DESCRIPTION

This message is issued when the pg\_pin specified with related\_power\_pin/related\_ground\_pin does not match with the corresponding pg\_type e.g. pg\_pin VDD with pg\_type as primary\_power is used in related\_ground\_pin. These attributes will be ignored which may impact analysis accuracy. To fix the issue, re-characterize the library with appropriate settings, such that the incompatible pg\_pin is not used.

# TECHLIB-1332

## NAME

TECHLIB-1332

### SUMMARY

The ecsm waveform associated with '%s' group of pin '%s' in cell '%s' will be ignored due to incorrect voltage values.

## **DESCRIPTION**

Error and Warning Messages

This message is issued when the voltage values specified in ecsm\_waveform/ecsm\_waveform\_set is either outside of range [0.02, 0.098] or are too close (less than 0.01 difference between two consecutive values), then that point will be ignored and if after applying this criteria, there are less than 2 values left in voltage grid then the complete group in the rise\_transition and fall\_transition group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the correct voltage values is specified

## TECHLIB-1333

## NAME

TECHLIB-1333

#### SUMMARY

The %s value defined in index %d (%s) of group '%s' on %s of cell '%s' is '%f' which is %s '%f'.

## **DESCRIPTION**

This message is issued when the first/last value defined in input\_voltage or output\_voltage indices on pin of cell is above VSS/below VDD of dc\_current group. The first value of input\_voltage/output\_voltage indices must be less than or equal to VSS and last value of input\_voltage/output\_voltage indices must be greater than or equal to VDD. To fix the issue, recharacterize the library with appropriate settings, such that the input\_voltage/output\_voltage indices of dc\_current group are correctly defined.

## TECHLIB-1334

## **NAME**

TECHLIB-1334

#### SUMMARY

Identified one or more of the required attributes/groups missing from '%s' group defined %s of cell '%s'. When the stage type is '%s', the required attributes/groups are %s. This may impact analysis

Error and Warning Messages

accuracy.

## DESCRIPTION

This message is issued when the required attributes/groups are missing from ccsn\_\*\_stage. The required attributes/groups are when stage\_type is both: miller\_cap\_rise, miller\_cap\_fall, dc\_current, output\_voltage\_rise, output\_voltage\_fall, when stage\_type is pull\_up: miller\_cap\_rise, dc\_current, output\_voltage\_rise, when stage\_type is pull\_down: miller\_cap\_fall, dc\_current, output\_voltage\_fall. This may impact analysis accuracy. To fix the issue, re-characterize the library with appropriate settings, such that the CCSN groups are correctly defined.

# TECHLIB-1335

#### NAME

TECHLIB-1335

## **SUMMARY**

The timing sense and sense of the group '%s' specified on timing arc on %s of cell '%s' is '%s' are inconsistent.

## DESCRIPTION

This message is issued when the timing sense is inconsistent with the sense of the ccsn\_\*\_stage group on the arc. The arc sense must match the combination i.e. chaining of the ccsn\_\*\_stage senses; for example, an inverting arc must contain only a single inverting ccsn\_first\_stage group or an inverting ccsn\_first\_stage group, and a non-inverting ccsn\_last\_stage group, or a non-inverting ccsn\_first\_stage group and an inverting ccsn\_last\_stage group. To fix the issue, re-characterize the library with appropriate settings, such that the timing sense of the arc should be consistent with sense of the ccsn\_\*\_stage group.

## NAME

TECHLIB-1336

### SUMMARY

The first or last value in %s attribute is not equal %d or %d respectively. The attribute will be ignored.

## **DESCRIPTION**

This message is issued when the first/last value of the attribute receiver\_capacitance\_rise\_threshold\_pct/receiver\_capacitance\_fall\_threshold\_pct is incorrectly defined. The valid value of first and last point for receiver\_capacitance\_rise\_threshold\_pct attribute is [0.0, and 100] and for receiver\_capacitance\_fall\_threshold\_pct attribute is [100, and 0.0]. Such attribute will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the threshold values are correctly defined at library level.

# TECHLIB-1337

## NAME

TECHLIB-1337

## **SUMMARY**

The library has '%s' groups defined but the '%s' definition is missing from library group. All '%s' groups will be ignored.

## **DESCRIPTION**

This message is issued when the attribute receiver capacitance rise threshold pct/receiver capacitance fall threshold pct is missing at

Error and Warning Messages

library level but receiver\_capacitance\_rise/receiver\_capacitance\_fall groups are defined. Complete set of receiver\_capacitance groups will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the threshold values are not undefined.

## TECHLIB-1338

#### NAME

TECHLIB-1338

## **SUMMARY**

The segment value for '%s' group for %s and cell '%s' has value %d which is not in the expected range [1, %d]. The group will be ignored.

## DESCRIPTION

This message is issued when the attribute segment defined for receiver\_capacitance\_rise/receiver\_capacitance\_fall group is out of range as per segment definition. The valid range of segment attribute is 1 to N where N is the number of {threshold points - 1} defined in the attribute

receiver\_capacitance\_rise\_threshold\_pct/receiver\_capacitance\_fall\_threshold\_pct. For example if seven threshold points are defined then valid range of segment attribute would be {threshold points -1} that is six. Complete set of receiver\_capacitance groups will be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the segment values are defined correctly.

## **TECHLIB-1339**

## **NAME**

TECHLIB-1339

## SUMMARY

The '%s' groups for all segments in the range [1, %d] for %s and cell '%s' are not defined. The

segment '%d' is missing. The '%s' groups will be ignored.

#### DESCRIPTION

This message is issued when the receiver\_capacitance\_rise/receiver\_capacitance\_fall group for all the segments is not defined. The valid range of segment attribute is 1 to N where N is the number of {threshold points -1} defined in the attribute

receiver\_capacitance\_rise\_threshold\_pct/receiver\_capacitance\_fall\_threshold\_pct. Complete set of receiver\_capacitance groups will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the receiver\_capacitance groups are defined for all segment values.

# TECHLIB-1340

#### NAME

TECHLIB-1340

## **SUMMARY**

The value %s specified for variable\_%d for '%s' group '%s' is invalid. This template group is used in '%s' (line %d). For this group valid variable values are %s only. The group '%s' will be ignored.

## **DESCRIPTION**

This message is issued when invalid variable is defined in the template used for specifc groups. For example variable time specified for the receiver\_capacitance\_rise/receiver\_capacitance\_fall group is invalid, the valid values are input\_net\_transition and total\_output\_net\_capacitance. These groups with invalid template will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the defined variable should be valid.

# TECHLIB-1341

## NAME

TECHLIB-1341

Error and Warning Messages

#### SUMMARY

The %s index values for '%s' group (line %d) for %s and cell '%s' do not match among all segments. These '%s' groups will be ignored.

## DESCRIPTION

This message is issued when there is mismatch in the index values of input\_net\_transition/total\_output\_net\_capacitance defined for receiver\_capacitance\_rise/receiver\_capacitance\_fall group at pin or timing level. Complete set of receiver\_capacitance groups will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the index values should be same.

# TECHLIB-1342

## **NAME**

TECHLIB-1342

## **SUMMARY**

The %s group with segment value '%d' is redefined at line %d for %s and cell '%s'. The last definition will be considered.

## DESCRIPTION

This message is issued when the receiver\_capacitance\_rise/receiver\_capacitance\_fall group with the same segment value is defined more than once at pin or timing level. The multiple definition of same segment value is not allowed. Last definition will be considered and rest will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the segment value is correctly defined.

#### NAME

TECHLIB-1343

#### **SUMMARY**

The %s group can have only one or two dimensional tables. All %s groups for %s and cell '%s' will be ignored.

### **DESCRIPTION**

This message is issued when the dimensions of receiver\_capacitance\_rise/receiver\_capacitance\_fall table is more than two. The receiver\_capacitance group can have only one or two dimensional tables. Complete set of receiver\_capacitance groups will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the table dimension should be correct.

### TECHLIB-1344

#### NAME

TECHLIB-1344

#### **SUMMARY**

The size of %s tables for %s and cell '%s' do not match among all segments. All '%s' groups will be ignored.

### **DESCRIPTION**

This message is issued when there is mismatch in the size of receiver\_capacitance\_rise/receiver\_capacitance\_fall tables among all the segments defined at pin or timing level. Complete set of receiver capacitance groups will be ignored. To fix the issue, re-

Error and Warning Messages

characterize the library with appropriate settings, such that the receiver\_capacitance tables should be matched.

## TECHLIB-1345

#### NAME

TECHLIB-1345

### **SUMMARY**

This library contains both multi-segmented CCS receiver capacitance models and the older two piece receiver capacitance models. The multi-segmented CCS receiver capacitance models will be used in analysis.

#### **DESCRIPTION**

This message is issued when the library contains both multi-segmented CCS receiver capacitance model and the two piece receiver capacitance model. The multi-segmented CCS receiver capacitance models will be used for analysis.

## TECHLIB-1346

#### NAME

TECHLIB-1346

### **SUMMARY**

The attribute '%s' defined in group '%s' on line %d is not monotonically %s for values '%f' to '%f'. This may lead to undesirable analysis results. The attribute will be ignored.

### **DESCRIPTION**

The message is issued when an attribute range does not increase or decrease monotonically as

Error and Warning Messages

per the Liberty standard or convention. For example, instead of the expected range of monotonically increasing index\_1: (1, 2, 3, 4, 5), the range defined in library is index\_1: (1, 2, 3, 2, 3). To fix the issue, re-characterize the library with appropriate settings.

## TECHLIB-1347

#### NAME

TECHLIB-1347

#### SUMMARY

Identified mismatch in the number of pins specified in the attributes pin\_names and pin\_name\_map for the cell '%s' for sensitization group '%s'. The sensitization group for that cell will be ignored.

#### **DESCRIPTION**

This message is issued when there is mismatch in the number of pins specified in pin\_names attribute at library level and pin\_name\_map attribute at cell/timing level for the sensitization group. The sensitization group for that cell will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the pins are correctly defined.

# TECHLIB-1348

### NAME

TECHLIB-1348

#### SUMMARY

Referred sensitization group '%s' in cell '%s' is not defined at library level. The sensitization group for that cell will be ignored.

Error and Warning Messages

This message is issued when the sensitization group name specified in sensitization\_master attribute at cell/timing level is not defined at library level. The sensitization group for that cell will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the undefined sensitization group is not referred.

# TECHLIB-1349

#### NAME

TECHLIB-1349

#### **SUMMARY**

The attributes '%s' defined with value ('%d') for cell '%s' is invalid, the value should not be 0.

#### DESCRIPTION

This message is issued when the attributes wave\_rise\_sampling\_index and wave\_fall\_sampling\_index are defined with '0' value in sensitization group. Such attribute will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined correctly.

# TECHLIB-1350

### NAME

TECHLIB-1350

#### SUMMARY

The attribute '%s' defined with value '%d' for cell '%s' is invalid, the value should not be greater than the number of entries in {wave rise/wave fall} -1 ('%d').

Error and Warning Messages

This message is issued when the attributes wave\_rise\_sampling\_index and wave\_fall\_sampling\_index are defined with the value which is greater than the number of entries in {wave\_rise/wave\_fall} -1. Such attribute will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined correctly.

# TECHLIB-1351

#### NAME

TECHLIB-1351

### **SUMMARY**

The number of entries ('%d') in the attribute '%s' defined for cell '%s' is greater than the number of entries in {wave\_rise/wave\_fall}-1 ('%d'). The attribute will be ignored.

#### **DESCRIPTION**

This message is issued when the number of entries defined in the attributes wave\_rise\_time\_interval and wave\_fall\_time\_interval are greater than the number of entries in {wave\_rise/wave\_fall} -1. Such attribute will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined correctly.

## TECHLIB-1352

### **NAME**

TECHLIB-1352

#### **SUMMARY**

The attribute '%s' has undefined vector ID (%d) for the sensitization group (%s) specified for cell '%s'. The attribute is ignored.

Error and Warning Messages

This message is issued when the attributes wave\_rise and wave\_fall are defined with incorrect vector ID in the sensitization group. Such attribute will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined correctly.

## TECHLIB-1353

#### NAME

TECHLIB-1353

#### SUMMARY

The vector ID ('%d') defined is already present in sensitization group '%s'. Last definition of the vector ID will be considered. Vector ID should be unique.

#### DESCRIPTION

This message is issued when the sensitization group has two or more vectors with the same vector ID. If duplicate vector IDs are present then tool will use the last vector with that ID. To fix the issue, re-characterize the library with appropriate settings, such that the vector ID defined should be unique.

# TECHLIB-1354

### **NAME**

TECHLIB-1354

#### SUMMARY

The sensitization\_master attribute is not present in cell '%s' but cell contains sensitization information. Sensitization group information for that cell will be ignored.

Error and Warning Messages

This message is issued when the sensitization\_master attribute is not defined at cell level but cell contains sensitization information. sensitization\_master attribute is required attribute if cell contains sensitization information. Sensitization group information for that cell will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the attribute is completely specified.

# TECHLIB-1355

#### NAME

TECHLIB-1355

#### SUMMARY

Pin '%s' specified in pin\_name\_map attribute at cell/timing level is either not present or refers to bus/bundle in cell '%s'. The sensitization group for that cell will be ignored.

#### **DESCRIPTION**

This message is issued when the pin specified for the sensitization in the pin\_name\_map attribute at cell or timing level either does not exist or refers to bus/bundle in cell. The sensitization group for that cell will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the pins are correctly specified.

## TECHLIB-1356

#### NAME

TECHLIB-1356

### **SUMMARY**

The number of pins in pin\_names ('%d') do not match with the number of pins specified ('%d') in the vector attribute of sensitization group '%s'.

Error and Warning Messages

#### DESCRIPTION

This message is issued when the size of the attribute pin\_names does not match with the number of columns of the second argument of vector attribute in the sensitization group. All the attributes defined for the sensitization group for that cell/timing will be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the size of pin\_names attribute is defined correctly.

# TECHLIB-1357

### NAME

TECHLIB-1357

#### SUMMARY

The attribute vector defined with vector ID ('%d') in sensitization group '%s' is negative. Vector ID should not be negative.

#### DESCRIPTION

This message is issued when the attribute vector is specified with negative vector ID in the sensitization group. Such vector attribute will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the vector ID is defined correctly.

## TECHLIB-1358

### **NAME**

TECHLIB-1358

#### SUMMARY

One or more vector values defined in the vector with ID '(%d)' in sensitization group '%s' are invalid. This vector attribute will be ignored

This message is issued when the attribute vector is specified with invalid value in the sensitization group. The valid values are  $\{0,1,X,Z\}$ . The attribute vector will be ignored. To fix the issue, recharacterize the library with appropriate settings, such that the vector values are defined correctly.

## TECHLIB-1359

#### NAME

TECHLIB-1359

#### **SUMMARY**

Timing library contains both 2-piece and multi-piece receiver capacitance data. Multi-piece receiver capacitance data will be ignored. To use multi-piece receiver capacitance data for timing analysis, specify 'set timing\_library\_enable\_advanced\_capacitance\_support 1' before loading the libraries in flow.

#### **DESCRIPTION**

Support for advanced capacitance data in libraries is enabled under global variable timing\_library\_enable\_advanced\_capacitance\_support. If library contains both 2-piece and N-piece receiver capacitance data, tool will load 2-piece capacitance data by default. To enable loading of N-piece receiver capacitance data, this global variable must be set before read\_lib or read\_view\_definition command in the flow.

### **TECHLIB-1360**

#### NAME

TECHLIB-1360

#### **SUMMARY**

The voltage values for %s group in '%s' is not %s at point close to %f (%s at '%f'). The value should

%s in the tolerance range of %f.

### **DESCRIPTION**

The voltage waveform for rise/fall transition should start at point close to 0/1 and end at close to 1/0.

# TECHLIB-1361

#### NAME

TECHLIB-1361

### **SUMMARY**

The number of index/values points found is '%d'. The number of sample points(index/values) should be 10 or more than 10 for accurate delay calculation.

### **DESCRIPTION**

The number of sample time and voltage points should be more than 10 for accurate delay calculation.

# TECHLIB-1362

#### **NAME**

TECHLIB-1362

### **SUMMARY**

The sample points for ECSM waveform number %d in %s transition are not near the %s threshold.

Error and Warning Messages

The number of sample time and voltage points should be more than 10 for accurate delay calculation.

# TECHLIB-1363

#### NAME

TECHLIB-1363

### **SUMMARY**

The slew value %f for ECSM waveform number %d in %s transition for %s of cell '%s' does not match the corresponding NLDM slew value %f.

### **DESCRIPTION**

This message is issued when the slew value calculated from ECSM waveform (e.g slew = time values at (upper slew threshold-lower slew threshold)) for rise/fall transition does not match with corresponding NLDM slew value. This can cause delay calculation discrepancies.

## TECHLIB-1364

#### NAME

TECHLIB-1364

### SUMMARY

The attribute '%s' is defined but the attribute '%s' is not defined in '%s' group. The attribute '%s' will be ignored.

### **DESCRIPTION**

This message is issued when defining one attribute alone is not sufficient, but another attribute which is also mandatorily needed to be defined with that attribute, is missing.

#### NAME

TECHLIB-1365

#### SUMMARY

The %s vector group for %s has a duplicate definition (line '%d') on %s and cell '%s'. The duplicate definition will be ignored.

#### **DESCRIPTION**

This message is issued when the vector group specified in output\_voltage\_rise/output\_voltage\_fall group for ccsn\_first\_stage/ccsn\_last\_stage group or output\_current\_rise/output\_current\_fall for timing group is defined more than once with the same value of 'total\_output\_net\_capacitance' and 'input\_net\_transition'. Multiple definition of vector group with same values of 'total\_output\_net\_capacitance' and 'input\_net\_transition' is not allowed. To fix the issue, recharacterize the library with appropriate settings, such that the vector group defined is unique.

## TECHLIB-1366

#### NAME

TECHLIB-1366

### **SUMMARY**

All combinations of %s in vector groups(s) of %s are not defined. The definition for %s vector group(s) is missing on %s and cell %s. The group will be ignored.

### **DESCRIPTION**

This message is issued when any of the combination of input\_net\_transition and

Error and Warning Messages

total\_output\_net\_capacitance defined in vector group for the output\_voltage\_rise/output\_voltage\_fall group in ccsn\_first\_stage/ccsn\_last\_stage group or output\_current\_rise/output\_current\_fall for timing group is missing. To fix the issue, re-characterize the library with appropriate settings, such that the vector groups are defined for all combination of input net transition and total output net capacitance.

## TECHLIB-1367

#### NAME

TECHLIB-1367

#### SUMMARY

The delay value '%f' calculated for CCS waveform for '%s' vector group on %s of cell '%s' does not match with the corresponding NLDM delay value '%f' at line '%d' and has '%.2g%%' error

#### **DESCRIPTION**

This message is issued when there is mismatch in delay value calculated for CCS timing waveform and its corresponding NLDM delay value. The percentage error is calculated with reference to NLDM delay value.

## TECHLIB-1368

### **NAME**

TECHLIB-1368

### **SUMMARY**

The slew value '%f' calculated for CCS waveform for '%s' vector group on %s of cell '%s' does not match with the corresponding NLDM slew value '%f' at line '%d' and has '%.2g%%' error

Error and Warning Messages

This message is issued when there is mismatch in slew value calculated for CCS timing waveform and its corresponding NLDM slew value. The percentage error is calculated with reference to NLDM slew value.

### TECHLIB-1369

#### NAME

TECHLIB-1369

#### SUMMARY

Design loading is aborted as the input ldb '%s' is not compatible with the current tool settings which enable support for advanced pin capacitance in library. It is recommended to either re-compile the ldb using write\_ldb command with current tool version or turn off the global 'timing\_library\_enable\_advanced\_capacitance\_support' to proceed.

#### DESCRIPTION

This message is issued when global 'timing\_library\_enable\_advanced\_capacitance\_support' is on to enable support of libraries with multi-piece CCS capacitance or ecsm\_capacitance\_set library constructs but input ldb provided is generated with version prior to Tempus 15.2 or Innovus 16.1 release. Such ldb files are incompatible with advanced pin capacitance feature support. User must either re-compile the ldb file with current tool version (or at least version newer than Tempus 15.2 or Innovus 16.1) if advanced capacitance feature is to be used or else turn off the global to disable the feature.

## **TECHLIB-1370**

### **NAME**

TECHLIB-1370

### **SUMMARY**

Identified inconsistency between function and timing sense for timing arc on pin '%s' of cell '%s'

This message is issued when the timing sense defined for timing arc is not consistent with the function of pin. For example, in case of inverter, which has function '!A' then arc should have a negative\_unate timing sense. To fix the issue, re-characterize the library with appropriate settings, such that the timing sense and function are consistent.

### TECHLIB-1371

#### NAME

TECHLIB-1371

#### SUMMARY

The '%s' pin '%s' defined for cell '%s' in library '%s' is either not defined or defined with different direction in the cell '%s' in library '%s'. The design loading will be aborted.

### **DESCRIPTION**

This message is issued when either the pin is defined for cell in one library and not defined for the same cell in other library or pins are defined with different direction. For example: Pin(A) defined as input pin for cell in one library and is not defined or defined as output pin in other library. Design loading will be aborted. To fix the issue, re-characterize the libraries with appropriate settings, such that the pins of same cell across libraries are consistent

## TECHLIB-1372

### **NAME**

TECHLIB-1372

#### SUMMARY

Scalar table specified for '%s' group defined on %s of cell '%s' is not supported. This group will be ignored.

This message is issued when the scalar table is specified for ecsm\_capacitance group. Such ecsm\_capacitance group will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the tables are specified with correct dimension.

## TECHLIB-1374

#### **NAME**

TECHLIB-1374

### **SUMMARY**

The normalized\_driver\_waveform %s is already defined on line %d. The first definition will be retained, rest will be ignored.

### DESCRIPTION

This message is issued when the normalized\_driver\_waveform group is defined multiple times either with same driver\_waveform\_name or without driver\_waveform\_name at library level. The first definition will be retained and rest will be ignored. To fix the issue, re-characterize the library with appropriate settings, such that the normalized\_driver\_waveform groups defined at library level are unique.

## TECHLIB-1377

### **NAME**

TECHLIB-1377

#### **SUMMARY**

Invalid data\_type '%s' is specified with command option -liberty\_incremental. Valid values of data type is ccs\_power.

This message is issued when data\_type specified with command option -liberty\_incremental is invalid. Valid values of data\_type is ccs\_power. To fix the issue, specify the correct data\_type.

# TECHLIB-1378

#### NAME

TECHLIB-1378

#### **SUMMARY**

Attribute driver\_waveform\_name '%s' specified with '%s' in set\_normalized\_driver\_waveform command is not defined in reference library '%s'. The command will be ignored.

#### DESCRIPTION

This message is issued when the driver\_waveform\_name specified with command option 'set\_normalized\_driver\_waveform\_lib -rise\_waveform/fall\_waveform' is not defined in reference library. To fix the issue, specify the correct driver\_waveform\_name.

## TECHLIB-1379

### NAME

TECHLIB-1379

#### SUMMARY

An inconsistency was found due to power arc defined on pin '%s' of cell '%s' between first library '%s' and second library. The power arc with attribute(s) '%s' is not defined in '%s' library.

Error and Warning Messages

This message is issued when inconsistency found due to the power arc between the libraries. For example power\_arc\_1 defined for cell\_1 is present in library\_1 but missing for cell\_1 in library\_2.

### TECHLIB-1380

#### NAME

TECHLIB-1380

### **SUMMARY**

An inconsistency was found due to '%s(%f,%f)' value defined at library level between first library '%s' and second library. The PVT condition must be same between two libraries.

#### **DESCRIPTION**

This message is issued when there is a mismatch in the PVT condition between two libraries. Library header name and PVT condition must be same.

# TECHLIB-1381

### **NAME**

TECHLIB-1381

#### SUMMARY

The library merging has failed due to the inconsistency between reference library '%s' and incremental library. To fix the issue, refer the previous messages.

### **DESCRIPTION**

This message is issued when library merging has failed due to the inconsistency between reference library and incremental library. Fix TECHLIB-1380 and TECHLIB-1382 errors issued related to library merging.

#### NAME

TECHLIB-1382

#### SUMMARY

No matching library is present with library header name '%s' corresponding to incremental library.

### **DESCRIPTION**

This message is issued when incremental library set does not have any library which has the same header name as the reference library. For library merging, header name must be same.

# TECHLIB-1383

#### NAME

TECHLIB-1383

#### **SUMMARY**

Invalid pin '%s' is specified with the attribute related\_output\_pin for timing group on %s of cell '%s'. The pin specified with related\_output\_pin must be an output or inout pin.

### **DESCRIPTION**

This message is issued when the pin specified with attribute related\_output\_pin is invalid. The direction of pin specified with related\_output\_pin must be either output or inout. To fix the issue, recharacterize the library with appropriate settings, such that the related\_output\_pin is correctly defined.

#### NAME

TECHLIB-1384

#### SUMMARY

The absolute mean shift value for '%s' group on %s of cell '%s' has value %f which is greater than the value %f. This may impact the delay calculation accuracy.

### **DESCRIPTION**

This message is issued when the absolute mean shift value is beyond the range. The value should be less than the value calculated as {0.5\*std\_dev} for accurate delay calculation. To fix the issue, re-characterize the library with appropriate settings, such that the absolute mean shift is within the defined range.

## TECHLIB-1385

#### **NAME**

TECHLIB-1385

#### SUMMARY

The standard deviation value for '%s' group on %s of cell '%s' has value %f which is greater than the value %f. This may impact the delay calculation accuracy.

### DESCRIPTION

This message is issued when the standard deviation value is beyond the range. The value should be less than the value calculated as {0.3\*input slew} for accurate delay calculation. To fix the issue, re-characterize the library with appropriate settings, such that the standard deviation is within the defined range.

#### NAME

TECHLIB-1386

#### SUMMARY

The cell '%s' has %u sigma tables out of %u(%g%%) which have beyond the range(1/%g and %g) ratios of attribute sigma\_type late to early value. This can result in inaccurate analysis. Cadence recommends libraries with LVF moments for such high sigma variation cells.

#### DESCRIPTION

This message is issued when the ratio of late and early sigma values is not within the range of (1/x) and x). The default value of x is 3. Cadence recommends libraries with LVF moments for such high sigma variation cells.

## TECHLIB-1388

#### NAME

TECHLIB-1388

### **SUMMARY**

The cell '%s' is %s in library '%s' but %s in other library.

#### **DESCRIPTION**

This message is issued when the cell is defined in one library but not defined in other library. For example: cell (AND) is defined is defined in one library and is not defined in other library. To fix the issue, re-characterize the libraries with appropriate settings, such that the cells across libraries are consistent.

#### NAME

TECHLIB-1389

#### SUMMARY

The %s '%s' is '%s' for cell '%s' in library '%s' but '%s' in the cell '%s' in other library.

#### DESCRIPTION

This message is issued when the pin is defined for cell in one library and not defined for the same cell in other library. For example: Pin(A) defined is defined for cell in one library and is not defined in other library. To fix the issue, re-characterize the libraries with appropriate settings, such that the pins for the same cell across libraries are consistent.

## TECHLIB-1391

### **NAME**

TECHLIB-1391

#### SUMMARY

The test\_cell group is defined for cell '%s' but its corresponding sequential group information is missing. The test\_cell group will be ignored.

#### DESCRIPTION

This message is issued when the cell has test\_cell group but its corresponding sequential group information is not defined. The behavior defined in test\_cell group, must be already described by an ff, ff\_bank, latch, latch\_bank or statetable at cell level. To fix the issue, re-characterize the library with appropriate settings, such that the cell having test\_cell group must have corresponding

sequential group information.

# TECHLIB-1392

### **NAME**

TECHLIB-1392

#### SUMMARY

The voltage\_name '%s' specified in pg\_pin '%s' of pg\_type '%s' of cell '%s' is mapped to voltage %gV. The nom\_voltage %gV will be used for this pg\_pin.

#### DESCRIPTION

This message is issued when pg\_pin of pg\_type primary\_power/backup\_power is mapped with the voltage having 0V or less than 0V. In such case, nominal voltage will be used for power pg\_pin. To fix the issue, re-characterize the libraries with appropriate settings

# **TECHLIB-1393**

### NAME

TECHLIB-1393

#### SUMMARY

The %s table is not supported for %s '%s'. This table will be ignored.

#### **DESCRIPTION**

This message is issued when a particular attribute is not supported in SOCV side file. For example, RC variation multipler table cannot have object\_type attribute as 'library'. To fix the issue, recharacterize the libraries with appropriate settings.

#### NAME

TECHLIB-1394

#### **SUMMARY**

Missing %s delay value for the path from pin %s to pin %s in the cell %s. Path is not generated. The data in the timing library is incomplete. This can result in a loss of accuracy during delay calculation.

#### **DESCRIPTION**

This message is issued when delay/retain values are not specified for the path. Path is not generated if either delay or slew value is missing. To fix the issue, re-characterize the libraries such that delay/retain values are specified correctly

## TECHLIB-1395

#### NAME

TECHLIB-1395

#### SUMMARY

The library level attribute(s) receiver\_capacitance\_rise\_threshold\_pct or(and) receiver\_capacitance\_fall\_threshold\_pct are defined in library but the library has no 'receiver\_capacitance\_rise' and 'receiver\_capacitance\_fall' groups.

### **DESCRIPTION**

The library level attribute(s) receiver\_capacitance\_rise\_threshold\_pct or(and) receiver\_capacitance\_fall\_threshold\_pct are defined in library but the library has no 'receiver capacitance rise' and 'receiver capacitance fall' groups.

#### NAME

TECHLIB-1396

#### SUMMARY

The cell '%s' with ff/latch group has pin reference names but there is no pin with reference\_input attribute. The ff/latch group will be ignored.

#### **DESCRIPTION**

This message is issued when the ff/latch group is defined with format that expects reference pin as reference\_input in any pin but its not present. The ff groups will be ignored in such cases. To fix the issue, re-characterize the library with appropriate settings, such that the correct combination is used.

## TECHLIB-1397

#### NAME

TECHLIB-1397

### **SUMMARY**

The cell '%s' doesn't have ff/latch group with pin reference names but there is pin with reference\_input attribute.

### **DESCRIPTION**

This message is issued when the cell has pin with reference\_input attribute but it doesn't have any ff/latch group with reference pin names. To fix the issue, re-characterize the library with appropriate settings, such that the correct combination is used.

#### NAME

TECHLIB-1398

#### SUMMARY

The '%s' waveform specified in cell '%s' has very long tail with time value reaching '%f'. The last '%d' points in waveform will be ignored and tool will complete the waveform using extrapolation for timing analysis.

#### DESCRIPTION

This message is issued when there are points in CCS timing waveform (output\_current\_rise/output\_current\_fall) which results in very long tail in waveform. These long tails in waveform if used as such may cause issues in delay calculations. The waveform has very big values in time index. Tool ignores such bad points and completes the waveform using extrapolation for timing analysis. Such waveform indicate issue in characterization and should be reviewed.

## TECHLIB-1399

#### NAME

TECHLIB-1399

#### **SUMMARY**

Attributes tied\_off and related\_pin present in timing group for pin '%s' of cell '%s'. Attribute related\_pin cannot be specified on a tied\_off output pin.

### **DESCRIPTION**

This message is issued when tied\_off output pin consists related\_pin attribute in the timing group.

Error and Warning Messages

To fix the issue, re-characterize the library with appropriate settings, such that the related\_pin is not specified for tied\_off output pin.

### TECHLIB-1400

#### NAME

TECHLIB-1400

### **SUMMARY**

Invalid group names '%s' specified with 'timing library ignore groups'.

#### DESCRIPTION

This message is issued when invalid group names are specified with 'timing\_library\_ignore\_groups', to be ignored.

## TECHLIB-1401

#### NAME

TECHLIB-1401

#### SUMMARY

The timing arc defined on pin '%s' of cell '%s' with timing\_sense '%s' and related\_pin '%s' has invalid when attribute '%s'. The when condition is not compatible with the pin function '%s'.

#### **DESCRIPTION**

This message is issued when timing\_arc is defined with invalid when condition for specified timing\_sense and related\_pin attributes. For example: in case of two input Mux (S0 I0 + !S0 I1) for related pin I0, the valid timing arcs are ((S0 I1) and (S0 !I1)) or (S0), which implies that output will toggle on toggling I0 only if S0=0. If when condition is defined as (!S0 I1), which is an invalid when

Error and Warning Messages

condition as there would be no transition in this condition at the output. To fix the issue, recharacterize the library with appropriate settings, such that the timing arc is defined with correct when condition.

### TECHLIB-1402

#### NAME

TECHLIB-1402

#### SUMMARY

The timing arc defined on pin '%s' of cell '%s' with timing\_sense '%s' and related\_pin '%s' is not defined for all possible 'when' conditions but default arc is present in library. As per the pin function '%s', the timing arc(s) with when condition '%s' are not defined.

#### DESCRIPTION

This message is issued when timing arc(s) are missing for reported when condition expression for specified pin function but default arc is present. For example, in case of two input Mux (S0 I0 + !S0 I1) for related pin I0, the valid timing arcs are ((S0 I1) and (S0 !I1)) or (S0), which implies that output will toggle on toggling I0 only if S0=0. If any of the arc ((S0 I1) and (S0 !I1)) is missing, it will be an invalid condition. To fix the issue, re-characterize the library with appropriate settings, such that the timing arc for all valid combinations are specified.

## TECHLIB-1403

#### NAME

TECHLIB-1403

#### SUMMARY

The timing arc defined on pin '%s' of cell '%s' with timing\_sense '%s' and related\_pin '%s' is not defined for all possible 'when' conditions. As per the pin function '%s', the timing arc(s) with when condition '%s' are not defined.

This message is issued when timing arc(s) are missing for reported when condition expression for specified pin function and default arc is also not specified. For example, in case of two input Mux (S0 I0 + !S0 I1) for related pin I0, the valid timing arcs are ((S0 I1) and (S0 !I1)) or (S0), which implies that output will toggle on toggling I0 only if S0=0. If any of the arc ((S0 I1) and (S0 !I1)) is missing, it will be an invalid condition. To fix the issue, re-characterize the library with appropriate settings, such that the timing arc for all valid combinations are specified.

## TECHLIB-1404

#### NAME

TECHLIB-1404

#### **SUMMARY**

The timing arc defined on pin '%s' of cell '%s' with related\_pin '%s' has incorrect timing sense '%s'. As per the when condition '%s' and pin function '%s', the timing sense should be '%s'.

#### DESCRIPTION

This message is issued when timing\_sense is invalid as per the 'when' condition defined for timing arc. For example, in case of two input Mux (S0 I0 + !S0 I1) for related pin I0, the valid timing arcs are ((S0 I1) and (S0 !I1)) or (S0), which implies that output will toggle on toggling I0 only if S0=0. This implies positive unate relationship between I0 and output. Attribute timing\_sense with 'negative\_unate' for this condition would be incorrect. To fix the issue, re-characterize the library with appropriate settings, such that the timing arc is specified with correct timing\_sense

## TECHLIB-1405

### **NAME**

#### **SUMMARY**

The timing arc defined on pin '%s' of cell '%s' with related\_pin '%s' has incorrect timing sense '%s'. As per the pin function '%s', the timing sense should be '%s'.

### **DESCRIPTION**

This message is issued when the timing sense defined for timing arc is not consistent with the function of pin. For example, in case of inverter, which has function (!A) then arc should have a negative\_unate timing sense. To fix the issue, re-characterize the library with appropriate settings, such that the timing\_sense and function are consistent.

## TECHLIB-1406

#### NAME

TECHLIB-1406

#### SUMMARY

The timing arc defined on pin '%s' of cell '%s' has related\_pin '%s'. As per the pin function '%s', the timing arc is not valid.

#### **DESCRIPTION**

This message is issued when timing\_arc defined for specified 'related\_pin' attribute is invalid as per the pin function. To fix the issue, re-characterize the library with appropriate settings, such that the timing arc is correctly defined.

## TECHLIB-1407

#### NAME

Error and Warning Messages

#### **SUMMARY**

There is no combinational timing arc defined on pin '%s' of cell '%s' with related pin '%s'. As per the pin function '%s', there should be at least one timing arc defined.

#### DESCRIPTION

This message is issued when timing\_arc is not defined for specified 'related\_pin' attribute as per the pin function. To fix the issue, re-characterize the library with appropriate settings, such that the timing arc is defined for all possible valid condition.

## TECHLIB-1408

#### NAME

TECHLIB-1408

#### **SUMMARY**

The ratio of attribute '%s' of group '%s' to the corresponding '%s' group specified on %s of cell '%s' has one or more values(%f) which are not in range [%g <= and >= %g]. This may lead to unexpected analysis results.

#### DESCRIPTION

This message is issued when ratio of skewness and its corresponding std\_dev is not in the predefined range. This may lead to unexpected results in analysis. To fix the issue, re-characterize the library with appropriate settings to have requisite values per the standard for the attributes for which this message is issued.

## TECHLIB-1409

#### NAME

Error and Warning Messages

#### SUMMARY

Attribute related\_pin is missing for '%s' group specified on pin '%s' of cell '%s'. Attribute is mandatory if '%s' is specified on output pin.

#### DESCRIPTION

This message is issued when attribute related\_pin is missing for max\_trans/cap group. To fix the issue, re-characterize the library with appropriate settings, such that the max\_trans/cap group is correctly defined.

# TECHLIB-1410

#### NAME

TECHLIB-1410

### **SUMMARY**

For group '%s', 2-Dimensional table is specified on input %s of cell '%s'. 2-Dimensional table is not supported on input pin.

### **DESCRIPTION**

This message is issued when 2-Dimensional table for group max\_trans/cap is specified on input pin. To fix the issue, re-characterize the library with appropriate settings, such that the max\_trans/cap tables are correctly defined.

## TECHLIB-1411

#### NAME

Error and Warning Messages

#### **SUMMARY**

The libraries being merged have different timing\_model\_types. The libraries '%s' and '%s' cannot be merged.

#### **DESCRIPTION**

This message is issued when libraries with different timing\_model\_type(s) are attempted to be merged with 'merge\_model\_timing' command. Libraries need to be merged must have the same timing\_model\_type.

# TECHLIB-1412

#### NAME

TECHLIB-1412

### **SUMMARY**

The '%s' group '%s' referenced in '%s' attribute of '%s' group of %s is not defined in %s of cell '%s'.

### **DESCRIPTION**

This message is issued when input\_ccb/output\_ccb groups mentioned in attribute, are not defined on pin. To fix the issue, re-characterize the library with appropriate settings, such that the input\_ccb/output\_ccb groups should be defined.

## TECHLIB-1413

#### NAME

Error and Warning Messages

### **SUMMARY**

The attribute '%s' of '%s' group of %s of cell '%s' does not support timing arcs with three or more inverting stages.

#### DESCRIPTION

This message is issued when attribute propagating\_ccb mentions timing\_arcs with three or more inverting stages. To fix the issue, re-characterize the library with appropriate settings.

## **TECHLIB-1414**

#### NAME

TECHLIB-1414

### **SUMMARY**

In cell '%s', the '%s' vector groups specified on %s are defined for more than one 'total\_output\_net\_capacitance' index value. This group is defined in '%s' group '%s' that does not directly drive an output pin, referenced in '%s' attribute of 'timing' group defined in %s.

### **DESCRIPTION**

This message is issued when output\_voltage\_rise/fall vector groups are defined for more than one load index value. To fix the issue, re-characterize the library with appropriate settings, such that vector groups should be specified for only one load index value as CCB group does not directly drives an output pin.

## TECHLIB-1415

#### NAME

Error and Warning Messages

#### **SUMMARY**

In cell '%s', the '%s' vector groups specified on %s are defined for only one 'total\_output\_net\_capacitance' index value. This group is defined in '%s' group '%s' that directly drives an output pin, referenced in '%s' attribute of 'timing' group defined in %s.

#### **DESCRIPTION**

This message is issued when output\_voltage\_rise/fall vector groups are defined for only one load index value. To fix the issue, re-characterize the library with appropriate settings, such that vector groups should be specified for more than one load index value as CCB group directly drives an output pin.

# TECHLIB-1416

#### NAME

TECHLIB-1416

#### SUMMARY

The receiver capacitance %s groups are missing in the timing group%s specified for %s of cell '%s'.

#### DESCRIPTION

This message is issued when either the rise group (receiver\_capacitance1\_rise/receiver\_capacitance2\_rise or receiver\_capacitance\_rise) or the fall group (receiver\_capacitance1\_fall/receiver\_capacitance2\_fall or receiver\_capacitance\_fall) is missing in the timing arc. Moreover, there is no corresponding pin level receiver\_capacitance group with the default or same when condition having the missing information. To fix the issue, recharacterize the library with appropriate settings, such that the receiver\_capacitance group is defined correctly

#### NAME

TECHLIB-1417

#### SUMMARY

The SOCV side file library doesn't support voltage attribute with multiple values. It will be ignored.

#### **DESCRIPTION**

This message is issued when the voltage attribute in SOCV side file contains more than one voltage entry. To fix the issue, re-characterize the SOCV side file with appropriate settings.

# TECHLIB-1418

#### NAME

TECHLIB-1418

### **SUMMARY**

The command '%s' is recommended to be run in a separate Tempus session. No other commands must be run either before or after this command. Design sanity may not be maintained when this command is run.

#### **DESCRIPTION**

This message is issued when commands such as merge\_model\_timing or write\_ldb are executed, to warn the user that such commands are stand-alone and it is recommended to run them in a separate Tempus session. No other commands must be run either before or after this command. Design sanity may not be maintained when this command is run.

### NAME

TECHLIB-1419

#### **SUMMARY**

The expression '%s' specified for attribute %s for %s is invalid. %s. The attribute will be ignored.

## **DESCRIPTION**

This message is issued when software encounters an error in parsing the boolean expressions like power\_down\_function etc.. To rectify the issue, fix the error issued by correcting the Boolean expression definition.

# TECHLIB-1420

#### NAME

TECHLIB-1420

### SUMMARY

The receiver capacitance group specified for '%s' input transition is invalid for '%s' timing arc defined for %s in cell '%s'.

### **DESCRIPTION**

This message is issued when a timing arc had receiver capacitance group specified which is not invalid. The validity check is done on the basis of valid input pin transitions for the given timing group.

### NAME

TECHLIB-1421

#### **SUMMARY**

Attribute 'max capacitance' on '%s' %s of cell '%s' is not defined in the library.

## **DESCRIPTION**

This message is issued when the attribute max\_capacitance is not defined on output/inout pin of cell in the library. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined in the cell pin.

# TECHLIB-1422

### NAME

TECHLIB-1422

### SUMMARY

Attribute 'max transition' on '%s' %s of cell '%s' is not defined in the library.

## **DESCRIPTION**

This message is issued when the attribute max\_transition is not defined on any pin of cell in the library. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined in the cell pin.

### NAME

TECHLIB-1423

#### SUMMARY

Attribute 'max fanout' on '%s' %s of cell '%s' is not defined in the library.

## **DESCRIPTION**

This message is issued when the attribute max\_fanout is not defined on output/inout pin of cell in the library. To fix the issue, re-characterize the library with appropriate settings, such that the attributes are defined in the cell pin.

# TECHLIB-1424

### NAME

TECHLIB-1424

### SUMMARY

The number of values in spatial derate table do not match with number of values in distance array in the SOCV side file library. The spatial derate table will be ignored.

### **DESCRIPTION**

This message is issued when there is a mismatch between number of values in spatial derate table and distance array size. To fix the issue, re-characterize the SOCV side file with appropriate settings.

### NAME

TECHLIB-1425

## **SUMMARY**

There is invalid float value specified for '%s' in the SOCV side file library. It will be ignored.

## **DESCRIPTION**

This message is issued when a float value can not be converted into valid value. To fix the issue, re-characterize the SOCV side file with appropriate settings.

## TECHLIB-1426

## **NAME**

TECHLIB-1426

## **SUMMARY**

Specify valid value for the option '%s', while using the command 'report lib arcs'.

## **DESCRIPTION**

This message is issued when an invalid collection is specified with the option '-arc' or if no arcs are found in the collection specified. The command 'report\_lib\_arcs -arc' takes the output of the command 'get\_lib\_arcs', as input. To fix the issue, specify a valid collection.

#### **NAME**

TECHLIB-1427

#### SUMMARY

There is a mismatch in dimensions of the table '%s' and the axes value specified, for the arc from pin '%s' to '%s' of cell '%s' and library '%s', while using the command 'report\_lib\_arcs'. The dimension of the table is '%d' and the axes values specified with command options are '%d'.

## **DESCRIPTION**

This message is issued when there is a mismatch between the options specified with command 'report\_lib\_arcs' and the dimensions of the table. To fix the issue for delay arcs, specify both options 'input\_net\_transition' and 'total\_output\_net\_capacitance' for 2-D tables, and either one of them for 1-D tables. For constraint arcs, specify both options 'related\_pin\_transition' and 'constrained pin transition' for 2-D tables, and either one of them for 1-D tables.

## TECHLIB-1428

## NAME

TECHLIB-1428

### SUMMARY

The '%s' variable name '%s' is also used for pin '%s' defined on line %d in cell '%s'. The variable name must be unique name.

## **DESCRIPTION**

This message is issued when variable name specified in ff/latch/ff\_bank/latch\_bank conflicts with pin/bus/bundle name. To fix the issue, please specify unique variable names.

## NAME

TECHLIB-1429

### SUMMARY

The '%s' table has negative value(%g) in the SOCV side file library. It will be ignored

## **DESCRIPTION**

This message is issued when a negative float value is present in derate or distance tables. To fix the issue, re-characterize the SOCV side file with appropriate settings.

## TECHLIB-1430

#### NAME

TECHLIB-1430

## **SUMMARY**

The cell '%s' is being ignored due to errors in its definition. This library cell will not be loaded in this session. Refer to the previous messages issued for this cell to find the details of the issue.

## **DESCRIPTION**

This message is issued when cell is defined incorrectly in library. Such cells will be ignored. Refer to previous messages issued for the cell. To fix the issue, re-characterize the library with appropriate settings, such that the cell is correctly defined in the library.

### NAME

TECHLIB-1431

#### SUMMARY

Valid command options for a collection of '%s' arc(s) is '%s' and/or '%s'.

## **DESCRIPTION**

This message is issued when there is a mismatch between the axes specified with the command 'report\_lib\_arcs' and the type of arc(s) in the collection i.e. if input\_net\_transition or total\_output\_net\_capacitance are specified for a constraint arc collection or if related\_pin\_transition or constrained pin transition are specified for a delay arc collection.

# TECHLIB-1433

## NAME

TECHLIB-1433

### SUMMARY

The pin '%s' defined for bundle '%s' in cell '%s' is not listed in 'members' attribute of bundle.

## **DESCRIPTION**

This message is issued when pin defined as bundle pin but not specified in member attribute. To fix the issue, re-characterize the library with appropriate settings, such that the pins are defined correctly for bundle group.

### NAME

TECHLIB-1434

#### **SUMMARY**

The attribute '%s' defined in group '%s' has one or more values which are %s. This may lead to undesirable analysis results. The attribute will be ignored.

## **DESCRIPTION**

The message is issued when attribute values defined are less than zero as per the Liberty standard or convention. For example, slew or cap index ranges cannot have negative values. To fix the issue, re-characterize the library with appropriate settings.

# TECHLIB-1435

## NAME

TECHLIB-1435

### SUMMARY

For dc\_current table defined in cell '%s' and pin '%s', the current values are not monotonically decreasing in the range '%.4g' to '%.4g' for '%s' '%f'.

## **DESCRIPTION**

This message is issued when current values specified in dc\_current table defined in CCSN/CCB group are not monotonically decreasing from VSS to VDD. This may impact delay calculation accuracy.

### NAME

TECHLIB-1436

#### **SUMMARY**

Identified mismatch '%f' and '%f' in '%s' of the hyperbolic noise %s in pin '%s', for cell '%s', between libraries '%s' and '%s'. The value '%f' would be used.

## **DESCRIPTION**

This message is issued when there is discrepancy between the height/width/area of the hyperblic noise of a cell pin in two libraries. In this case, the value from the first library would be retained.

# TECHLIB-1437

#### NAME

TECHLIB-1437

### SUMMARY

Identified mismatch in '%s' voltage ranges '%f to %f' and '%f to %f' in pin '%s', for cell '%s', between libraries '%s' and '%s'. The libraries cannot be used for merging.

### **DESCRIPTION**

This message is issued when there is discrepancy between the power\_down\_function/always\_on atribute of a cell pin in two libraries. This may not permit the merging of these two libraries. To fix the issue, re-characterize the library with appropriate settings, such that there is no discrepency in pin the specified attribute across two libraries.

### NAME

TECHLIB-1438

#### SUMMARY

Identified mismatch in %s definition in pin '%s', for cell '%s', between libraries '%s and '%s'. The libraries cannot be used for merging.

## **DESCRIPTION**

This message is issued when there is discrepancy between the definition of power\_down\_function/always\_on in a pin of a cell of two libraries. To fix the issue, re-characterize the library with appropriate settings, such that such that there is no discrepency in pin the specified attribute across two libraries.

## TECHLIB-1439

#### NAME

TECHLIB-1439

### SUMMARY

Identified mismatch in 'leakage\_power' definition, for cell '%s', between libraries '%s' and '%s'. The libraries cannot be used for merging.

## **DESCRIPTION**

This message is issued when there is discrepancy between the definition of leakage\_power on a cell of two libraries. To fix the issue, re-characterize the library with appropriate settings, such that such that there is no discrepency in pin the specified attribute across two libraries.

#### **NAME**

TECHLIB-1440

#### **SUMMARY**

An inconsistency was found due to CCS and ECSM data present in the libraries specified to be merged. The libraries cannot be used for merging.

## **DESCRIPTION**

This message is issued when timing waveform data in the ETM libraries specified for merging does not have same library format. The libraries consists of the mix of CCS timing and ECSM timing data. Such libraries cannot be merged. To fix the issue, re-characterize the library with appropriate settings, such that there is no discrepancy in timing waveform data representation across libraries.

## TECHLIB-1441

#### NAME

TECHLIB-1441

### SUMMARY

The group '%s' in timing arc for %s on cell '%s', is missing for sigma\_type '%s'. The table for sigma\_type '%s' will be used for both sigma\_types 'early' and 'late'.

## DESCRIPTION

This message is issued when an ocv\_sigma group is not present in a pair on a timing arc. For example 'ocv\_sigma\_cell\_rise' group is present for sigma\_type early and missing for sigma\_type late. In such cases the same tables would be used for both early and late sigma. To fix the issue, recharacterize the library with appropriate settings, to ensure completeness of ocv\_sigma data.

#### NAME

TECHLIB-1442

### SUMMARY

The timing arc defined for cell '%s' and for pin '%s', with related\_pin '%s' and timing\_type '%s' in library '%s' is not defined in the cell '%s' in library '%s'.

### **DESCRIPTION**

This message is issued when a timing arc is defined for cell in one library and not defined for the same cell in other library. To fix the issue, re-characterize the libraries with appropriate settings, such that the timing arcs of same cell across libraries are consistent.

# TECHLIB-1443

## **NAME**

TECHLIB-1443

#### SUMMARY

The collection of timing arcs specified with option '%s', should either consist of only delay arcs or only constraint arcs.

#### DESCRIPTION

This message is issued when the collection of timing arcs specified with option '-arc' in the command 'report\_lib\_arcs', consists of both delay and constraint arcs. To fix the issue, specify a collection of only delay arcs or only constraint arcs.

### NAME

TECHLIB-1444

### SUMMARY

The attribute 'clock' defined on pin '%s' of cell '%s' is inconsistent in all the libraries to be merged. The merged library would have the 'clock' attribute, specified as true on this pin.

## **DESCRIPTION**

This message is issued when there is discrepancy in definition of 'clock' attribute on a pin of the cell, in all libraries to be merged. The merged library would have the 'clock' attribute, specified as true on this pin. To fix the issue, consistency in clock pins should be maintained across libraries.

## TECHLIB-1445

## **NAME**

TECHLIB-1445

### SUMMARY

Attribute 'function' on output %s of cell '%s' is not defined in the library.

### **DESCRIPTION**

This message is issued when the attribute function is not defined on an output pin of cell in the library. To fix the issue, re-characterize the library with appropriate settings, such that the attribute is defined in the cell pin.

### NAME

TECHLIB-9001

#### SUMMARY

Cell '%s' has timing arcs/checks from %s '%s' to %s '%s'. Such paths are currently not used by some of the backend tools

## **DESCRIPTION**

Cell <cellName> has timing arc/checks from <pintype> <srcPinName> to <pintype> <DstPinName>. Such paths are not supported by some of the backend tools and may possibly create problems with such tools. It is advised that such timing arcs may be removed from the input technology library OR from the generated TLF file before using it with any backend tools.

## TECHLIB-9002

#### **NAME**

TECHLIB-9002

## **SUMMARY**

%s

## **DESCRIPTION**

It is internal error message. No description is available.

### NAME

TECHLIB-9004

### **SUMMARY**

Command Line Error.

## **DESCRIPTION**

Command Line Error. \n\nCommand line error occurs when either the input file name is not specified or more than one input files are specified.

## TECHLIB-9007

## **NAME**

TECHLIB-9007

## **SUMMARY**

Ignoring Command Line Option. (-sunit option is no longer supported.\nTLF3.1/TLF4.1/TLF4.2 are generated in TLF units\nTLF4.3 is generated in input technology library units.).

## **DESCRIPTION**

This command line option is no longer supported.

### NAME

TECHLIB-9008

#### SUMMARY

The slew measurement points are incompletely specified. Specify all the slew measurement points

## **DESCRIPTION**

While specifying slew measurement points on the command line it is required that all the slew measured points (slew\_measure\_lower\_rise, slew\_measure\_lower\_fall, slew\_measure\_upper\_rise, slew\_measure\_upper\_fall) are completely defined. The slew measured threshold values should correspond to those used during Spice characterization of the library timing/power data.

## TECHLIB-9009

#### **NAME**

TECHLIB-9009

## **SUMMARY**

Slew measured command line options are not supported for TLF3.1/TLF4.1...

## **DESCRIPTION**

Slew measured command line options are supported in TLF4.2 and higher version's of TLF

### NAME

TECHLIB-9010

#### SUMMARY

Incompletely specified threshold values in input technology library. .

## **DESCRIPTION**

Incompletely specified threshold values in input technology library. . \n\nSpecify the delay characterization threshold values completely either in the input technology library or on the command line. The input technology library has one or more, but not all, of the following defined in the input technology library.\n1. input\_threshold\_pct\_fall\n2. input\_threshold\_pct\_rise\n3. output\_threshold\_pct\_fall\n4. output\_threshold\_pct\_rise\n5. slew\_lower\_threshold\_pct\_fall\n6. slew\_lower\_threshold\_pct\_fall\n6.

slew\_upper\_threshold\_pct\_fall\n8.slew\_upper\_threshold\_pct\_rise.\nSpecify all the threshold points in the input technology library or use the following command line options\nFor TLF3.1/TLF4.1 use - i,-d,-s,-t and\nFor TLF4.2/TLF4.3 use -ir,-if,-dr,-df,-sr,-sf,-tr,-tf.\n.The threshold points are crucial for timing analysis and should be specified correctly.

## TECHLIB-9011

## NAME

TECHLIB-9011

## **SUMMARY**

%s..

## **DESCRIPTION**

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

While generating TLF3.1/TLF4.1 use -i,-d,-s,-t command line options for specifying the threshold points. While generating TLF4.2/TLF4.3 use -ir,-if,-dr,-df,-sr,-sf,-tr,-tf command line options for specifying the threshold points.

## TECHLIB-9012

## **NAME**

TECHLIB-9012

#### SUMMARY

%s..

## **DESCRIPTION**

Specify the complete set of threshold points using the command line options '-i,-d,-s,-t' OR '-ir,-if,-dr,-df,-sr,-sf,-tr,-tf'. Complete set of threshold points is crucial for correct timing analysis.

## TECHLIB-9016

## **NAME**

TECHLIB-9016

#### SUMMARY

File '%s' could not be opened for writing.

### **DESCRIPTION**

Either the file specified already exists and there is no permission to overwrite or there is no write permission to the user in the run directory. Check the permissions.

### NAME

TECHLIB-9017

#### SUMMARY

Nominal Condition '%s' not defined.

## **DESCRIPTION**

Nominal Condition (<NomCondName>) not defined\n\nOne or more of the nominal conditions (nom process, nom voltage & nom temperature) are unspecified in the input technology library.

## TECHLIB-9018

## **NAME**

TECHLIB-9018

## **SUMMARY**

Nominal Condition '%s' is not defined in timing library. Assuming default value '%f'. Setting this attribute is recommended as it can impact timing and SI results.

## **DESCRIPTION**

This message is issued when the attribute '<NomCondName>' is not defined in timing library. This attribute is a must requirement in case the user uses the set\_op\_cond/setOpCond or -opcond command with delay corners in MMMC. This value would be used to derate the library values to the operating conditions of the design. \n\n To avoid this warning, make sure that '<NomCondName>' is specified in the timing library.

### NAME

TECHLIB-9019

#### SUMMARY

Nominal condition '%s' not defined in input technology library.

## **DESCRIPTION**

The input technology library has derating factors k\_process\_XXX/k\_volt\_XXX/k\_temp\_XXX but does not have nom\_process/nom\_voltage/nom\_temperature defined in the library. Tool needs this/these nominal value(s) to translate the derating factors (k\_factors) into TLF linear models. Specify the nominal condition(s) in the input technology library.

# TECHLIB-9023

## **NAME**

TECHLIB-9023

### SUMMARY

Pin/bus/bundle '%s' definition not found in cell '%s'.

## **DESCRIPTION**

Pin/bus/bundle (<PinName>) definition not found in cell (<CellName>). The indicated cell <CellName> does not have description for the pin/bus/bundle <PinName>. Check if <PinName> has been used correctly. If yes, add the necessary description, otherwise modify the cell by deleting the reference(s) to <PinName>.

### NAME

TECHLIB-9024

## **SUMMARY**

Pin '%s' is invalid for bus '%s' in cell '%s'.

## **DESCRIPTION**

This message is issued when there is a mismatch in pin name and bus name or pin index is out of range as per bus index range defined in a cell. To fix the issue, re-characterize the library with appropriate settings, such that the pin name is matched with bus name.

## TECHLIB-9025

### NAME

TECHLIB-9025

### SUMMARY

Pin name '%s' in bus '%s' of cell '%s' does not match library bus naming style '%s'.

### DESCRIPTION

Pin name (<PinName>) in bus (<PinBusName>) of cell (<CellName>) does not match library bus\_naming\_style (<bus\_naming\_style>). Bus pin name must match the bus naming style of library.

## NAME

TECHLIB-9026

## **SUMMARY**

Look-up table template '%s' definition not found.

## **DESCRIPTION**

Look-up table template (<TemplateName>) definition not found. Undefined look-up table template is referred in the timing description. Check the correctness of <TemplateName>. In case it has been used correctly, add definition for it at the library level, otherwise delete reference(s) to this template.

## TECHLIB-9027

#### NAME

TECHLIB-9027

## **SUMMARY**

Clock pin absent in sequential cell(s) '%s'

## DESCRIPTION

Clock pin absent in sequential cell(s) (<CellName>)\n\nThe indicated sequential cell(s) <CellName> does not have any pin with Pintype 'clock'. As per the requirement of delay calculation tools, at least one pin in a sequential cell must be a clock pin. Verify the description of the specified cell(s) in the input technology library.

### NAME

TECHLIB-9028

#### SUMMARY

Sequential block (ff/ff\_bank/latch/latch\_bank) missing in cell(s) '%s'. This may cause potential problems with results of downstream tools

## DESCRIPTION

Sequential block (ff/ff\_bank/latch/latch\_bank) missing in cell(s) (<CellName>). This may cause potential problems with results of downstream tools\n\nThe indicated sequential cell(s) <CellName> does not have any sequential block (ff/ff\_bank/latch/latch\_bank) in the input technology library. This means that for TLF 3.0 translations, the corresponding Register/Latch TLF clauses will not be generated. Besides, this leads to imprecise Pintype determination. Also, if the timing groups of such cells do not have timing\_sense attributes, then corresponding path polarities are assumed to be either (i.e. paths with both input transitions 01/10 will be generated for every output transition). Provide the sequential block (ff/ff\_bank/latch/latch\_bank) information in the input technology library or verify the generated pintypes and polarities.

## TECHLIB-9030

## NAME

TECHLIB-9030

## **SUMMARY**

Could not find pin direction for pin '%s' in cell '%s'.

## **DESCRIPTION**

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

\n\nDirection attribute absent in pin/busPin/bundlePin (<PinName>), cell (<CellName>). Default direction is not assigned.

## TECHLIB-9031

### NAME

TECHLIB-9031

## **SUMMARY**

'%s' absent in pin/bundle/bus '%s' of cell '%s'.

## **DESCRIPTION**

(<AttributeName>) absent in pin/bundle/bus (<PinBusBundleName>) of cell (<CellName>). The specified attribute <AttributeName> is absent in the indicated pin/bus/bundle <PinBusBundleName> of the cell <CellName>. This attribute is essential for translation. Rectify the library by specifying the missing information.

# TECHLIB-9032

## **NAME**

TECHLIB-9032

### **SUMMARY**

Definition of type group for bus\_type '%s' is absent for cell '%s' in library. Library reading will be aborted.

## **DESCRIPTION**

This message is issued when the type group definition is missing at library level for specified bus\_type. Library reading will be aborted. To fix the issue, re-characterize the library with

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

appropriate settings, such that the type is defined for bus\_type.

## TECHLIB-9034

## **NAME**

TECHLIB-9034

#### SUMMARY

Conflicting value for direction found in pin '%s' of bundle/bus '%s' in cell '%s'.

## DESCRIPTION

This message is issued when the direction of a pin is not matched with the direction specified in its parent bus/bundle. To fix the issue, re-characterize the library with appropriate settings, such that the correct direction is defined.

## TECHLIB-9035

#### NAME

TECHLIB-9035

### **SUMMARY**

Scaling factors group '%s' referred in cell '%s', is either empty or not defined in the Library.

## **DESCRIPTION**

The scaling factors group <scaling\_factors group name> is either empty or not defined in the Library. Define the scaling factors group at library level OR do not refer to it in the cell group.

### NAME

TECHLIB-9036

#### **SUMMARY**

The default\_wire\_load\_selection\_group '%s' not found in the library.

## **DESCRIPTION**

The default\_wire\_load\_selection(<Group Name>) not found in the library. \n\nVerify that the indicated default\_wire\_load\_selection group has previously been defined using wire\_load\_selection group.

# TECHLIB-9037

### NAME

TECHLIB-9037

### SUMMARY

Could not translate default wireload '%s' construct. The model has been referred in the library but not defined

### **DESCRIPTION**

Could not translate wireload <WireloadModelName> construct. The model has been referred in the library but no defined. \n\nChange the default wireload name to some defined wireload in the library or define a new wireload for the the indicated name of wireload.

### NAME

TECHLIB-9038

#### SUMMARY

The default wire load selection group not found in the library.

## **DESCRIPTION**

The default\_wire\_load\_selection construct not found in the library. \n\nlnput library has more than one wire\_load\_selection groups specified. Therefore, it is must to specify one default wire load selection.

# TECHLIB-9039

#### NAME

TECHLIB-9039

### SUMMARY

Missing timing check between constrained pin'%s' and related pin '%s' in cell '%s'. Ignoring timing check corresponding to this arc.

### **DESCRIPTION**

Either of intrinsic\_rise/rise\_constraint or intrinsic\_fall/fall\_constraint is missing for the specified timing arc in the library. \n\n Ignoring timing check corresponding to the missing timing arc.

### NAME

TECHLIB-9040

#### SUMMARY

Improper definition of related pin '%s'.

## **DESCRIPTION**

To resolve the problem, check the definition of related pin.

## TECHLIB-9041

## **NAME**

TECHLIB-9041

#### SUMMARY

Unspecified/zero capacitance value for input/inout pin/bus/bundle in cell(s) '%s'. This may cause potential problems with delay calculation results

#### DESCRIPTION

Unspecified/zero capacitance value for input/inout pin/bus/bundle in cell(s) (<CellName>). This may cause potential problems with delay calculation results\n\nOne or more input/inout pin/bus/bundle in the indicated cell(s) <CellName> have unspecified or zero capacitance value (considering the default input/inout capacitance values also). As per delay calculation tools' requirement, the input/inout capacitance value should be non-zero. Check the input technology library and provide appropriate capacitance value.

### NAME

TECHLIB-9042

#### SUMMARY

Both rise/fall propagation and cell rise/fall encountered.

## **DESCRIPTION**

Both rise/fall\_propagation and cell\_rise/fall encountered. The input technology library has both rise/fall\_propagation and cell\_rise/fall tables. This effectively means that two sets of characterization points are used in the library. This is not supported in TLF. A workaround is to replace rise/fall\_propagation with cell\_rise/fall (or vice-versa) depending on whether cell\_rise/fall or rise/fall\_propagation derating factors are used. Check that the rise/fall\_transitions are zero in such cases. If not, then the above-mentioned workaround can not be used.

## TECHLIB-9044

#### NAME

TECHLIB-9044

## **SUMMARY**

Multiple references of wire\_load group '%s' encountered in wire\_load\_selection group(s)

### DESCRIPTION

Multiple references of wire\_load group (<WireLoadName>) encountered in wire\_load\_selection group(s)\n\nThe indicated wire\_load group name <wireLoadName> appears multiple times either in the same wire\_load\_selection group or in different wire\_load\_selection groups. A wire\_load\_group name should appear only once in any wire\_load\_selection group.

#### NAME

TECHLIB-9045

### SUMMARY

Single axis point encountered for %s axis in table '%s'. Ignoring axis else TLFC may not compile this library successfully

#### **DESCRIPTION**

Single axis point encountered for (<AxisName>) in table (<TableName>). Ignoring axis else TLFC may not compile this library successfully\n\nThe indicated axis <AxisName> of the two-dimensional table <TableName> in the input technology library has only one coordinate point. Hence the values in the table are independent of this axis. Therefore, one-dimensional table in TLF file corresponding to this input technology library table is generated. This does not result in any loss of data.

# TECHLIB-9048

## NAME

TECHLIB-9048

## **SUMMARY**

Inconsistency in the expression '%s' in cell '%s'; %s.

## **DESCRIPTION**

Inconsistency in the expression '<Expr>' in cell (<CellName>); Extra parenthesis. There is a mismatch in parenthesis in the expression <Expr> in cell <CellName>. Correct the expression.

### NAME

TECHLIB-9053

## **SUMMARY**

Three-state expression for pin '%s' in cell '%s' is missing or does not contain '%s', whereas, tri-state paths exist from '%s' to '%s'.

## DESCRIPTION

Three-state expression for pin (<outputPin>) in cell (<cellName>) is missing or does not contain (<relatedPin>), whereas, tri-state paths exist from (<relatedPin>) to (<outputPin>).\n\nThe 'three\_state' attribute for pin <outputPin> in cell <cellName> is either missing or does not contain pin <relatedPin> in the three-state expression. But the timing group(s) inside pin <outputPin> with <relatedPin> as input pin have timing\_type as 'three\_state\_disable'. Hence tri-state paths generated in such cases are (Z->0, Z->1, 1->Z and 0->Z transitions at output). But the active level of the control pin <relatedPin> is not determined as the three-state expression does not contain this pin. So the paths are generated for both the rise and fall transitions at control pin and it's pintype is specified without active level. Verify whether the <relatedPin> is a Control High or Control Low pin.

## TECHLIB-9056

#### NAME

TECHLIB-9056

## **SUMMARY**

'%s' not found in the library. Assuming '%s'

## **DESCRIPTION**

#### Innovus Stylus Common UI Error Message Reference

Error and Warning Messages

This message is issued when the attribute leakage\_power\_unit is not defined in the library. It defaults to 1nW. To fix the issue, re-characterize the library with appropriate settings, such that the leakage\_power\_unit is defined.

# TECHLIB-9057

## **NAME**

TECHLIB-9057

## **SUMMARY**

'%s' unit not found in the library. Assuming '%s'

## **DESCRIPTION**

Unit is found missing in the library. Verify the data values in the output.

## TECHLIB-9058

#### NAME

TECHLIB-9058

### **SUMMARY**

Incorrect '%s' unit specified in the library. Assuming '%s'

## **DESCRIPTION**

This message is issued when incorrect unit is specified in the library. To fix the issue, recharacterize the library with appropriate settings, such that the correct unit is specified.

### NAME

TECHLIB-9059

### SUMMARY

Both force\_00 and force\_11 found in state group. Only force\_00 will be used and force\_11 will be ignored

## **DESCRIPTION**

It is message in string format. No description is available.

# TECHLIB-9060

## **NAME**

TECHLIB-9060

## **SUMMARY**

Two dimensional table referred in timing group containing related\_output\_pin

## **DESCRIPTION**

Two dimensional table referred in timing group containing related\_output\_pin.

### NAME

TECHLIB-9061

### SUMMARY

Could not translate the expression for the function string '%s'.

## **DESCRIPTION**

Could not translate the expression correctly. Verify the output. One of the resons for this, could be the presence of interface\_timing set to true at cell level, which leads to sequential elements being ignored.

# TECHLIB-9062

### NAME

TECHLIB-9062

## **SUMMARY**

Functionality is missing at pin '%s' for the cell '%s'.

## **DESCRIPTION**

Function is missing for the cell

### NAME

TECHLIB-9063

### SUMMARY

Invalid delay model specified for the library '%s'. Delay model other than table\_lookup/cmos2/generic\_cmos is not supported.

## DESCRIPTION

This message is issued when invalid delay model is specified. To fix the issue, re-characterize the library with appropriate settings, such that the correct delay model is specified.

## TECHLIB-9064

### NAME

TECHLIB-9064

## **SUMMARY**

Missing delay model statement in the library '%s'. %s delay model is assumed.

## **DESCRIPTION**

The delay\_model statement is missing in the library. Assuming default model

### NAME

TECHLIB-9065

## SUMMARY

Invalid polarity/input transition

## **DESCRIPTION**

Invalid polarity/input transition. Verify the output.

## **TECHLIB-9066**

## **NAME**

TECHLIB-9066

## **SUMMARY**

Invalid values in leakage\_power group for the cell '%s'

## **DESCRIPTION**

Either the values attribute of leakage\_power group in cell <CellName> is not specified or specified incorrectly. verify the output.

### NAME

TECHLIB-9067

### **SUMMARY**

Missing %s delay value for the path from pin %s to pin %s in the cell %s. Path is not generated. The data in the timing library is incomplete. This can result in a loss of accuracy during delay calculation.

## **DESCRIPTION**

This message is issued when delay and retain values are not specified for the path. Path is not generated if either delay or slew value is missing. To fix the issue, re-characterize the libraries such that delay and retain values are specified correctly.

# TECHLIB-9068

# **NAME**

TECHLIB-9068

### SUMMARY

Missing %s slew value for the path from pin %s to pin %s in the cell %s. %s. The data in the timing library is incomplete. This can result in a loss of accuracy during delay calculation.

# DESCRIPTION

This warning is encountered if the delay tables (cell\_rise/cell\_fall) are specified between a pin pair in the cells and output slew(rise\_transition/fall\_transition) tables are missing.\n\nlt is imperative to have both the delay and slew tables to accurately model the slew propagation and hence delay for the cell driven by the cell in question. If the output slew table is missing, the output slew is set to 0

Error and Warning Messages

for this cell which would definitely cause wrong delay calculation for the cell driven by the cell in question.\n\nTo avoid this warning make sure that the timing libraries have complete delay and slew data.

# TECHLIB-9069

### NAME

TECHLIB-9069

#### SUMMARY

Missing disable timing arc for the path from related pin(s) '%s' to source pin(s) '%s' in the cell '%s'.

# **DESCRIPTION**

Disable arc path are not specified for the given path. Verify the output.

# **TECHLIB-9070**

#### NAME

TECHLIB-9070

#### SUMMARY

Missing '%s' parameter in operating condition block '%s' in the library. Assuming zero value for the missing parameter.

### DESCRIPTION

Process/voltage/temperature is not specified within operating\_conditions group. Zero value for the missing parameters are assumed.

### NAME

TECHLIB-9071

### **SUMMARY**

Missing parameter '%s' in voltage block '%s' in the library. Assuming zero value for the missing parameter.

# **DESCRIPTION**

Some of the parameters are not specified within %\_voltage group. Zero value for the missing parameters are assumed.

# TECHLIB-9072

## NAME

TECHLIB-9072

### SUMMARY

Missing '%s' parameter in routing track block '%s'. Assuming zero value for the missing parameter.

# **DESCRIPTION**

The attribute tracks/total\_track\_area is not specified within routing\_track group. Zero value for the missing parameters are assumed.

# NAME

TECHLIB-9073

# **SUMMARY**

The number of member pins in the bundles '%s' and '%s' is not the same.

# **DESCRIPTION**

The number of member pins in the bundles (<ReferencedBundleName>) and (<OriginalBundleName>) is not the same. Since one of the bundles is defined as a function to the other, the number of member pins in both should be the same.

# TECHLIB-9074

## NAME

TECHLIB-9074

### SUMMARY

Voltage Group '%s' definition not found in library.

# **DESCRIPTION**

This message is issued when the undefined voltage group is used in the library. To fix the issue, recharacterize the library with appropriate settings, such that the voltage group is defined.

# NAME

TECHLIB-9081

### **SUMMARY**

Attribute '%s' found in Library/Cell/Pin '%s' is not supported and would not be translated

# **DESCRIPTION**

The specified attribute has no correspondence in TLF and hence will not be translated

# TECHLIB-9082

# **NAME**

TECHLIB-9082

### SUMMARY

Define attribute '%s' clashes with a TLF reserved keyword of the same name and would not be translated

#### DESCRIPTION

The specified define attribute clashes with a TLF reserved keyword of the same name and hence is not being translated. An alternative would be to change the name of the define attribute, so that it does not clash with any of the TLF keywords.

### NAME

TECHLIB-9084

### **SUMMARY**

Missing one of rise/fall capacitance in input/inout pin of cell '%s' and would be ignored.

# **DESCRIPTION**

Missing one of rise/fall capacitance in input/inout pin of cell (<CellName>) and would be ignored. \n\nRise capacitance and Fall capacitance must be specified together at cell or pin level. If for a pin rise capacitance attribute is set, then fall capacitance must be set for the same and vice versa.

# TECHLIB-9085

#### NAME

TECHLIB-9085

### **SUMMARY**

Scaled cell's enclosing cell handle '%s' not specified in the library, hence, would not be translated

## DESCRIPTION

Scaled cell's enclosing cell handle <CellName> not specified in the library, hence, would not be translated. \n\nLibrary does not have a normal cell defintion with name <cellName> for the scaled cell with the same name. Specify a normal cell with name <CellName> to rectify the problem.

### NAME

TECHLIB-9086

### SUMMARY

Scaled cell's operating conditions '%s' not specified in the library, hence, would not be translated

# **DESCRIPTION**

Scaled cell's operating conditions <Operating Condition Name> not specified in the library, hence, would not be translated. \n\nEvery scaled cell is associated with an operating condition and library must have the definition for the operating condition with which the scaled cell is associted. Specify the operating condition with name <Operating Condition Name> in the library to rectify the problem.

# TECHLIB-9087

# NAME

TECHLIB-9087

### SUMMARY

Driver type inside pin '%s' of cell '%s' are not specified with the correct pin/bus/bundle type, hence, would be ignored

## DESCRIPTION

Driver type inside pin <PinName> of cell <CellName> are not specified with the correct pin/bus/bundle type, hence, would be ignored. \n\nDriver types must be specified with the correct pin/bus/bundle direction. Every driver type has applicable pin/bus/bundle types with which they can be associted. Specfy the correct pin/bus/bundle type to rectify the problem. resistive, resistive\_0, resistive 1, open source and open drain driver type can be specified with output pin/bus/bundle

Error and Warning Messages

only. bus\_hold can only be specified with inout pin/bus/bundle and pull\_up, pull\_down can be specified with input/output/inout pin/bus/bundle.

# TECHLIB-9088

# NAME

TECHLIB-9088

# SUMMARY

Incompletely/Incorrectly specified data (divided\_by/multiplied\_by/edges/shifts) in generated clock '%s' in cell '%s', hence would not be translated.

# **DESCRIPTION**

Incompletely/Incorrectly specidied data (divided\_by/multiplied\_by/edges/shifts) in generated clock <GeneratedClockName> in cell <CellName>, hence would not be translated. \n\nGenerated clock definition in .lib must contain one of the construct among divided\_by, muliplied\_by and edges/shifts combination. One of these is required for translation of generated clock. Specify divided\_by/multiplied\_by for clock generation through frequency division/multiplication. Edges must be specified along with shifts but not vice versa. Either edges or an edge shift combination is expected, in case of clocks generated through edge derivation. Edges/Shifts must be specified as triplet.

# TECHLIB-9089

### NAME

TECHLIB-9089

### SUMMARY

Missing generated pin name in generated clock '%s' specification in cell '%s', hence would not be translated.

Error and Warning Messages

### DESCRIPTION

Missing clock pin in generated clock <GeneratedClockName> specification in cell <CellName>, hence would not be translated. \n\nCheck the definition of generated clock <GeneratedClockName> and specify the clock pin.

# TECHLIB-9090

### NAME

TECHLIB-9090

# SUMMARY

More than one clock generation construct specified in generated clock '%s' specification in cell '%s', hence would not be translated.

# DESCRIPTION

More than one clock generation construct specified in generated clock <GeneratedClockName> specification in cell <CellName>, hence would not be translated. \n\nGenerated clock <GeneratedClockName> is specified with more than one method of clock generation (divided\_by/multiplied\_by/edges or edge/shift combination). A combination of clock generation methods results in ambiguity as tool cannot decide which method to be chosen out of these to translate the generated clock appropriately. Specify a single clock generation construct to allow its translation.

# **TECHLIB-9091**

# NAME

TECHLIB-9091

# **SUMMARY**

Incorrect pulling resistance unit value specified in the library, hence ignoring

### DESCRIPTION

Incorrect pulling\_resistance\_unit value specified in the library, hence ignoring. \n\npulling\_resistance\_unit can be only specified with following mentioned values (10hm, 100hm, 1000hm, 1k0hm). Specify one of these to rectify the library.

# TECHLIB-9092

# **NAME**

TECHLIB-9092

### **SUMMARY**

Invalid timing type specified in the arc from clear/preset pin '%s' to pin '%s', ignoring arc.

#### DESCRIPTION

The specified timing\_type attribute is invalid between the source pin and related\_pin.\n\nlt is most likely that you have specified a combinational timing arc from the clear/preset pin to the output pin.

# TECHLIB-9093

## NAME

TECHLIB-9093

### SUMMARY

Incorrect timing\_type specified in timing group of pin '%s' with related pin name '%s' in cell '%s', ignoring arc.

# **DESCRIPTION**

This message is issued when the incorrect timing\_type is specified. Such timing arc will be ignored.

Error and Warning Messages

Arcs from clock\_gate\_clock\_pin and clock\_gate\_enable\_pin to clock\_gate\_out\_pin should be of combinational timing\_type. To fix the issue, re-characterize the library with appropriate settings, such that the correct timing\_type is defined.

# TECHLIB-9095

#### NAME

TECHLIB-9095

#### SUMMARY

Negative Pulling Resistance specified for pin '%s' in cell '%s', setting the value to 0.

### DESCRIPTION

Negative Pulling Resistance specified for pin (<PinName>) in cell (<CellName>), setting the value to 0. \n\nPulling resistance is used to specify the resistance of a pull\_up or pull\_down device. A negative pulling resistance would produce a current flow in opposite direction, hence a value 0 is set. Specify a positive value to define pulling resistance.

# TECHLIB-9096

#### NAME

TECHLIB-9096

### SUMMARY

Pulling resistance specified for a non pull up/pull down pin '%s' in cell '%s'.

# **DESCRIPTION**

Pulling resistance specified for a non pull\_up/pull\_down pin (<PinName>) in cell (<CellName>). \n\nPulling resistance can only be specified for pull\_up/pull\_down devices. Specify the device as

Error and Warning Messages

pull up/pull down by using driver type attribute to rectify the problem.

# TECHLIB-9097

#### NAME

TECHLIB-9097

#### SUMMARY

No pulling resistance unit specified for pulling resistance of pull\_up/pull\_down devices in cell '%s'.

# **DESCRIPTION**

This message is issued when the pulling resistance is specified without unit. Valid unit values are 10hm, 100hm, 100hm, and 1kohm. To fix the issue, re-characterize the library with appropriate settings, such that the unit of pulling resistance is defined.

# TECHLIB-9098

#### NAME

TECHLIB-9098

### **SUMMARY**

Cell '%s' is redefined but cannot be overwritten.

# **DESCRIPTION**

Cell (<CellName>) is redefined but cannot be overwritten. Cell redefinitions in a library are not allowed. To resolve the issue, modify the cell definition by changing name of cells such that all the cells are distinct.

### NAME

TECHLIB-9099

### **SUMMARY**

Scaled cell '%s' is redefined but cannot be overwritten.

# **DESCRIPTION**

Scaled cell (<CellName>) is redefined but cannot be overwritten. Scaled cell redefinitions in a library are not allowed. To resolve the issue, modify the scaled cell definition by changing the PVT condition name such that all the scaled cells are distinct in that cell.

# TECHLIB-9100

## NAME

TECHLIB-9100

# **SUMMARY**

The data pin and enable pin in Tlatch construct are same for pin '%s' in cell '%s'. This will be ignored

# **DESCRIPTION**

This is ignored

### NAME

TECHLIB-9101

# **SUMMARY**

The Tlatch construct is not effective.timing\_model\_type attribute needs to be defined in cell '%s'.This Tlatch contruct will be ignored

# **DESCRIPTION**

This is ignored

# TECHLIB-9102

### NAME

TECHLIB-9102

# **SUMMARY**

Incorrectly specified slew measurement points. Reported slews falling beyond the range (0.0 - 100.0).

# DESCRIPTION

Incorrectly specified slew measurement points. Reported slews falling beyond the range (0.0 - 100.0). To resolve the issue, check/modify the definitions of the slew measurement thresholds and the slew\_derate\_from\_library construct such that the reported slew range falls in between (0 - 100). To calculate reported slew use, (measured slew upper - measured slew lower) slew derate factor

### NAME

TECHLIB-9103

### **SUMMARY**

The slew\_derate\_from\_library and Input slew measurement points produce reported slews which fall beyond the range (0.0 - 100.0).

# **DESCRIPTION**

This warning is issued if reported slew threshold is computed to be beyond the range (0.0-100.0).\n\nThe slew derate from library is the factor which defines the relationship between the reported and measured slew thresholds for the library. The formula is as follows - \n\n delta reported = delta measured / slew\_derate\_from\_library \n\n 'delta' signifies the difference between 'slew\_upper' and 'slew\_lower'. \n\nlf delta reported comes out to be greater than hundred with the measure thresholds and slew derate specified, then the reported slews will fall beyond 0-100 range - which is not possible. In such case the above warning is issued. To avoid this warning, make sure proper values of slew\_derate\_from\_library and Input slew measurement points are specified in the timing library.

# TECHLIB-9104

### NAME

TECHLIB-9104

# **SUMMARY**

Slew derate from library would be assumed to be 1 and the derating would be applied using this value as slew thresholds are specified on the command line and not specified in the library.

# **DESCRIPTION**

Error and Warning Messages

Slew derating would not be applied as slew thresholds are specified on the command line and not specified in the library. \n\nTo rectify the issue specify thresholds and slew derating factor (slew derate from library) inside the library.

# TECHLIB-9105

#### NAME

TECHLIB-9105

# **SUMMARY**

Slew derate from library specified as  $0 \le x > 1$  in the library where x is the value of slew derate.

## DESCRIPTION

Slew\_derate\_from\_library specified as  $0 \le x > 1$  in the library where x is the value of slew\_derate. To rectify the issue change slew derating factor (slew\_derate\_from\_library) inside the library.

# TECHLIB-9106

# **NAME**

TECHLIB-9106

#### SUMMARY

Tool detected missing threshold parameters in your .lib, and substituted the proper default values. To provide explicit setting of thresholds, update your .lib and retranslate; or, specify the appropriate settings. For accurate results, it is necessary that the slew measurement points used during Spice characterization of the library are provided to the delay calculator. The threshold points are crucial for timing analysis and should be specified correctly.

# **DESCRIPTION**

Error and Warning Messages

Tool detected missing threshold parameters in your .lib, and substituted the proper default values. To provide explicit setting of thresholds, update your .lib and retranslate; or, specify the appropriate settings. For accurate results, it is necessary that the slew measurement points used during Spice characterization of the library are provided to the delay calculator. \n\nTo specify the thresholds in input technology library, specify the following constructs in the library.\n1. input\_ threshold\_pct\_fall\n2. input\_threshold\_pct\_rise\n3. output\_threshold\_pct\_fall\n4. output\_threshold\_pct\_rise\n5. slew\_lower\_threshold\_pct\_fall\n6. slew\_lower\_threshold\_pct\_rise\n7. slew\_upper\_threshold\_pct\_fall\n8.slew\_upper\_threshold\_pct\_rise \n\nTo specify the same through command line, use the following command line options:\n -ir, -if, -dr, -df, -sr, -sf, -tr, -tf, \n - slew\_measure\_lower\_rise, -slew\_measure\_lower\_fall, \n -slew\_measure\_upper\_rise, - slew\_measure\_upper\_fall

# TECHLIB-9107

### NAME

TECHLIB-9107

### SUMMARY

Thresholds specified both in library and on command line. Command line values will be used.

# DESCRIPTION

Thresholds specified both in library and on command line. Command line values will be used. \n\nTo avoid the warning, specify the thresholds either on command line or in the library.

# TECHLIB-9108

#### NAME

TECHLIB-9108

# **SUMMARY**

Error and Warning Messages

'%s' not specified in the library, using .lib default of '%s'.

#### DESCRIPTION

This warning is encountered if the construct (<ThresholdConstruct>) is missing from the library. This construct in the timing library defines how the delay of the characterized cells has been deduced. For example a input\_threshold\_pct\_rise of 30 and output\_threshold\_pct\_rise of 60 means that the delay value in the tables are the time difference between the input rising to 30% of its values and output rising to 70% of its value. If this is missing, then a value of (<PercentageValue>) is assumed. \n\n To avoid this warning make sure that the timing libraries have the correct values of (<ThresholdConstruct>) specified.

# TECHLIB-9109

### **NAME**

TECHLIB-9109

# SUMMARY

slew\_derate\_from\_library not specified in the library, using .lib default of 1.

### DESCRIPTION

The slew\_derate\_from\_library not specifed in the library, using .lib default of 1.\n\nTo clear the warning, specify the slew\_derate\_from\_library value in the library.

# TECHLIB-9110

# **NAME**

TECHLIB-9110

## **SUMMARY**

Single data point found in the axis point redefinition of template '%s' in cell '%s'. Axis point is useless and would not be used in table lookup.

### **DESCRIPTION**

Single data point found in the axis point redefinition of template (<TemplateName>) in cell (<CellName>). Axis point is useless and would not be used in table lookup. \n\nTo clear the warning, modify the axis point definition in the library. For lookup, at least two points should be specified.

# TECHLIB-9111

## **NAME**

TECHLIB-9111

### SUMMARY

Illegal [0-100] delay thresholds specified in the library. Library can be translated by using -force command line option however it is recommended that library should be fixed by providing the correct/legal delay threshold points. Tool when forced to translate the library containing 0-100 delay thresholds, assumes 50-50 delay thresholds (liberty defaults). For accurate results, it is necessary that the delay threshold points used during Spice characterization of the library are provided to the delay calculator.

# **DESCRIPTION**

Illegal [0-100] delay thresholds specified in the library. Library can be translated by using -force command line option however it is recommended that library should be fixed by providing the correct/legal delay threshold points. Tool when forced to translate the library containing 0-100 delay thresholds, assumes 50-50 delay thresholds (liberty defaults). For accurate results, it is necessary that the delay threshold points used during Spice characterization of the library are provided to the delay calculator. \n\nThe threshold points are crucial for timing analysis and should be specified correctly. Otherwise, it may cause potential problems with delay calculation results. A better solution is to modify the library for legal thresholds if possible.

### NAME

TECHLIB-9112

### SUMMARY

Illegal [0-100] delay thresholds specified in the library. Library translated by using -force command line option. It may cause potential problems with delay calculation results. It is recommended that library is fixed and translated again.

# DESCRIPTION

Illegal [0-100] delay thresholds specified in the library. Library translated by using -force command line option. It may cause potential problems with delay calculation results. It is recommended that library is fixed and translated again. \n\nTool when forced to translate the library containing 0-100 delay thresholds, assumes 50-50 delay thresholds (liberty defaults). For accurate results, it is necessary that the delay threshold points used during Spice characterization of the library are provided to the delay calculator.

# TECHLIB-9113

# **NAME**

TECHLIB-9113

#### SUMMARY

Illegal [0-100] slew measurement thresholds specified in the library. Library can be translated by using -force command line option however it is recommended that library should be fixed by providing the correct/legal slew measurement points. Tool when forced to translate the library containing 0-100 slew measurement thresholds, assumes 20-80 measured slew (liberty defaults). For accurate results, it is necessary that the slew measurement points used during Spice characterization of the library are provided to the delay calculator.

Error and Warning Messages

### DESCRIPTION

Illegal [0-100] slew measurement thresholds specified in the library. Library can be translated by using -force command line option however it is recommended that library should be fixed by providing the correct/legal slew measurement points. Tool when forced to translate the library containing 0-100 slew measurement thresholds, assumes 20-80 measured slew (liberty defaults). For accurate results, it is necessary that the slew measurement points used during Spice characterization of the library are provided to the delay calculator. \n\nThe threshold points are crucial for timing analysis and should be specified correctly. Otherwise, it may cause potential problems with delay calculation results. A better solution is to modify the library for legal thresholds if possible.

# TECHLIB-9114

## **NAME**

TECHLIB-9114

# **SUMMARY**

Illegal [0-100] slew measurement thresholds specified in the library. Library translated by using force command line option. It may cause potential problems with delay calculation results. It is recommended that library is fixed and translated again.

### DESCRIPTION

Illegal [0-100] slew measurement thresholds specified in the library. Library translated by using - force command line option. It may cause potential problems with delay calculation results. It is recommended that library is fixed and translated again. \n\nTool when forced to translate the library containing 0-100 slew measurement thresholds, assumes 20-80 measured slew (liberty defaults). For accurate results, it is necessary that the slew measurement points used during Spice characterization of the library are provided to the delay calculator.

### NAME

TECHLIB-9115

### SUMMARY

Could not over write the definition of the Bus %s in the cell %s. There might be a scalar pin of the same name defined earlier.

# **DESCRIPTION**

Could not over write the definition of the Bus <bus\_name> in the cell <cell\_name>. There might be a scalar pin of the same name defined earlier.\n\nThere might be certain pin names which can conflict with the bus name and range. Remove or rename such pin names.

# TECHLIB-9118

# **NAME**

TECHLIB-9118

### SUMMARY

The statetable for the %s %s is syntactically incorrect. This may be because of %s.

### **DESCRIPTION**

This message is issued when the statetable is incorrectly defined. This might be due to incorrectly placed commas/colons. To fix the issue, re-characterize the library with appropriate settings, such that the statetable is correctly defined.

### NAME

TECHLIB-9119

### SUMMARY

Missing related pin %s for a timing group of pin %s in cell %s.

# **DESCRIPTION**

This message is issued when the related\_pin is specified for a timing group but is not defined in the cell. To fix the issue, re-characterize the library with appropriate settings, such that the related\_pin is defined.

# TECHLIB-9120

### NAME

TECHLIB-9120

### SUMMARY

Duplicate definition found for pin/bus/bundle %s in cell %s. Overwriting the duplicate definition.

# DESCRIPTION

Duplicate definition found for <RelatedPin> in cell <Cell>. Overwriting the duplicate definition.\n\nCheck for possible errors. It is recommended that such redifinition is examined before loading the .lib as this could result in loss of information.

### NAME

TECHLIB-9121

### SUMMARY

Mismatch in bit from/bit to values while overwriting the bus type for bus %s in cell %s.

# **DESCRIPTION**

This message is issued when there is mismatch in the attributes bit\_from/bit\_to values while overwriting the bus\_type for bus. To fix the issue, re-characterize the library with appropriate settings, such that the attributes bit\_from/bit\_to are defined correctly.

# TECHLIB-9122

### NAME

TECHLIB-9122

### SUMMARY

Multiple statetables found in cell %s. Only the last statetable definition will be preserved.

## DESCRIPTION

Multiple statetables found in cell <Cell>. Only the last statetable definition will be preserved. A cell having multiple statetables is considered to be an incorrect style of modelling. Thus only the latest statetable definition is preserved.

# NAME

TECHLIB-9123

# **SUMMARY**

Slew threshold difference '%s' is less than 1%.

# **DESCRIPTION**

Slew threshold difference (<Rise>/<Fall>) is less than 1%.\n\nThis library might not be usable with some of the downstream tools.

# TECHLIB-9124

# **NAME**

TECHLIB-9124

# **SUMMARY**

Missing when or sdf cond attributes in the min pulse width group of pin '%s' in cell '%s'.

#### DESCRIPTION

Missing when or sdf\_cond attributes in the min\_pulse\_width group of pin <Pin> in cell <Cell>.\n\nAttributes when and sdf\_cond define the enabling condition for the timing check. Both attributes are required in the min\_pulse\_width group.

# NAME

TECHLIB-9125

# **SUMMARY**

Missing axis name in template definition '%s'.

# **DESCRIPTION**

Missing axis name in template definition <Template name>. Number of template variables in a template should correspond with the number of Index statements.

# TECHLIB-9127

# **NAME**

TECHLIB-9127

# **SUMMARY**

Multiple '%s' were detected at (Line %d). Using the last value.

# **DESCRIPTION**

The last value of the multiple definitions would be used.

#### **NAME**

TECHLIB-9128

### SUMMARY

Lookup tables are only supported in 'table\_lookup' libraries. Table seen at line %d. Verify that the delay model for this library is table lookup.

# **DESCRIPTION**

Table can be seen when delay model type is defined as table\_lookup. The library needs to be reviewed.

# TECHLIB-9129

#### NAME

TECHLIB-9129

### SUMMARY

Missing third axis name in template definiton '%s', assuming 'related out total output net capacitance/equal or opposite output net capacitance'.

# **DESCRIPTION**

Missing third axis name in template definiton <Template Name>, assuming 'related\_out\_total\_output\_net\_capacitance/equal\_or\_opposite\_output\_net\_capacitance'.\n\nThird axis name is not specified in the 3D template definition, assuming it to be 'related\_out\_total\_output\_net\_capacitance/equal\_or\_opposite\_output\_net\_capacitance' for timing/power template respectively. To supress this behavior specify the name of the third axis in the template definition.

# NAME

TECHLIB-9131

### SUMMARY

Unnamed '%s' found in input technology library. This is incorrect liberty Syntax.

# **DESCRIPTION**

The library does not have pin/cell/library name defined in the library. The input technology library should have pin/cell/library name defined. Check the library correctness.

# TECHLIB-9132

#### NAME

TECHLIB-9132

### **SUMMARY**

Identified more than one leakage\_power groups with same condition in cell '%s', Last definition will be retained.

# DESCRIPTION

More than one leakage\_power groups with same condition identified in cell <CellName>. The last definition will be retained

### NAME

TECHLIB-9133

### SUMMARY

Identified more than 1 power\_gating\_pin/retention\_pin attributes for pin %s (Line %d). First definition would be retained.

# **DESCRIPTION**

Found multiple power\_gating\_pin/retention\_pin constructs for same pin. Specify only one power\_gating\_pin/retention\_pin construct for a pin in the library cell.

# TECHLIB-9134

## NAME

TECHLIB-9134

### SUMMARY

Multiple unit definitions detected (Line %d). A library can only have one definition for capacitive load units. First definition would be retained.

## **DESCRIPTION**

The first value of the multiple unit definitions would be used.

### NAME

TECHLIB-9135

### SUMMARY

%s (Line %d) has both attributes 'power\_level' & 'related\_pg\_pin' defined. power\_level would be ignored.

# **DESCRIPTION**

The power group should be reviewed for correctness.

# TECHLIB-9136

# NAME

TECHLIB-9136

# **SUMMARY**

Single axis point encountered for %s axis in table '%s'.

# DESCRIPTION

Single axis point encountered for (<AxisName>) in table (<TableName>). Ignoring axis else TLFC may not compile this library successfully\n\nThe indicated axis <AxisName> of the two-dimensional table <TableName> in the input technology library has only one coordinate point. Hence the values in the table are independent of this axis. Therefore, one-dimensional table in TLF file corresponding to this input technology library table is generated. This does not result in any loss of data.

### NAME

TECHLIB-9137

### SUMMARY

Mismatch in bus width in timing arc with related pin '%s' in pin '%s' of cell '%s'. Ignoring the timing arc.

# **DESCRIPTION**

The bus width of path between source bus pin and target bus pin should match otherwise that timing arc would be ignored.

# TECHLIB-9138

## NAME

TECHLIB-9138

### SUMMARY

The 'default\_operation\_condition' should be defined after the 'operation\_condition' group. Check the library for correctness.

# **DESCRIPTION**

The attribute 'default\_operation\_condition' should be defined in the library after the operation\_condition' group. This is done to ensure the validity of the properties signified by these attributes.

### NAME

TECHLIB-9139

### SUMMARY

'%s' not found in the library. Assuming '%s'

# **DESCRIPTION**

The attribute leakage\_power\_unit is found missing in the library. Assuming it to be 1nW.\n\nTo avoid this assumption, specify (leakage\_power\_unit) in the library.

# TECHLIB-9140

# **NAME**

TECHLIB-9140

# **SUMMARY**

No timing sense found for the timing arc at (line no : %d) for cell %s. This is a required attribute for delay timing arcs.

# **DESCRIPTION**

Timing Sense is a required attribute for delay arcs. If missing can cause issues during timing analysis.

### NAME

TECHLIB-9141

### **SUMMARY**

Identified delay/slew table(s) for timing arc at (line no :%d) with timing type '%s' for cell '%s'. This timing group is check arc and cannot have delay/slew tables.

# **DESCRIPTION**

The cell\_rise, cell\_fall, rise\_transition. fall\_transition table are not expected in min\_pulse\_width arc. These arcs can have only rise\_constraint or fall\_constraint tables.

# TECHLIB-9142

## NAME

TECHLIB-9142

### SUMMARY

Mismatch between number of values(%d) defined in template '%s' and number of values(%d) characterized in table, on line no. %d.

# **DESCRIPTION**

If any library template has n\*m entries, then its corresponding table entries values should be n\*m.

#### **NAME**

TECHLIB-9143

### SUMMARY

Timing group defined in library has either missing or incorrectly defined lookup tables(s) for cell '%s'. This timing group will be ignored.

# **DESCRIPTION**

Timing groups in library without any delay, transition, or constraint tables are not allowed. The timing group without any indices on lookup table or its referred template is not allowed. All such timing groups in the library will be ignored. To resolve the issue, modify the timing arc definition by adding cell rise rise transition/rise constraint table or cell fall/fall transition/fall constraint table.

# TECHLIB-9144

# **NAME**

TECHLIB-9144

#### SUMMARY

The statetable for the %s %s is syntactically incorrect. This may be because the number of %s columns (%d) is %s than %d

#### DESCRIPTION

This message is issued when there is a mismatch in number of entries in statetable and number of entries in the table header for next state/current state/inputs. To fix the issue, re-characterize the library with appropriate settings, such that the statetable is defined correctly.

### NAME

TECHLIB-9145

### SUMMARY

Cell '%s' has interface\_timing attribute set to true and it also has statetable defined. The statetable will be ignored.

# **DESCRIPTION**

The library cell does not require to have a statetable defined if the cell definition has interface\_timing attribute set to true. In the case both interface\_timing attribute and statetable are defined for a cell, the state table will be ignored and interface\_timing attribute would be honored. In this case, to enable tool honor the statetable, either set the interface\_timing attribute to false in the cell definition or remove the attribute from cell definition

# TECHLIB-9147

#### NAME

TECHLIB-9147

# **SUMMARY**

The 'default\_operating\_condition' '%s' is not defined in the library. This will be ignored and nominal operating condition will be used for analysis. To avoid this error, you need to add the missing operating condition definition in the library and then re-run.

# DESCRIPTION

This error is issued when the default\_operating\_condition definition is missing in the library. In such cases, the nominal operating condition is used to proceed with the analysis. However, this might

Error and Warning Messages

lead to unexpected analysis results and may impact signoff quality. To rectify the error, either recharacterize the library or add the definition of the missing operating condition in the library.

# TECHLIB-9148

### NAME

TECHLIB-9148

# **SUMMARY**

The pin class value for power\_gating\_pin attribute at line no '%d' for pin '%s' is not recognized type. It will be ignored.

## DESCRIPTION

The valid pin class values for power\_gating\_pin attribute are power\_pin\_[1-5]. The values other than this will be ignored. To resolve this issue, modify the power pin class values with valid values in the library.

# TECHLIB-9149

#### NAME

TECHLIB-9149

# **SUMMARY**

For cell '%s', the bundle group '%s' (on line %d) does not have the mandatory attribute '%s' present.

#### DESCRIPTION

This message is issued when mandatory attribute in library is missing. The attribute mentioned is an essential attribute for a bundle group. The library loading cannot proceed without this. To fix the issue, re-characterize the library with appropriate settings, such that all mandatory attributes are

defined in the library.

# TECHLIB-9150

# **NAME**

TECHLIB-9150

# **SUMMARY**

Could not open file %s for %s

# **DESCRIPTION**

Could not open file <InputFileName> for reading\n\nThe input technology file <InputFileName> either does not exist or is unreadable. Provide the correct file name or change the file permissions.

# TECHLIB-9152

## NAME

TECHLIB-9152

# **SUMMARY**

Unknown Liberty %s '%s' encountered. Ignoring

# **DESCRIPTION**

Unknown Liberty entity encountered. Ignoring.\n\nSyn2Tlf does not support this construct at present.

### NAME

TECHLIB-9153

### SUMMARY

Duplicate definition for attribute '%s' encountered. The last definition will be retained.

# **DESCRIPTION**

Duplicating definition for attribute encountered. The last definition will be retained.

# TECHLIB-9154

# **NAME**

TECHLIB-9154

# **SUMMARY**

Unknown value '%s' encountered for Liberty simple attribute '%s'. Ignoring

# **DESCRIPTION**

Unknown value <value> encountered for Liberty simple attribute <name>. Ignoring.\n\nSyn2Tlf does not support the specified value <value> for the simple attribute <name> at present.

### NAME

TECHLIB-9155

### SUMMARY

Syntax error/unsupported construct '%s'

# **DESCRIPTION**

(<InputFileName>, <LineNumber>) Syntax error/unsupported construct\n\nSyntax error or unsupported construct has been encountered at the indicated line number <LineNumber> in the input technology file <InputFileName>. Check for the correctness of the syntax at the specified line number. In case of correct syntax, the error could be because Syn2Tlf does not support this construct at present. In that case, contact the Syn2Tlf support team (india\_dsm@cadence.com).

# TECHLIB-9156

# **NAME**

TECHLIB-9156

# **SUMMARY**

Syntax error: library header is missing or this file may not be a liberty file.

## DESCRIPTION

Syntax error: library header is missing. The input tech file does not contain the library header. Correct the library to contain a valid library header.

### NAME

TECHLIB-9157

### SUMMARY

Memory allocation failed

# **DESCRIPTION**

Memory allocation failed\n\nThe size of the input technology library is very large and the machine on which Syn2Tlf is being run does not have sufficient swap space for translation. Run Syn2Tlf on a machine with higher swap space.

# TECHLIB-9161

## NAME

TECHLIB-9161

### SUMMARY

Group '%s' is ignored. It is either empty or has attributes which are not relevant for current tool.

# **DESCRIPTION**

This message is issued when the group is defined either without any attributes or has attributes which are not relevant for existing tool being used. For example, group has only power related attributes which are not used in Tempus.

### NAME

TECHLIB-9162

### **SUMMARY**

Illegal comments in a statetable %s of the cell %s

# **DESCRIPTION**

This message is issued when some illegal symbols are found in the statetable definition. These are more likely to be unclosed or runaway nested comments.

# TECHLIB-9164

# **NAME**

TECHLIB-9164

# **SUMMARY**

The group name is larger than %d characters. Such large names would cause problems in downstream tools. Rename the group to remove this error.

# **DESCRIPTION**

The group name cannot be larger than the limit specified. The downstream tools might not be able to handle such large names. Rename the group to meet the size limit.

### NAME

TECHLIB-9166

### SUMMARY

Multiple library groups are defined in this text file. Only the first library will be parsed. The remaining libraries in the file will be ignored.

# **DESCRIPTION**

Multiple library groups are defined in this text file. Only the first library will be parsed. The remaining libraries in the file will be ignored.

# TECHLIB-9167

## NAME

TECHLIB-9167

### SUMMARY

Found complex attribute in user defined group. As per liberty specification, complex attributes are not allowed in user defined groups. The attribute will be ignored.

# **DESCRIPTION**

Found complex attribute in user defined group. As per liberty specification, complex attributes are not allowed in user defined groups. The attribute will be ignored.

# NAME

TECHLIB-9168

# **SUMMARY**

Unknown value '%s' encountered for Liberty simple attribute '%s'. Ignoring

# **DESCRIPTION**

Unknown value <value> encountered for Liberty simple attribute <name>. Ignoring.\n\nSoftware does not support the specified value <value> for the simple attribute <name> at present.

# TECHLIB-9170

# NAME

TECHLIB-9170

# **SUMMARY**

Multiple definitions of the fanout length '%d' for the wire\_load group. The first definition would be retained

## DESCRIPTION

This message is issued when same fanout length is defined more than once with different values in wire\_load group. The same fanout length cannot have multiple definition. First definition will be retained and rest will be ignored.

# **VOLTUS-1186**

# **NAME**

VOLTUS-1186

# **SUMMARY**

Option %s is valid only under multi-die model.

# **DESCRIPTION**

Run set\_rail\_analysis\_mode -die\_model muti-die to set correct die model.

# VOLTUS-5348

# **NAME**

VOLTUS-5348

# **SUMMARY**

Option %s is not valid under multi-die mode.

# **DESCRIPTION**

Use component\_mapping\_file in "set\_advanced\_package\_options" to set them.

•

# **WHATIF-2**

### NAME

WHATIF-2

### SUMMARY

The option '-outFile' is obsolete and will be removed in the next major release. To specify the prefix of the constraints file and the directory in which the constraints file will be generated, use the '-filePrefix' and the '-dir' options.

# **DESCRIPTION**

This message is generated when using obsolete options. These options can be removed in future and the present flow may not work. Updation in script is required.

# **WHATIF-3**

# **NAME**

WHATIF-3

# **SUMMARY**

The setWhatlfPortPriority command is obsolete and will be removed in the next major release. To set the port priority, use the setWhatlfTimingMode command.

# **DESCRIPTION**

setWhatlfPortPriority is now obsolete and has been replaced by setWhatlfTimingMode -portPriority. The -driveCell and -portParam options are not options passed to setWhatlfTimingMode (-driveCell is now cellType, -portParam is now portParam)

Example:

Error and Warning Messages

The command

\t setWhatIfPortPriority -driveCell

Becomes:

\t setWhatIfTimingMode -portPriority cellType

The command

\t setWhatIfPortPriority -portParam

Becomes:

 $\verb|\t setWhat| If Timing Mode -portPriority portParam| \\$