// Copyright 2020 Google LLC // // This source code is licensed under the BSD-style license found in the // LICENSE file in the root directory of this source tree. #include #include #include #include #include #include enum xnn_status xnn_define_depth_to_space( xnn_subgraph_t subgraph, uint32_t input_id, uint32_t output_id, uint32_t block_size, uint32_t flags) { if ((xnn_params.init_flags & XNN_INIT_FLAG_XNNPACK) == 0) { xnn_log_error("failed to define %s operator: XNNPACK is not initialized", xnn_node_type_to_string(xnn_node_type_depth_to_space)); return xnn_status_uninitialized; } if (input_id >= subgraph->num_values) { xnn_log_error( "failed to define %s operator with input ID #%" PRIu32 ": invalid Value ID", xnn_node_type_to_string(xnn_node_type_depth_to_space), input_id); return xnn_status_invalid_parameter; } if (output_id >= subgraph->num_values) { xnn_log_error( "failed to define %s operator with output ID #%" PRIu32 ": invalid Value ID", xnn_node_type_to_string(xnn_node_type_depth_to_space), output_id); return xnn_status_invalid_parameter; } if (block_size < 2) { xnn_log_error( "failed to define %s operator with block size #%" PRIu32 ": invalid block_size", xnn_node_type_to_string(xnn_node_type_depth_to_space), block_size); return xnn_status_invalid_parameter; } struct xnn_node* node = xnn_subgraph_new_node(subgraph); if (node == NULL) { return xnn_status_out_of_memory; } node->type = xnn_node_type_depth_to_space; node->num_inputs = 1; node->inputs[0] = input_id; node->num_outputs = 1; node->outputs[0] = output_id; node->params.depth_to_space.block_size = block_size; node->flags = flags; return xnn_status_success; }