linuxer
    @electrlife:我觉得内核中的semaphore和你说的场景是类似的,我们一起来看看它的代码(示意代码,我做了修改): void down(struct semaphore *sem) { raw_spin_lock_irqsave(&sem->lock, flags);----加锁 list_add_tail(&waiter.list, &sem->wait_list);--挂入等待队列 for (;;) { __set_task_state(task, state);-----设定任务状态 raw_spin_unlock_irq(&sem->lock);----解锁 timeout = schedule_timeout(timeout);-----调度 raw_spin_lock_irq(&sem->lock);------上锁 } raw_spin_unlock_irqrestore(&sem->lock, flags);----解锁 } 从上面的代码可以看出来,1和2是临界区,被spin lock保护的。
    Linux内核同步机制之(一):原子操作  发表时间:2015-08-12 11:26
    Eros_Y
    刚开始学习,受益良多,会继续跟进!
    Linux设备模型(1)_基本概念  发表时间:2015-08-12 11:16
    tastier
    @wowo:wowo大神,请问反编译出来的dts文件可以直接用来生成dtb文件吗?
    Device Tree(三):代码分析  发表时间:2015-08-12 10:20
    dd
    @wowo:我也是用的emlog的主机,但没有用emlog,主机在美国,前几天他们的美国主机被黑了,所有的资料及备份全没了,幸好我自己有备份。。我觉得博主最好找个好点的主机或服务器,比如新浪云,阿里云等,不然这么好的一个博客没了,实在是太可惜了。
    留言板  发表时间:2015-08-12 09:22
    electrlife
    一直一来,有一个和原语操作类似概念(临界段)代码不解, task1: 1 add_waitqueue(); 2 set_current_state(TASH_UNINTERRUPTIBLE); 3 schedule(); 上面的代码是大多同步机制使用的,让线程进入阻塞的一种方式,个人的理解,对于1,2,3的所有操作应该是一个 临界段,但是内核中所的代码都是这样操作。比如如果在2和3的操作中发生抢占,而获得运行的线程,正好release 相关的资源,并把task1从相应的waitqueue中移除,而当task1再次运行时,接着进行schedule,让自己让出cpu, 但此时的task1则丢失了此次的信号。不知道自己应该从哪方面去理解类似的这种场景,希望解惑!
    Linux内核同步机制之(一):原子操作  发表时间:2015-08-12 07:02
    wowo
    @wenky:非常感谢wenky的建议,由于对ARM64的理解不是很深刻,有些表述不清或者错误的地方,还请多指正、讨论。 关于A64指令集的定义,确实不太好表述,因此本文只是如实引用了ARM白皮书(ARMv8_white_paper_v5.pdf)中的说法:“Does ARMv8 need to be considering a full 64-bit instruction set architecture with its larger virtual address space architecture or not?”,也即64-bit指令集。至于这里的64-bit到底指的是什么,由于不想在这个介绍性的文档中带入太多信息,就没有提。是的,您的说法是正确的,指令编码是32位,通用寄存器等,是64位。 关于内存寻址,您说的也很正确,和总线以及内存管理单元有关,和指令集无关,但这并不是A64关心的地方。对于物理内存,ARMv7+LPAE是可以解决4GB的限制,但虚拟内存怎么办?这才是A64关心的地方。 正因为有MMU的存在,内存寻址才可以和指令集剥离开来,CPU访问虚拟地址,MMU将之转换为物理地址(理论上可以是任何范围)。但虚拟地址的范围由什么决定的呢?可以参考下面的表述(希望后续能以单独的文章和大家讨论AArch64的内存模型,这里就不再细述了): The A64 instruction set supports 64-bit addresses. The valid address range is determined by the following factors: • The size of the implemented virtual address space. • Memory Management Unit (MMU) configuration settings.
    ARMv8-a架构简介  发表时间:2015-08-11 09:15
    linuxer
    @faxiang1230:你再仔细看看Distributor,cpu interface和cpu的结构图,然后思考这样一个问题:如果cpu 0想要把某个SPI送达自己,那么它应该怎么做?如果拓扑结构是: cpu interface 0 -----> cpu 0 cpu interface 1 -----> cpu 1 ....... cpu interface 7 -----> cpu 7 那么实际上设定到GIC_DIST_TARGETx(x和你要设定的SPI中断号相关)寄存器的mask是0b00000001,不过实际上,拓扑结构并发总是那么一一对应,假设拓扑结构如下: cpu interface 0 -----> cpu 4 cpu interface 1 -----> cpu 1 cpu interface 2 -----> cpu 2 cpu interface 3 -----> cpu 3 cpu interface 4 -----> cpu 0 cpu interface 5 -----> cpu 5 cpu interface 6 -----> cpu 6 cpu interface 7 -----> cpu 7 在这样的结构下,cpu 0想要把某个SPI送达自己应该怎么办?实际上该SPI的中断信号是需要送到cpu interface 4,其实也就是送达了cpu0。这时候,cpu 0在set affinity的时候需要设定的mask就是0b00010000,对应cpu interface 4. 那么,如何得到cpu和cpu interface之间的拓扑呢?当然通过read only的寄存器了,这些都是芯片设计的时候就确定的结构。使用哪个寄存器呢? 我们知道SGI和PPI不需要使用GIC_DIST_TARGET控制target CPU。SGI送达目标CPU有自己特有的寄存器来控制(Software Generated Interrupt Register),对于PPI,其是CPU私有的,因此不需要控制target CPU。GIC_DIST_TARGET0~GIC_DIST_TARGET7是控制0~31这32个interrupt ID(SGI和PPI)的target CPU的,但是实际上SGI和PPI是不需要控制target CPU的,因此,可以借用这些TARGET寄存器。
    linux kernel的中断子系统之(七):GIC代码分析  发表时间:2015-08-11 09:13
    faxiang1230
    @faxiang1230:如果每个Dist都需要GIC_DIST_TARGET0~GIC_DIST_TARGET7,那么8×8应该有64个GICD_ITARGETSR,但是GIC-400的文档上是这样的: 0x800 - 0x81C GICD_ITARGETSRn---共计28个,对不上啊? 而且读出来的值也不对,很困或。
    linux kernel的中断子系统之(七):GIC代码分析  发表时间:2015-08-11 00:59
    faxiang1230
    @piter:那为什么读出来的是0b00010000值?不懂啊,睡不着觉。
    linux kernel的中断子系统之(七):GIC代码分析  发表时间:2015-08-11 00:53
    wenky
    版主,A64指令集可不是指ARMv8指令集是64位的,"Each instruction in A64 is defined within a fixed length 32-bit instruction."。实际上指令集只是对指令的一种编码方式,32位的编码对目前来说已经够用了。64位主要是指寄存器的宽度是64位,另外内存寻址范围跟寄存器的宽度也没关系,取决于处理器内部的总线宽度,实际上ARMv8寻址也只用到了48位。Intel32位的处理器内部寻址总线也远远不止32位。阅读量越来越大、请及时修正~~
    ARMv8-a架构简介  发表时间:2015-08-11 00:03

共7893条576/790上一页 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 下一页
Copyright @ 2013-2015 蜗窝科技 All rights reserved. Powered by emlog