property_get/property_set

本文深入介绍了Android系统中的属性服务机制,包括属性的加载、修改、只读和持久化特性等。详细阐述了如何通过API函数获取和设置属性,并解释了特殊属性的作用。

每个属性都有一个名称和值,他们都是字符串格式。属性被大量使用在Android系统中,用来记录系统设置或进程之间的信息交换。属性是在整个系统中全局可见的。每个进程可以get/set属性。

 

在系统初始化时,Android将分配一个共享内存区来存储的属性。这些是由“init”守护进程完成的,其源代码位于:device/system/init。“init”守护进程将启动一个属性服务。

 

属性服务在“init”守护进程中运行。每一个客户端想要设置属性时,必须连接属性服务,再向其发送信息。属性服务将会在共享内存区中修改和创建属性。任何客户端想获得属性信息,可以从共享内存直接读取。这提高了读取性能。客户端应用程序可以调用libcutils中的API函数以GET/SET属性信息。libcutils的源代码位于:device/libs/cutils。API函数是:

int property_get(const char *key, char *value, const char *default_value);

int property_set(const char *key, const char *value);

 

而libcutils又调用libc中的 __system_property_xxx 函数获得共享内存中的属性。libc的源代码位于:device/system/bionic。

 

属性服务调用libc中的__system_property_init函数来初始化属性系统的共享内存。当启动属性服务时,将从以下文件中加载默认属性:

 

/default.prop

/system/build.prop

/system/default.prop

/data/local.prop

 

属性将会以上述顺序加载。后加载的属性将覆盖原先的值。这些属性加载之后,最后加载的属性会被保持在/data/property中。

 

特别属性如果属性名称以“ro.”开头,那么这个属性被视为只读属性。一旦设置,属性值不能改变。

 

如果属性名称以“persist.”开头,当设置这个属性时,其值也将写入/data/property。

 

如果属性名称以“net.”开头,当设置这个属性时,“net.change”属性将会自动设置,以加入到最后修改的属性名。(这是很巧妙的。 netresolve模块的使用这个属性来追踪在net.*属性上的任何变化。)

 

属性“ ctrl.start ”和“ ctrl.stop ”是用来启动和停止服务。

 

每一项服务必须在/init.rc中定义.系统启动时,与init守护进程将解析init.rc和启动属性服务。一旦收到设置“ ctrl.start ”属性的请求,属性服务将使用该属性值作为服务名找到该服务,启动该服务。这项服务的启动结果将会放入“ init.svc.<服务名>“属性中 。客户端应用程序可以轮询那个属性值,以确定结果

这段代码的意义:#---------------- LOC ------------------- set_property LOC IDELAYCTRL_X0Y5 [get_cells -hierarchical -filter {NAME =~ *loop_IDELAYCTRL[0].inst_IDELAYCTRL}] set_property LOC IDELAYCTRL_X0Y6 [get_cells -hierarchical -filter {NAME =~ *loop_IDELAYCTRL[1].inst_IDELAYCTRL}] set_property LOC IDELAYCTRL_X0Y4 [get_cells -hierarchical -filter {NAME =~ *loop_IDELAYCTRL[2].inst_IDELAYCTRL}] set_property LOC IDELAYCTRL_X0Y1 [get_cells -hierarchical -filter {NAME =~ *loop_IDELAYCTRL[3].inst_IDELAYCTRL}] set_property LOC IDELAY_X0Y274 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[0].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y222 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[1].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y280 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[2].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y228 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[3].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y246 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[4].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y242 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[5].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y262 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[6].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y230 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[7].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y296 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[8].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y266 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[9].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y236 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[10].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y282 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[11].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y284 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[12].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y286 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[13].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y272 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_COUT[14].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y294 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[0].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y290 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[1].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y334 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[2].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y344 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[3].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y342 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[4].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y348 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[5].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y304 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[6].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y312 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[7].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y308 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[8].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y314 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[9].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y336 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[10].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y302 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[11].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y326 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[12].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y346 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[13].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y316 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_COUT[14].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y208 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[0].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y206 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[1].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y218 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[2].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y204 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[3].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y224 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[4].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y210 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[5].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y240 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[6].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y238 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[7].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y202 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[8].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y232 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[9].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y216 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[10].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y220 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[11].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y214 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[12].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y212 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[13].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y244 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_COUT[14].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y84 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[0].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y76 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[1].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y96 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[2].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y90 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[3].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y80 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[4].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y88 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[5].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y82 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[6].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y62 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[7].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y72 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[8].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y56 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[9].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y54 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[10].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y58 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[11].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y92 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[12].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y98 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[13].inst_Serdes/IDELAYE2_inst}] set_property LOC IDELAY_X0Y60 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_COUT[14].inst_Serdes/IDELAYE2_inst}] set_property LOC ILOGIC_X0Y274 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[0].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y222 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[1].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y280 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[2].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y228 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[3].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y246 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[4].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y242 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[5].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y262 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[6].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y230 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[7].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y296 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[8].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y266 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[9].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y236 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[10].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y282 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[11].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y284 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[12].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y286 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_DATA[13].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y272 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TL/Loop_Serdes_COUT[14].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y294 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[0].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y290 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[1].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y334 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[2].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y344 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[3].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y342 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[4].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y348 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[5].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y304 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[6].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y312 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[7].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y308 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[8].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y314 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[9].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y336 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[10].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y302 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[11].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y326 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[12].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y346 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_DATA[13].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y316 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_TR/Loop_Serdes_COUT[14].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y208 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[0].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y206 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[1].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y218 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[2].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y204 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[3].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y224 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[4].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y210 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[5].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y240 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[6].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y238 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[7].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y202 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[8].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y232 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[9].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y216 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[10].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y220 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[11].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y214 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[12].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y212 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_DATA[13].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y244 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BL/Loop_Serdes_COUT[14].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y84 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[0].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y76 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[1].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y96 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[2].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y90 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[3].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y80 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[4].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y88 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[5].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y82 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[6].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y62 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[7].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y72 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[8].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y56 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[9].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y54 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[10].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y58 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[11].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y92 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[12].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y98 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_DATA[13].inst_Serdes/IDDR_inst}] set_property LOC ILOGIC_X0Y60 [get_cells -hierarchical -filter {NAME =~ *inst_Serdes_Top_BR/Loop_Serdes_COUT[14].inst_Serdes/IDDR_inst}]
最新发布
08-20
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值