베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • 자바8
    • 운영체제
    • 이펙티브자바
    • 함수형인터페이스
    • 스프링시큐리티
    • 코드업
    • 자바
    • 토비스프링
    • Spring
    • BFS
    • leetcode
    • C++
    • dfs
    • 백준
    • java
    • 스프링
    • 데이터베이스
    • jpa
    • 스레드
    • 알고리즘

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    [운영체제] 동기화를 위한 하드웨어 지원
    운영체제(OS)/공룡책

    [운영체제] 동기화를 위한 하드웨어 지원

    2021. 5. 3. 21:46

    피터슨의 방법은 하드웨어 지원을 요구하지 않기 때문에 소프트웨어 기반 해결책이라고 함.

    → 임계구역 문제를 해결하기 위한 3가지 하드웨어 명령어가 제시됨.

     

    다음과 같은 상황을 가정해보자.

    x = 100의 연산과 flag = true의 연산은 서로 아무련 관련이 없다.

    ->만약 컴파일러가 flag = true를 먼저 실행한다면 예상과 다른 값이 나와버린다.

     

    이러한 문제를 해결하기 위해 하드웨어 명령어를 제시한다.

    1 ) 메모리 장벽 : memory barrier() 위로 선언된 모든 문장들이 실행 되어야 그 다음 문장이 실행됨.

    while(!flag)
        memory_barrier();
    print x;
    
    x = 100;           // x가 적재 되는 것을 보장
    memory_barrier();
    flag = true;

     

    2 ) test_and_set : 기계어 명령으로 atomy하게 실행됨.

    boolean test_and_set (boolean *target)
    {
        boolean rv = *target;
        *target = TRUE;
        return rv;
    }

     

    단점 : 무한 대기 문제가 생길 수 있음. 여러 프로세스가 있을 때 흔히 발생.

    → 한계 대기로 바꿔 해결가능 (한 방향으로 체크하면서 실행하게 함)

    3 ) compare_and_swap : 원래 있던 값이 expected값과 같으면 새로운 값을 대입 후 이전 값 리턴.

    int compare_and_swap(int *value, int expected, int new_value) 
    {
        int temp = *value;
        if(*value == expected)
            *value = new_value;
        return temp;
    }
      '운영체제(OS)/공룡책' 카테고리의 다른 글
      • [운영체제] POSIX 동기화
      • [운영체제] 고전적 동기화 문제들
      • [운영체제] 스레드 스케줄링
      • [운영체제] 프로세스 간 통신 - 공유 메모리
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바