BufferedCustomFileEmission

firrtl.options.BufferedCustomFileEmission

A buffered version of CustomFileEmission

This is especially useful for serializing large data structures. When emitting Strings, it makes it much easier to avoid materializing the entire serialized String in memory. It also helps avoid materializing intermediate datastructures in memory. Finally, it reduces iteration overhead and helps optimize I/O performance.

It may seem strange to use Array[Byte] in an otherwise immutable API, but for maximal performance it is best to use the JVM primitive that file I/O uses. These Arrays should only used immutably even though the Java API technically does allow mutating them.

Attributes

Deprecated
[Since version Chisel 7.0.0] All APIs in package firrtl are deprecated.
Source
StageAnnotations.scala
Graph
Supertypes
class Object
trait Matchable
class Any
Known subtypes
Self type

Members list

Value members

Abstract methods

def getBytesBuffered: Iterable[Array[Byte]]

A buffered version of getBytes for more efficient serialization

A buffered version of getBytes for more efficient serialization

If you only need to serialize an Iterable[String], you can use the String.getBytes method. It's also helpful to create a view which will do the .map lazily instead of eagerly, improving GC performance.

def getBytesBuffered: Iterable[Array[Byte]] = myListString.view.map(_.getBytes)

Attributes

Source
StageAnnotations.scala

Concrete methods

final def getBytes: Iterable[Byte]

A method that can convert this annotation to bytes that will be written to a file.

A method that can convert this annotation to bytes that will be written to a file.

If you only need to serialize a string, you can use the getBytes method:

def getBytes: Iterable[Byte] = myString.getBytes

Attributes

Source
StageAnnotations.scala

Inherited methods

final def filename(annotations: AnnotationSeq): File

Method that returns the filename where this annotation will be serialized.

Method that returns the filename where this annotation will be serialized.

Value parameters

annotations

the annotations at the time of serialization

Attributes

Inherited from:
CustomFileEmission
Source
StageAnnotations.scala
def replacements(file: File): AnnotationSeq

Optionally, a sequence of annotations that will replace this annotation in the output annotation file.

Optionally, a sequence of annotations that will replace this annotation in the output annotation file.

A non-empty implementation of this method is a mechanism for telling a downstream Stage how to deserialize the information that was serialized to a separate file. For example, if a FIRRTL circuit is serialized to a separate file, this method could include an input file annotation that a later stage can use to read the serialized FIRRTL circuit back in.

Attributes

Inherited from:
CustomFileEmission
Source
StageAnnotations.scala

Inherited and Abstract methods

protected def baseFileName(annotations: AnnotationSeq): String

Output filename where serialized content will be written

Output filename where serialized content will be written

The full annotation sequence is a parameter to allow for the location where this annotation will be serialized to be a function of other annotations, e.g., if the location where information is written is controlled by a separate file location annotation.

Value parameters

annotations

the annotation sequence at the time of emission

Attributes

Inherited from:
CustomFileEmission
Source
StageAnnotations.scala
protected def suffix: Option[String]

Optional suffix of the output file

Optional suffix of the output file

Attributes

Inherited from:
CustomFileEmission
Source
StageAnnotations.scala