dts的pci模块中bus-range和ranges

bus-range = <2 3>;       该设备(一般为RC)下的pci总线号范围
 ranges = <0x2000000 0x0 0xc0000000 0 0xc0000000 0x0 0x20000000  
                 0x1000000 0x0 0x00000000 0 0xffc20000 0x0 0x10000>;

ranges表示资源配置信息,7个元素为一组,第一个元素表示属性,第二个和第三个为pci域地址,第四个和第五个为CPU域地址空间,第六个和第七个为size,表示设备将访问CPU域的地址时,将转化到pci域的地址

kernel 4.12.12代码中

of_pci_get_host_bridge_resources函数用来解析该配置信息

  ----of_pci_parse_bus_range

    |----of_get_property(node, "bus-range", &len);

  ----of_pci_range_parser_init

    |----of_get_property(node, "ranges", &rlen);

    |----for_each_of_pci_range

      |----of_pci_range_parser_one

 

range->pci_space = be32_to_cpup(parser->range);
range->flags = of_bus_pci_get_flags(parser->range);
range->pci_addr = of_read_number(parser->range + 1, ns);
range->cpu_addr = of_translate_address(parser->node,
parser->range + na);
range->size = of_read_number(parser->range + parser->pna + na, ns);

 

posted @ 2018-07-13 22:18  二虎  阅读(2589)  评论(1编辑  收藏  举报