Skip to content

Commit

Permalink
[lower_to_mlir] Use named_attrs from tt-forge ops instead of hardcodi…
Browse files Browse the repository at this point in the history
…ng attributes for each op, while lowering to mlir.
  • Loading branch information
dgolubovicTT committed Aug 9, 2024
1 parent 9fdcd5a commit 557ed8b
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 10 deletions.
34 changes: 26 additions & 8 deletions pybuda/csrc/passes/lower_to_mlir.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ using namespace tt;
/**
* @brief Implementation of TT-MLIR emission from the TTForge graph.
*/

class MLIRGenerator
{
public:
Expand Down Expand Up @@ -109,6 +110,25 @@ class MLIRGenerator
symbolTable_[node->name()] = {value, node};
}

// Convert a TTForge attribute to an MLIR attribute.
mlir::Attribute convert_to_mlir_attribute(const tt::BudaOpAttr& value) {
return std::visit([this](auto&& arg) -> mlir::Attribute {
using T = std::decay_t<decltype(arg)>;
if constexpr (std::is_same_v<T, std::string>) {
return builder_.getStringAttr(arg);
} else if constexpr (std::is_same_v<T, bool>) {
return builder_.getBoolAttr(arg);
} else if constexpr (std::is_same_v<T, int>) {
return builder_.getI32IntegerAttr(arg);
} else if constexpr (std::is_same_v<T, float>) {
return builder_.getF32FloatAttr(arg);
} else {
// If type not handled, throw an exception or handle it appropriately
throw std::runtime_error("Unhandled attribute type");
}
}, value);
}

/// Emit a new function in MLIR.
/// A function represents a set of TTForge operations that are executed to produce output results.
/// This function will generate the MLIR code for each TTForge operation in the graph and emit the return operation for the function.
Expand Down Expand Up @@ -225,15 +245,13 @@ class MLIRGenerator
}
}

// Workaround for now, need to figure out how to handle this properly
if(op_node->op_name() == "softmax")
for(const auto & attribute: op_node->op_type().named_attrs)
{
log_info("Softmax");
int32_t dimension = std::get<int>(op_node->op_attrs()[0]);
mlir::NamedAttribute dimension_attribute = builder_.getNamedAttr(
"dimension",
builder_.getSI32IntegerAttr(dimension));
attributes.push_back(dimension_attribute);
// convert atribute to mlir atribute
auto mlir_atribute = convert_to_mlir_attribute(attribute.second);
mlir::NamedAttribute named_attribute = builder_.getNamedAttr(
attribute.first, mlir_atribute);
attributes.push_back(named_attribute);
}

auto op = builder_.create<TTIROp>(
Expand Down
4 changes: 2 additions & 2 deletions pybuda/pybuda/op/nn.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ def Softmax(
Tensor
Buda tensor
"""
return op("softmax", name, operandA, attrs=(dim, stable)).get_tensor()
return op("softmax", name, operandA, attrs=(dim, stable), dimension=dim).get_tensor()


def LogSoftmax(
Expand Down Expand Up @@ -82,7 +82,7 @@ def LogSoftmax(
Tensor
Buda tensor
"""
return op("log_softmax", name, operandA, attrs=(dim, stable)).get_tensor()
return op("log_softmax", name, operandA, attrs=(dim, stable), dimension=dim).get_tensor()

def Layernorm(
name: str,
Expand Down

0 comments on commit 557ed8b

Please sign in to comment.