feat(server): check cuda capability when importing flash models (#201)

close #198
This commit is contained in:
OlivierDehaene 2023-04-19 12:52:37 +02:00 committed by GitHub
parent e14ae3b5e9
commit a88c54bb4c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 12 additions and 1 deletions

View File

@ -24,7 +24,18 @@ try:
FlashSantacoderSharded,
)
FLASH_ATTENTION = torch.cuda.is_available()
if torch.cuda.is_available():
major, minor = torch.cuda.get_device_capability()
is_sm75 = major == 7 and minor == 5
is_sm8x = major == 8 and minor >= 0
is_sm90 = major == 9 and minor == 0
supported = is_sm75 or is_sm8x or is_sm90
if not supported:
raise ImportError(f"GPU with CUDA capability {major} {minor} is not supported")
FLASH_ATTENTION = True
else:
FLASH_ATTENTION = False
except ImportError:
logger.opt(exception=True).warning(
"Could not import Flash Attention enabled models"