12bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan/* ===-- clzdi2.c - Implement __clzdi2 -------------------------------------===
22bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan *
31c5f89b1dd741135a4007ab577723d422f421eecAnton Korobeynikov *               The LLVM Compiler Infrastructure
42bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan *
59ad441ffec97db647fee3725b3424284fb913e14Howard Hinnant * This file is dual licensed under the MIT and the University of Illinois Open
69ad441ffec97db647fee3725b3424284fb913e14Howard Hinnant * Source Licenses. See LICENSE.TXT for details.
72bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan *
82bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan * ===----------------------------------------------------------------------===
92bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan *
102bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan * This file implements __clzdi2 for the compiler_rt library.
112bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan *
122bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan * ===----------------------------------------------------------------------===
132bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan */
14b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar
15b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar#include "int_lib.h"
16b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar
172bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan/* Returns: the number of leading 0-bits */
18b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar
192bf62728b8ce00e295c7bf0fb328427496cc85aaEdward O'Callaghan/* Precondition: a != 0 */
20b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar
211c5f89b1dd741135a4007ab577723d422f421eecAnton KorobeynikovCOMPILER_RT_ABI si_int
22b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar__clzdi2(di_int a)
23b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar{
24b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar    dwords x;
25b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar    x.all = a;
268bf1e094893cb24796137b47ee0d46d18d299996Edward O'Callaghan    const si_int f = -(x.s.high == 0);
278bf1e094893cb24796137b47ee0d46d18d299996Edward O'Callaghan    return __builtin_clz((x.s.high & ~f) | (x.s.low & f)) +
28b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar           (f & ((si_int)(sizeof(si_int) * CHAR_BIT)));
29b3a6901e66f55b35aa9e01bcb24134e6a65ea004Daniel Dunbar}
30