"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > x86 어셈블리의 \"lock\" 명령이 버스를 무기한 유지합니까?

x86 어셈블리의 \"lock\" 명령이 버스를 무기한 유지합니까?

2024-11-08에 게시됨
검색:941

 Does the \

x86 어셈블리의 "잠금" 명령어 이해

x86 어셈블리의 "잠금" 명령어는 후속 명령어에 대해 버스의 독점적 소유권을 적용하는 접두사입니다. 이렇게 하면 CPU가 해당 명령 기간 동안 캐시 라인을 완벽하게 제어할 수 있습니다.

버스 잠금 비활성화

일반적인 이해와는 달리 "lock" 접두사는 CPU를 잠그지 않습니다. 버스는 무한정. 잠금은 후속 명령 실행 후 해제됩니다. 이를 통해 CPU는 꼭 필요한 경우에만 버스를 잠가서 최적의 성능을 유지할 수 있습니다.

"잠금"을 사용한 추가 구현

제공하신 코드 조각은 다음 위치에서 긴 단어의 원자적 증분을 구현합니다. ecx 레지스터의 값으로 지정된 메모리 위치:

  1. movl 4(%esp), �x: 증가할 변수의 주소를 ecx 레지스터에 복사합니다.
  2. incl (�x): ecx 레지스터에 저장된 주소에서 긴 단어를 원자적으로 증가시킵니다.
  3. mov $0,�x: eax 레지스터를 0으로 설정합니다.
  4. setne %al: 변수의 새 값이 0이 아닌 경우(증가 작업이 성공했음을 나타냄) al 레지스터의 값을 1로 설정합니다.

결과적으로 변수는 다음과 같이 원자적으로 증가됩니다. 1이고 eax 레지스터는 새 값이 0이면 0으로 설정되고 그렇지 않으면 1로 설정됩니다. 이 작업은 추가가 아닌 증가입니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3