×

Optimizing placement of circuit resources using a globally accessible placement memory

  • US 10,210,297 B2
  • Filed: 12/07/2016
  • Issued: 02/19/2019
  • Est. Priority Date: 03/24/2015
  • Status: Expired due to Fees
First Claim
Patent Images

1. A computer program product comprising:

  • a non-transitory machine readable storage device; and

    computer code stored on the non-transitory machine readable storage device, with the computer code including instructions for causing a processor(s) set to perform operations including the following;

    partitioning, by the processor(s) set, a logic network comprising a plurality of logic elements into a plurality of logic partitions;

    launching, by the processor(s) set, a plurality of placement optimization threads that correspond to the plurality of logic partitions;

    allocating, by the processor(s) set, memory that is accessible to the plurality of placement optimization threads to provide a globally accessible placement memory;

    reserving, by the processor(s) set, a placement location for at least a portion of the plurality of logic elements via the globally accessible placement memory; and

    wherein each placement optimization thread of the plurality of placement optimization threads is configured to conduct the operations of;

    determining, by the processor(s) set, a desired location for a logic element of the plurality of logic elements, wherein the logic element is within a logic partition that corresponds to the placement optimization thread,reserving, by the processor(s) set and via the globally accessible placement memory, a plurality of potential locations for the logic element that are proximate to the desired location,determining, by the processor(s) set, a best location from the plurality of potential locations,releasing, by the processor(s) set, each of the plurality of potential locations that are not the best location,placing, by the processor(s) set, the logic element at the best location, andwherein reserving a potential location comprises locking at least a portion of the globally accessible placement memory, inserting, by the processor(s) set, a thread identifier within at least one entry of an owning thread array stored within the globally accessible placement memory, inserting, by the processor(s) set, at least one bit within a reserved locations bitmap stored within the globally accessible placement memory, and unlocking, by the processor(s) set, the portion of the globally accessible placement memory that was locked to reserve the potential location.

View all claims
  • 1 Assignment
Timeline View
Assignment View
    ×
    ×