mecanismos de trava no conjunto x86 Assembly
na montagem x86, a instrução "bloqueio" é um prefixo em vez de uma própria instrução. Ele modifica a instrução subsequente, normalmente uma operação de leitura-modificação-gravação na memória, para garantir que a CPU mantenha o acesso exclusivo à linha de cache necessária. Em vez disso, aciona a CPU para implementar mecanismos de travamento para garantir a integridade dos dados. Isso pode envolver afirmar uma trava de ônibus, mas as CPUs geralmente buscam otimizações e evitam o bloqueio de ônibus sempre que possível. Em vez disso, eles podem empregar bloqueio de cache ou outras técnicas para manter o acesso exclusivo. O estado bloqueado termina assim que a instrução bloqueada estiver concluída. Aqui está uma quebra:
O código carrega o endereço da variável a ser incrementado da pilha para o registro ecx. Seguir as instruções Defina o EAX (o valor de retorno) como 0 se o valor incrementado for 0 e 1 caso contrário.
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3