mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-25 08:54:37 +00:00 
			
		
		
		
	Added "select %xe %cie %coe"
This commit is contained in:
		
							parent
							
								
									4c22195c38
								
							
						
					
					
						commit
						5f54be54b8
					
				
					 1 changed files with 28 additions and 7 deletions
				
			
		|  | @ -365,7 +365,7 @@ static int parse_comma_list(std::set<RTLIL::IdString> &tokens, std::string str, | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int select_op_expand(RTLIL::Design *design, RTLIL::Selection &lhs, std::vector<expand_rule_t> &rules, std::set<RTLIL::IdString> &limits, int max_objects, char mode, CellTypes &ct) | static int select_op_expand(RTLIL::Design *design, RTLIL::Selection &lhs, std::vector<expand_rule_t> &rules, std::set<RTLIL::IdString> &limits, int max_objects, char mode, CellTypes &ct, bool eval_only) | ||||||
| { | { | ||||||
| 	int sel_objects = 0; | 	int sel_objects = 0; | ||||||
| 	bool is_input, is_output; | 	bool is_input, is_output; | ||||||
|  | @ -401,6 +401,8 @@ static int select_op_expand(RTLIL::Design *design, RTLIL::Selection &lhs, std::v | ||||||
| 		for (auto &conn : cell.second->connections()) | 		for (auto &conn : cell.second->connections()) | ||||||
| 		{ | 		{ | ||||||
| 			char last_mode = '-'; | 			char last_mode = '-'; | ||||||
|  | 			if (eval_only && !yosys_celltypes.cell_evaluable(cell.second->type)) | ||||||
|  | 				goto exclude_match; | ||||||
| 			for (auto &rule : rules) { | 			for (auto &rule : rules) { | ||||||
| 				last_mode = rule.mode; | 				last_mode = rule.mode; | ||||||
| 				if (rule.cell_types.size() > 0 && rule.cell_types.count(cell.second->type) == 0) | 				if (rule.cell_types.size() > 0 && rule.cell_types.count(cell.second->type) == 0) | ||||||
|  | @ -433,9 +435,10 @@ static int select_op_expand(RTLIL::Design *design, RTLIL::Selection &lhs, std::v | ||||||
| 	return sel_objects; | 	return sel_objects; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void select_op_expand(RTLIL::Design *design, std::string arg, char mode) | static void select_op_expand(RTLIL::Design *design, std::string arg, char mode, bool eval_only) | ||||||
| { | { | ||||||
| 	int pos = mode == 'x' ? 2 : 3, levels = 1, rem_objects = -1; | 	int pos = (mode == 'x' ? 2 : 3) + (eval_only ? 1 : 0); | ||||||
|  | 	int levels = 1, rem_objects = -1; | ||||||
| 	std::vector<expand_rule_t> rules; | 	std::vector<expand_rule_t> rules; | ||||||
| 	std::set<RTLIL::IdString> limits; | 	std::set<RTLIL::IdString> limits; | ||||||
| 
 | 
 | ||||||
|  | @ -526,7 +529,7 @@ static void select_op_expand(RTLIL::Design *design, std::string arg, char mode) | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| 	while (levels-- > 0 && rem_objects != 0) { | 	while (levels-- > 0 && rem_objects != 0) { | ||||||
| 		int num_objects = select_op_expand(design, work_stack.back(), rules, limits, rem_objects, mode, ct); | 		int num_objects = select_op_expand(design, work_stack.back(), rules, limits, rem_objects, mode, ct, eval_only); | ||||||
| 		if (num_objects == 0) | 		if (num_objects == 0) | ||||||
| 			break; | 			break; | ||||||
| 		rem_objects -= num_objects; | 		rem_objects -= num_objects; | ||||||
|  | @ -633,17 +636,32 @@ static void select_stmt(RTLIL::Design *design, std::string arg) | ||||||
| 		if (arg == "%x" || (arg.size() > 2 && arg.substr(0, 2) == "%x" && (arg[2] == ':' || arg[2] == '*' || arg[2] == '.' || ('0' <= arg[2] && arg[2] <= '9')))) { | 		if (arg == "%x" || (arg.size() > 2 && arg.substr(0, 2) == "%x" && (arg[2] == ':' || arg[2] == '*' || arg[2] == '.' || ('0' <= arg[2] && arg[2] <= '9')))) { | ||||||
| 			if (work_stack.size() < 1) | 			if (work_stack.size() < 1) | ||||||
| 				log_cmd_error("Must have at least one element on the stack for operator %%x.\n"); | 				log_cmd_error("Must have at least one element on the stack for operator %%x.\n"); | ||||||
| 			select_op_expand(design, arg, 'x'); | 			select_op_expand(design, arg, 'x', false); | ||||||
| 		} else | 		} else | ||||||
| 		if (arg == "%ci" || (arg.size() > 3 && arg.substr(0, 3) == "%ci" && (arg[3] == ':' || arg[3] == '*' || arg[3] == '.' || ('0' <= arg[3] && arg[3] <= '9')))) { | 		if (arg == "%ci" || (arg.size() > 3 && arg.substr(0, 3) == "%ci" && (arg[3] == ':' || arg[3] == '*' || arg[3] == '.' || ('0' <= arg[3] && arg[3] <= '9')))) { | ||||||
| 			if (work_stack.size() < 1) | 			if (work_stack.size() < 1) | ||||||
| 				log_cmd_error("Must have at least one element on the stack for operator %%ci.\n"); | 				log_cmd_error("Must have at least one element on the stack for operator %%ci.\n"); | ||||||
| 			select_op_expand(design, arg, 'i'); | 			select_op_expand(design, arg, 'i', false); | ||||||
| 		} else | 		} else | ||||||
| 		if (arg == "%co" || (arg.size() > 3 && arg.substr(0, 3) == "%co" && (arg[3] == ':' || arg[3] == '*' || arg[3] == '.' || ('0' <= arg[3] && arg[3] <= '9')))) { | 		if (arg == "%co" || (arg.size() > 3 && arg.substr(0, 3) == "%co" && (arg[3] == ':' || arg[3] == '*' || arg[3] == '.' || ('0' <= arg[3] && arg[3] <= '9')))) { | ||||||
| 			if (work_stack.size() < 1) | 			if (work_stack.size() < 1) | ||||||
| 				log_cmd_error("Must have at least one element on the stack for operator %%co.\n"); | 				log_cmd_error("Must have at least one element on the stack for operator %%co.\n"); | ||||||
| 			select_op_expand(design, arg, 'o'); | 			select_op_expand(design, arg, 'o', false); | ||||||
|  | 		} else | ||||||
|  | 		if (arg == "%xe" || (arg.size() > 3 && arg.substr(0, 3) == "%x" && (arg[3] == ':' || arg[3] == '*' || arg[3] == '.' || ('0' <= arg[3] && arg[3] <= '9')))) { | ||||||
|  | 			if (work_stack.size() < 1) | ||||||
|  | 				log_cmd_error("Must have at least one element on the stack for operator %%xe.\n"); | ||||||
|  | 			select_op_expand(design, arg, 'x', true); | ||||||
|  | 		} else | ||||||
|  | 		if (arg == "%cie" || (arg.size() > 4 && arg.substr(0, 4) == "%cie" && (arg[4] == ':' || arg[4] == '*' || arg[4] == '.' || ('0' <= arg[4] && arg[4] <= '9')))) { | ||||||
|  | 			if (work_stack.size() < 1) | ||||||
|  | 				log_cmd_error("Must have at least one element on the stack for operator %%cie.\n"); | ||||||
|  | 			select_op_expand(design, arg, 'i', true); | ||||||
|  | 		} else | ||||||
|  | 		if (arg == "%coe" || (arg.size() > 4 && arg.substr(0, 4) == "%coe" && (arg[4] == ':' || arg[4] == '*' || arg[4] == '.' || ('0' <= arg[4] && arg[4] <= '9')))) { | ||||||
|  | 			if (work_stack.size() < 1) | ||||||
|  | 				log_cmd_error("Must have at least one element on the stack for operator %%coe.\n"); | ||||||
|  | 			select_op_expand(design, arg, 'o', true); | ||||||
| 		} else | 		} else | ||||||
| 			log_cmd_error("Unknown selection operator '%s'.\n", arg.c_str()); | 			log_cmd_error("Unknown selection operator '%s'.\n", arg.c_str()); | ||||||
| 		if (work_stack.size() >= 1) | 		if (work_stack.size() >= 1) | ||||||
|  | @ -1031,6 +1049,9 @@ struct SelectPass : public Pass { | ||||||
| 		log("    %%co[<num1>|*][.<num2>][:<rule>[:<rule>..]]\n"); | 		log("    %%co[<num1>|*][.<num2>][:<rule>[:<rule>..]]\n"); | ||||||
| 		log("        simmilar to %%x, but only select input (%%ci) or output cones (%%co)\n"); | 		log("        simmilar to %%x, but only select input (%%ci) or output cones (%%co)\n"); | ||||||
| 		log("\n"); | 		log("\n"); | ||||||
|  | 		log("    %%xe[...] %%cie[...] %%coe\n"); | ||||||
|  | 		log("        like %%x, %%ci, and %%co but only consider combinatorial cells\n"); | ||||||
|  | 		log("\n"); | ||||||
| 		log("    %%a\n"); | 		log("    %%a\n"); | ||||||
| 		log("        expand top set by selecting all wires that are (at least in part)\n"); | 		log("        expand top set by selecting all wires that are (at least in part)\n"); | ||||||
| 		log("        aliases for selected wires.\n"); | 		log("        aliases for selected wires.\n"); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue