• Sharry
    2019-07-03
    终于把共享内存和信号量集合的知识串联在一起了, 其中的操作的确有些复杂

    共享内存若想实现进程之间的同步读写, 则需要配合信号量共同使用
    - **共享内存**
      - **共享内存的创建**
        - 开辟共享内存区域, 使用 shmid_kernel 描述
        - 通过 kvmalloc 在内核的直接映射区分配一个 shmid_kernel 结构体
        - 将内存映射到文件
          - 这个文件并非磁盘文件, **而是通过内存文件系统 shmem 创建的内存文件**
          - 这么做的原因是因为**文件可以跨进程共享**
          - 将这个 shmid_kernel 挂载到共享内存基树上, 返回对应的 id
      - **共享内存的映射**
        - 通过 id 在共享内存基树上找到对应的共享内存描述 shmid_kernel
        - 创建一个 shm_file_data 指向共享内存的内存文件
        - 创建一个 file 指向 shm_file_data
        - 在用户空间找一块内存区域, 将这个 file 映射到用户地址空间
          - 通过文件映射之后, 便可以在用户空间操作这块内存了
    - **信号量集合**
      - 信号量集合的创建
        - 创建 sem_array 结构体, 用于描述信号量
        - 将这个 sem_array 信号量添加到基树上, 返回对应的 id
      - 信号量集合的初始化
        - SETALL: 为所有信号量集合赋值
        - SETVAL: 为指定信号量赋值
      - 操作信号量集合
        - 调用 **perform_atomic_semop** 尝试从操作队列中读取执行
        - 若执行成功, 则说明无需等待
          - 调用 do_smart_update, 看看这次操作能够激活等待队列中的哪些进程
          - 调用 **wake_up_q** 唤醒因为信号量阻塞的进程
        - 若需要等待
          - 根据是操作信号量还是信号集合, 将其挂载到对应的 pending_alter 中
          - 执行 looper 等待, 直到 timeout 或者被 wake_up_q 唤醒
            - 若未设置 timeout, 则让出 CPU 资源
    展开
    
     2
  • Helios
    2019-10-18
    思考问题总结了个图:
    https://user-images.githubusercontent.com/12036324/67062221-431e6f80-f195-11e9-9dd1-4353ebbc730c.png

    https://github.com/helios741/myblog/issues/60
    
     1
  • Geek_835e66
    2019-07-16
    请问消息队列的内容在哪里?

    作者回复: 实际编程的时候,用的少,就没有解析

     1
     1
  • 免费的人
    2019-07-03
    消息队列的内核实现好像没讲过?

    作者回复: 是的,因为不太被使用

     2
     1
  • 王之刚
    2019-07-06
    请问一下老师,在应用程序开发中,像信号量 共享内存这些内核资源怎么样防止泄漏呢?比如有进程a和b用共享内存共享数据,共享内存资源由教程a申请和维护,但由于异常情况导致教程异常退出导致共享内存资源没有释放,导致了申请的共享内存没有释放。这种情况一般怎么处理呢?Linux内核是否有相关资源保护吗?谢谢了

    作者回复: 或者客户端,或者服务端,要负责到底,不负责到底的话,linux就被搞挂了呗。所以c语言不像java那样有个垃圾回收器,而是自己要操心整个生命周期,不操心就会出事情

    
    
  • 安排
    2019-07-04
    schedule_timeout调用完后,会让出cpu,过一段时间还会回来。这个过一段时间是多长时间啊?是说超时之后返回来吗,还是被其它信号打断睡眠之后回来?
     1
    
  • 莫名
    2019-07-04
    老师,有没有打算讲一下POSIX IPC呢?
    
    
我们在线,来聊聊吧